940acbb137245814897dea6eb17e0ac478f7f0a0
[vpp.git] / src / vnet / devices / af_packet / af_packet.h
1 /*
2  *------------------------------------------------------------------
3  * af_packet.h - linux kernel packet interface header file
4  *
5  * Copyright (c) 2016 Cisco and/or its affiliates.
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at:
9  *
10  *     http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  *------------------------------------------------------------------
18  */
19
20 #include <linux/if_packet.h>
21
22 #include <vppinfra/lock.h>
23 #include <vlib/log.h>
24
25 typedef struct tpacket_block_desc block_desc_t;
26 typedef struct tpacket_req3 tpacket_req3_t;
27 typedef struct tpacket3_hdr tpacket3_hdr_t;
28
29 typedef enum
30 {
31   AF_PACKET_IF_MODE_ETHERNET = 1,
32   AF_PACKET_IF_MODE_IP = 2
33 } af_packet_if_mode_t;
34
35 typedef enum
36 {
37   AF_PACKET_IF_FLAGS_QDISC_BYPASS = 1,
38   AF_PACKET_IF_FLAGS_CKSUM_GSO = 2,
39   AF_PACKET_IF_FLAGS_FANOUT = 4,
40 } af_packet_if_flags_t;
41
42 typedef struct
43 {
44   u32 sw_if_index;
45   u8 host_if_name[64];
46 } af_packet_if_detail_t;
47
48 typedef struct
49 {
50   u8 *ring_start_addr;
51   u32 ring_size;
52 } af_packet_ring_t;
53
54 typedef struct
55 {
56   CLIB_CACHE_LINE_ALIGN_MARK (cacheline0);
57   clib_spinlock_t lockp;
58   int fd;
59   union
60   {
61     tpacket_req3_t *rx_req;
62     tpacket_req3_t *tx_req;
63   };
64
65   union
66   {
67     u8 **rx_ring;
68     u8 **tx_ring;
69   };
70
71   union
72   {
73     u32 next_rx_block;
74     u32 next_tx_frame;
75   };
76
77   u16 queue_id;
78   u32 queue_index;
79
80   u32 clib_file_index;
81
82   u32 rx_frame_offset;
83   u16 num_rx_pkts;
84   u8 is_rx_pending;
85   u8 is_tx_pending;
86   vnet_hw_if_rx_mode mode;
87 } af_packet_queue_t;
88
89 typedef struct
90 {
91   CLIB_CACHE_LINE_ALIGN_MARK (cacheline0);
92   u32 hw_if_index;
93   u32 sw_if_index;
94   u32 per_interface_next_index;
95   af_packet_if_mode_t mode;
96   u8 is_admin_up;
97   u8 is_cksum_gso_enabled;
98
99   af_packet_queue_t *rx_queues;
100   af_packet_queue_t *tx_queues;
101
102   u8 num_rxqs;
103   u8 num_txqs;
104
105   u8 *host_if_name;
106   int host_if_index;
107
108   u32 host_mtu;
109   u32 dev_instance;
110
111   af_packet_ring_t *rings;
112   u8 is_qdisc_bypass_enabled;
113   u8 is_fanout_enabled;
114 } af_packet_if_t;
115
116 typedef struct
117 {
118   CLIB_CACHE_LINE_ALIGN_MARK (cacheline0);
119   af_packet_if_t *interfaces;
120
121   u32 polling_count;
122   /* rx buffer cache */
123   u32 **rx_buffers;
124
125   /* hash of host interface names */
126   mhash_t if_index_by_host_if_name;
127
128   /** log class */
129   vlib_log_class_t log_class;
130 } af_packet_main_t;
131
132 typedef struct
133 {
134   u8 *host_if_name;
135   u8 *hw_addr;
136   u32 rx_frame_size;
137   u32 tx_frame_size;
138   u32 rx_frames_per_block;
139   u32 tx_frames_per_block;
140   u8 num_rxqs;
141   u8 num_txqs;
142   af_packet_if_mode_t mode;
143   af_packet_if_flags_t flags;
144
145   /* return */
146   u32 sw_if_index;
147 } af_packet_create_if_arg_t;
148
149 extern af_packet_main_t af_packet_main;
150 extern vnet_device_class_t af_packet_device_class;
151 extern vlib_node_registration_t af_packet_input_node;
152
153 int af_packet_create_if (af_packet_create_if_arg_t *arg);
154 int af_packet_delete_if (u8 *host_if_name);
155 int af_packet_set_l4_cksum_offload (u32 sw_if_index, u8 set);
156 int af_packet_dump_ifs (af_packet_if_detail_t ** out_af_packet_ifs);
157
158 format_function_t format_af_packet_device_name;
159
160 #define MIN(x,y) (((x)<(y))?(x):(y))
161
162 /*
163  * fd.io coding-style-patch-verification: ON
164  *
165  * Local Variables:
166  * eval: (c-set-style "gnu")
167  * End:
168  */