120 lines
4.4 KiB
C
120 lines
4.4 KiB
C
/*
|
|
* Copyright (c) 2006-2023, RT-Thread Development Team
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2021-11-11 GuEe-GUI the first version
|
|
*/
|
|
|
|
#ifndef __VIRTIO_NET_H__
|
|
#define __VIRTIO_NET_H__
|
|
|
|
#ifdef RT_USING_VIRTIO_NET
|
|
|
|
#include <rtdef.h>
|
|
#include <netif/ethernetif.h>
|
|
|
|
#include <virtio.h>
|
|
|
|
#define VIRTIO_NET_QUEUE_RX 0
|
|
#define VIRTIO_NET_QUEUE_TX 1
|
|
#define VIRTIO_NET_RTX_QUEUE_SIZE 16
|
|
#define VIRTIO_NET_RTX_BUF_SIZE 2048
|
|
|
|
#define VIRTIO_NET_F_CSUM 0 /* Host handles pkts w/ partial csum */
|
|
#define VIRTIO_NET_F_GUEST_CSUM 1 /* Guest handles pkts w/ partial csum */
|
|
#define VIRTIO_NET_F_CTRL_GUEST_OFFLOADS 2 /* Dynamic offload configuration */
|
|
#define VIRTIO_NET_F_MTU 3 /* Initial MTU advice */
|
|
#define VIRTIO_NET_F_MAC 5 /* Host has given MAC address */
|
|
#define VIRTIO_NET_F_GUEST_TSO4 7 /* Guest can handle TSOv4 in */
|
|
#define VIRTIO_NET_F_GUEST_TSO6 8 /* Guest can handle TSOv6 in */
|
|
#define VIRTIO_NET_F_GUEST_ECN 9 /* Guest can handle TSO[6] w/ ECN in */
|
|
#define VIRTIO_NET_F_GUEST_UFO 10 /* Guest can handle UFO in */
|
|
#define VIRTIO_NET_F_HOST_TSO4 11 /* Host can handle TSOv4 in */
|
|
#define VIRTIO_NET_F_HOST_TSO6 12 /* Host can handle TSOv6 in */
|
|
#define VIRTIO_NET_F_HOST_ECN 13 /* Host can handle TSO[6] w/ ECN in */
|
|
#define VIRTIO_NET_F_HOST_UFO 14 /* Host can handle UFO in */
|
|
#define VIRTIO_NET_F_MRG_RXBUF 15 /* Host can merge receive buffers. */
|
|
#define VIRTIO_NET_F_STATUS 16 /* virtio_net_config.status available */
|
|
#define VIRTIO_NET_F_CTRL_VQ 17 /* Control channel available */
|
|
#define VIRTIO_NET_F_CTRL_RX 18 /* Control channel RX mode support */
|
|
#define VIRTIO_NET_F_CTRL_VLAN 19 /* Control channel VLAN filtering */
|
|
#define VIRTIO_NET_F_CTRL_RX_EXTRA 20 /* Extra RX mode control support */
|
|
#define VIRTIO_NET_F_GUEST_ANNOUNCE 21 /* Guest can announce device on the network */
|
|
#define VIRTIO_NET_F_MQ 22 /* Device supports Receive Flow Steering */
|
|
#define VIRTIO_NET_F_CTRL_MAC_ADDR 23 /* Set MAC address */
|
|
|
|
#define VIRTIO_NET_F_HASH_REPORT 57 /* Supports hash report */
|
|
#define VIRTIO_NET_F_RSS 60 /* Supports RSS RX steering */
|
|
#define VIRTIO_NET_F_RSC_EXT 61 /* Extended coalescing info */
|
|
#define VIRTIO_NET_F_STANDBY 62 /* Act as standby for another device with the same MAC */
|
|
#define VIRTIO_NET_F_SPEED_DUPLEX 63 /* Device set linkspeed and duplex */
|
|
|
|
#define VIRTIO_NET_S_LINK_UP (1 << 0)
|
|
#define VIRTIO_NET_S_ANNOUNCE (1 << 1)
|
|
|
|
#define VIRTIO_NET_HDR_F_NEEDS_CSUM 1
|
|
#define VIRTIO_NET_HDR_F_DATA_VALID 2
|
|
#define VIRTIO_NET_HDR_F_RSC_INFO 4
|
|
|
|
#define VIRTIO_NET_HDR_GSO_NONE 0
|
|
#define VIRTIO_NET_HDR_GSO_TCPV4 1
|
|
#define VIRTIO_NET_HDR_GSO_UDP 3
|
|
#define VIRTIO_NET_HDR_GSO_TCPV6 4
|
|
#define VIRTIO_NET_HDR_GSO_ECN 0x80
|
|
|
|
struct virtio_net_hdr
|
|
{
|
|
rt_uint8_t flags;
|
|
rt_uint8_t gso_type;
|
|
rt_uint16_t hdr_len;
|
|
rt_uint16_t gso_size;
|
|
rt_uint16_t csum_start;
|
|
rt_uint16_t csum_offset;
|
|
rt_uint16_t num_buffers;
|
|
} __attribute__ ((packed));
|
|
|
|
#define VIRTIO_NET_MSS 1514
|
|
#define VIRTIO_NET_HDR_SIZE (sizeof(struct virtio_net_hdr))
|
|
#define VIRTIO_NET_PAYLOAD_MAX_SIZE (VIRTIO_NET_HDR_SIZE + VIRTIO_NET_MSS)
|
|
|
|
struct virtio_net_config
|
|
{
|
|
rt_uint8_t mac[6];
|
|
rt_uint16_t status;
|
|
rt_uint16_t max_virtqueue_pairs;
|
|
rt_uint16_t mtu;
|
|
rt_uint32_t speed;
|
|
rt_uint8_t duplex;
|
|
rt_uint8_t rss_max_key_size;
|
|
rt_uint16_t rss_max_indirection_table_length;
|
|
rt_uint32_t supported_hash_types;
|
|
} __attribute__((packed));
|
|
|
|
struct virtio_net_device
|
|
{
|
|
struct eth_device parent;
|
|
|
|
struct virtio_device virtio_dev;
|
|
|
|
struct virtio_net_config *config;
|
|
|
|
struct
|
|
{
|
|
/* Transmit hdr */
|
|
struct virtio_net_hdr hdr;
|
|
/* Transmit buffer */
|
|
rt_uint8_t tx_buffer[VIRTIO_NET_PAYLOAD_MAX_SIZE];
|
|
/* Receive buffer */
|
|
rt_uint8_t rx_buffer[VIRTIO_NET_PAYLOAD_MAX_SIZE];
|
|
} info[VIRTIO_NET_RTX_QUEUE_SIZE];
|
|
};
|
|
|
|
rt_err_t rt_virtio_net_init(rt_ubase_t *mmio_base, rt_uint32_t irq);
|
|
|
|
#endif /* RT_USING_VIRTIO_NET */
|
|
|
|
#endif /* __VIRTIO_NET_H__ */
|