120 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			120 lines
		
	
	
		
			4.5 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__ */
 |