AF_PACKET_IF_MODE_IP = 2
} af_packet_if_mode_t;
+typedef enum
+{
+ AF_PACKET_IF_FLAGS_QDISC_BYPASS = 1,
+ AF_PACKET_IF_FLAGS_CKSUM_GSO = 2,
+ AF_PACKET_IF_FLAGS_FANOUT = 4,
+} af_packet_if_flags_t;
+
typedef struct
{
u32 sw_if_index;
typedef struct
{
- u32 rx_frame_offset;
- u32 num_pkts;
- u8 is_save;
-} save_state_t;
+ u8 *ring_start_addr;
+ u32 ring_size;
+} af_packet_ring_t;
typedef struct
{
CLIB_CACHE_LINE_ALIGN_MARK (cacheline0);
clib_spinlock_t lockp;
- u8 *host_if_name;
- int host_if_index;
int fd;
- tpacket_req3_t *rx_req;
- tpacket_req3_t *tx_req;
- u8 **rx_ring;
- u8 **tx_ring;
- u8 is_cksum_gso_enabled;
- u32 hdrlen;
- u32 hw_if_index;
- u32 sw_if_index;
+ union
+ {
+ tpacket_req3_t *rx_req;
+ tpacket_req3_t *tx_req;
+ };
+
+ union
+ {
+ u8 **rx_ring;
+ u8 **tx_ring;
+ };
+
+ union
+ {
+ u32 next_rx_block;
+ u32 next_tx_frame;
+ };
+
+ u16 queue_id;
+ u32 queue_index;
+
u32 clib_file_index;
- u32 next_rx_block;
- u32 next_tx_frame;
+ u32 rx_frame_offset;
+ u16 num_rx_pkts;
+ u8 is_rx_pending;
+ u8 is_tx_pending;
+ vnet_hw_if_rx_mode mode;
+} af_packet_queue_t;
+typedef struct
+{
+ CLIB_CACHE_LINE_ALIGN_MARK (cacheline0);
+ u32 hw_if_index;
+ u32 sw_if_index;
u32 per_interface_next_index;
+ af_packet_if_mode_t mode;
u8 is_admin_up;
- u32 queue_index;
+ u8 is_cksum_gso_enabled;
+
+ af_packet_queue_t *rx_queues;
+ af_packet_queue_t *tx_queues;
+
+ u8 num_rxqs;
+ u8 num_txqs;
+
+ u8 *host_if_name;
+ int host_if_index;
+
u32 host_mtu;
- af_packet_if_mode_t mode;
- save_state_t ss;
+ u32 dev_instance;
+
+ af_packet_ring_t *rings;
+ u8 is_qdisc_bypass_enabled;
+ u8 is_fanout_enabled;
} af_packet_if_t;
typedef struct
CLIB_CACHE_LINE_ALIGN_MARK (cacheline0);
af_packet_if_t *interfaces;
+ u32 polling_count;
/* rx buffer cache */
u32 **rx_buffers;
u32 tx_frame_size;
u32 rx_frames_per_block;
u32 tx_frames_per_block;
+ u8 num_rxqs;
+ u8 num_txqs;
af_packet_if_mode_t mode;
+ af_packet_if_flags_t flags;
/* return */
u32 sw_if_index;