blob: a8e652dcdab159a7562fd1c7707c6a0b9e56ca55 [file] [log] [blame]
Damjan Marionb4d89272016-05-12 22:14:45 +02001/*
2 * Copyright (c) 2016 Cisco and/or its affiliates.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at:
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16#ifndef included_ixge_h
17#define included_ixge_h
18
19#include <vnet/vnet.h>
20#include <vlib/pci/pci.h>
21#include <vlib/i2c.h>
22#include <vnet/devices/nic/sfp.h>
23#include <vnet/ip/ip4_packet.h>
24#include <vnet/ip/ip6_packet.h>
25
Damjan Marion00a9dca2016-08-17 17:05:46 +020026typedef volatile struct
27{
Damjan Marionb4d89272016-05-12 22:14:45 +020028 /* [31:7] 128 byte aligned. */
29 u32 descriptor_address[2];
30 u32 n_descriptor_bytes;
31
32 /* [5] rx/tx descriptor dca enable
33 [6] rx packet head dca enable
34 [7] rx packet tail dca enable
35 [9] rx/tx descriptor relaxed order
36 [11] rx/tx descriptor write back relaxed order
37 [13] rx/tx data write/read relaxed order
38 [15] rx head data write relaxed order
39 [31:24] apic id for cpu's cache. */
40 u32 dca_control;
41
42 u32 head_index;
43
44 /* [4:0] tail buffer size (in 1k byte units)
45 [13:8] head buffer size (in 64 byte units)
46 [24:22] lo free descriptors threshold (units of 64 descriptors)
47 [27:25] descriptor type 0 = legacy, 1 = advanced one buffer (e.g. tail),
48 2 = advanced header splitting (head + tail), 5 = advanced header
49 splitting (head only).
50 [28] drop if no descriptors available. */
51 u32 rx_split_control;
52
53 u32 tail_index;
Damjan Marion00a9dca2016-08-17 17:05:46 +020054 CLIB_PAD_FROM_TO (0x1c, 0x28);
Damjan Marionb4d89272016-05-12 22:14:45 +020055
56 /* [7:0] rx/tx prefetch threshold
57 [15:8] rx/tx host threshold
58 [24:16] rx/tx write back threshold
59 [25] rx/tx enable
60 [26] tx descriptor writeback flush
61 [30] rx strip vlan enable */
62 u32 control;
63
64 u32 rx_coallesce_control;
65
Damjan Marion00a9dca2016-08-17 17:05:46 +020066 union
67 {
68 struct
69 {
Damjan Marionb4d89272016-05-12 22:14:45 +020070 /* packets bytes lo hi */
71 u32 stats[3];
72
73 u32 unused;
74 } rx;
75
Damjan Marion00a9dca2016-08-17 17:05:46 +020076 struct
77 {
Damjan Marionb4d89272016-05-12 22:14:45 +020078 u32 unused[2];
79
80 /* [0] enables head write back. */
81 u32 head_index_write_back_address[2];
82 } tx;
83 };
84} ixge_dma_regs_t;
85
86/* Only advanced descriptors are supported. */
Damjan Marion00a9dca2016-08-17 17:05:46 +020087typedef struct
88{
Damjan Marionb4d89272016-05-12 22:14:45 +020089 u64 tail_address;
90 u64 head_address;
91} ixge_rx_to_hw_descriptor_t;
92
Damjan Marion00a9dca2016-08-17 17:05:46 +020093typedef struct
94{
Damjan Marionb4d89272016-05-12 22:14:45 +020095 u32 status[3];
96 u16 n_packet_bytes_this_descriptor;
97 u16 vlan_tag;
98} ixge_rx_from_hw_descriptor_t;
99
100#define IXGE_RX_DESCRIPTOR_STATUS0_IS_LAYER2 (1 << (4 + 11))
101/* Valid if not layer2. */
102#define IXGE_RX_DESCRIPTOR_STATUS0_IS_IP4 (1 << (4 + 0))
103#define IXGE_RX_DESCRIPTOR_STATUS0_IS_IP4_EXT (1 << (4 + 1))
104#define IXGE_RX_DESCRIPTOR_STATUS0_IS_IP6 (1 << (4 + 2))
105#define IXGE_RX_DESCRIPTOR_STATUS0_IS_IP6_EXT (1 << (4 + 3))
106#define IXGE_RX_DESCRIPTOR_STATUS0_IS_TCP (1 << (4 + 4))
107#define IXGE_RX_DESCRIPTOR_STATUS0_IS_UDP (1 << (4 + 5))
108#define IXGE_RX_DESCRIPTOR_STATUS0_L3_OFFSET(s) (((s) >> 21) & 0x3ff)
109
110#define IXGE_RX_DESCRIPTOR_STATUS2_IS_OWNED_BY_SOFTWARE (1 << (0 + 0))
111#define IXGE_RX_DESCRIPTOR_STATUS2_IS_END_OF_PACKET (1 << (0 + 1))
112#define IXGE_RX_DESCRIPTOR_STATUS2_IS_VLAN (1 << (0 + 3))
113#define IXGE_RX_DESCRIPTOR_STATUS2_IS_UDP_CHECKSUMMED (1 << (0 + 4))
114#define IXGE_RX_DESCRIPTOR_STATUS2_IS_TCP_CHECKSUMMED (1 << (0 + 5))
115#define IXGE_RX_DESCRIPTOR_STATUS2_IS_IP4_CHECKSUMMED (1 << (0 + 6))
116#define IXGE_RX_DESCRIPTOR_STATUS2_NOT_UNICAST (1 << (0 + 7))
117#define IXGE_RX_DESCRIPTOR_STATUS2_IS_DOUBLE_VLAN (1 << (0 + 9))
118#define IXGE_RX_DESCRIPTOR_STATUS2_UDP_CHECKSUM_ERROR (1 << (0 + 10))
119#define IXGE_RX_DESCRIPTOR_STATUS2_ETHERNET_ERROR (1 << (20 + 9))
120#define IXGE_RX_DESCRIPTOR_STATUS2_TCP_CHECKSUM_ERROR (1 << (20 + 10))
121#define IXGE_RX_DESCRIPTOR_STATUS2_IP4_CHECKSUM_ERROR (1 << (20 + 11))
122
123/* For layer2 packets stats0 bottom 3 bits give ether type index from filter. */
124#define IXGE_RX_DESCRIPTOR_STATUS0_LAYER2_ETHERNET_TYPE(s) ((s) & 7)
125
Damjan Marion00a9dca2016-08-17 17:05:46 +0200126typedef struct
127{
Damjan Marionb4d89272016-05-12 22:14:45 +0200128 u64 buffer_address;
129 u16 n_bytes_this_buffer;
130 u16 status0;
131 u32 status1;
132#define IXGE_TX_DESCRIPTOR_STATUS0_ADVANCED (3 << 4)
133#define IXGE_TX_DESCRIPTOR_STATUS0_IS_ADVANCED (1 << (8 + 5))
134#define IXGE_TX_DESCRIPTOR_STATUS0_LOG2_REPORT_STATUS (8 + 3)
135#define IXGE_TX_DESCRIPTOR_STATUS0_REPORT_STATUS (1 << IXGE_TX_DESCRIPTOR_STATUS0_LOG2_REPORT_STATUS)
136#define IXGE_TX_DESCRIPTOR_STATUS0_INSERT_FCS (1 << (8 + 1))
137#define IXGE_TX_DESCRIPTOR_STATUS0_LOG2_IS_END_OF_PACKET (8 + 0)
138#define IXGE_TX_DESCRIPTOR_STATUS0_IS_END_OF_PACKET (1 << IXGE_TX_DESCRIPTOR_STATUS0_LOG2_IS_END_OF_PACKET)
139#define IXGE_TX_DESCRIPTOR_STATUS1_DONE (1 << 0)
140#define IXGE_TX_DESCRIPTOR_STATUS1_CONTEXT(i) (/* valid */ (1 << 7) | ((i) << 4))
141#define IXGE_TX_DESCRIPTOR_STATUS1_IPSEC_OFFLOAD (1 << (8 + 2))
142#define IXGE_TX_DESCRIPTOR_STATUS1_INSERT_TCP_UDP_CHECKSUM (1 << (8 + 1))
143#define IXGE_TX_DESCRIPTOR_STATUS1_INSERT_IP4_CHECKSUM (1 << (8 + 0))
144#define IXGE_TX_DESCRIPTOR_STATUS0_N_BYTES_THIS_BUFFER(l) ((l) << 0)
145#define IXGE_TX_DESCRIPTOR_STATUS1_N_BYTES_IN_PACKET(l) ((l) << 14)
146} ixge_tx_descriptor_t;
147
Damjan Marion00a9dca2016-08-17 17:05:46 +0200148typedef struct
149{
150 struct
151 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200152 u8 checksum_start_offset;
153 u8 checksum_insert_offset;
154 u16 checksum_end_offset;
155 } ip, tcp;
156 u32 status0;
157
158 u8 status1;
159
160 /* Byte offset after UDP/TCP header. */
161 u8 payload_offset;
162
163 u16 max_tcp_segment_size;
164} __attribute__ ((packed)) ixge_tx_context_descriptor_t;
165
Damjan Marion00a9dca2016-08-17 17:05:46 +0200166typedef union
167{
Damjan Marionb4d89272016-05-12 22:14:45 +0200168 ixge_rx_to_hw_descriptor_t rx_to_hw;
169 ixge_rx_from_hw_descriptor_t rx_from_hw;
170 ixge_tx_descriptor_t tx;
171 u32x4 as_u32x4;
172} ixge_descriptor_t;
173
Damjan Marion00a9dca2016-08-17 17:05:46 +0200174typedef volatile struct
175{
Damjan Marionb4d89272016-05-12 22:14:45 +0200176 /* [2] pcie master disable
177 [3] mac reset
178 [26] global device reset */
179 u32 control;
180 u32 control_alias;
181 /* [3:2] device id (0 or 1 for dual port chips)
182 [7] link is up
183 [17:10] num vfs
184 [18] io active
185 [19] pcie master enable status */
186 u32 status_read_only;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200187 CLIB_PAD_FROM_TO (0xc, 0x18);
Damjan Marionb4d89272016-05-12 22:14:45 +0200188 /* [14] pf reset done
189 [17] relaxed ordering disable
190 [26] extended vlan enable
191 [28] driver loaded */
192 u32 extended_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200193 CLIB_PAD_FROM_TO (0x1c, 0x20);
Damjan Marionb4d89272016-05-12 22:14:45 +0200194
195 /* software definable pins.
196 sdp_data [7:0]
197 sdp_is_output [15:8]
198 sdp_is_native [23:16]
199 sdp_function [31:24].
Damjan Marion00a9dca2016-08-17 17:05:46 +0200200 */
Damjan Marionb4d89272016-05-12 22:14:45 +0200201 u32 sdp_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200202 CLIB_PAD_FROM_TO (0x24, 0x28);
Damjan Marionb4d89272016-05-12 22:14:45 +0200203
204 /* [0] i2c clock in
205 [1] i2c clock out
206 [2] i2c data in
207 [3] i2c data out */
208 u32 i2c_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200209 CLIB_PAD_FROM_TO (0x2c, 0x4c);
Damjan Marionb4d89272016-05-12 22:14:45 +0200210 u32 tcp_timer;
211
Damjan Marion00a9dca2016-08-17 17:05:46 +0200212 CLIB_PAD_FROM_TO (0x50, 0x200);
Damjan Marionb4d89272016-05-12 22:14:45 +0200213
214 u32 led_control;
215
Damjan Marion00a9dca2016-08-17 17:05:46 +0200216 CLIB_PAD_FROM_TO (0x204, 0x600);
Damjan Marionb4d89272016-05-12 22:14:45 +0200217 u32 core_spare;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200218 CLIB_PAD_FROM_TO (0x604, 0x700);
Damjan Marionb4d89272016-05-12 22:14:45 +0200219
Damjan Marion00a9dca2016-08-17 17:05:46 +0200220 struct
221 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200222 u32 vflr_events_clear[4];
223 u32 mailbox_interrupt_status[4];
224 u32 mailbox_interrupt_enable[4];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200225 CLIB_PAD_FROM_TO (0x730, 0x800);
Damjan Marionb4d89272016-05-12 22:14:45 +0200226 } pf_foo;
227
Damjan Marion00a9dca2016-08-17 17:05:46 +0200228 struct
229 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200230 u32 status_write_1_to_clear;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200231 CLIB_PAD_FROM_TO (0x804, 0x808);
Damjan Marionb4d89272016-05-12 22:14:45 +0200232 u32 status_write_1_to_set;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200233 CLIB_PAD_FROM_TO (0x80c, 0x810);
Damjan Marionb4d89272016-05-12 22:14:45 +0200234 u32 status_auto_clear_enable;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200235 CLIB_PAD_FROM_TO (0x814, 0x820);
Damjan Marionb4d89272016-05-12 22:14:45 +0200236
237 /* [11:3] minimum inter-interrupt interval
Damjan Marion00a9dca2016-08-17 17:05:46 +0200238 (2e-6 units; 20e-6 units for fast ethernet).
Damjan Marionb4d89272016-05-12 22:14:45 +0200239 [15] low-latency interrupt moderation enable
240 [20:16] low-latency interrupt credit
241 [27:21] interval counter
242 [31] write disable for credit and counter (write only). */
243 u32 throttle0[24];
244
245 u32 enable_write_1_to_set;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200246 CLIB_PAD_FROM_TO (0x884, 0x888);
Damjan Marionb4d89272016-05-12 22:14:45 +0200247 u32 enable_write_1_to_clear;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200248 CLIB_PAD_FROM_TO (0x88c, 0x890);
Damjan Marionb4d89272016-05-12 22:14:45 +0200249 u32 enable_auto_clear;
250 u32 msi_to_eitr_select;
251 /* [3:0] spd 0-3 interrupt detection enable
252 [4] msi-x enable
253 [5] other clear disable (makes other bits in status not clear on read)
254 etc. */
255 u32 control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200256 CLIB_PAD_FROM_TO (0x89c, 0x900);
Damjan Marionb4d89272016-05-12 22:14:45 +0200257
258 /* Defines interrupt mapping for 128 rx + 128 tx queues.
259 64 x 4 8 bit entries.
260 For register [i]:
Damjan Marion00a9dca2016-08-17 17:05:46 +0200261 [5:0] bit in interrupt status for rx queue 2*i + 0
262 [7] valid bit
263 [13:8] bit for tx queue 2*i + 0
264 [15] valid bit
265 similar for rx 2*i + 1 and tx 2*i + 1. */
Damjan Marionb4d89272016-05-12 22:14:45 +0200266 u32 queue_mapping[64];
267
268 /* tcp timer [7:0] and other interrupts [15:8] */
269 u32 misc_mapping;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200270 CLIB_PAD_FROM_TO (0xa04, 0xa90);
Damjan Marionb4d89272016-05-12 22:14:45 +0200271
272 /* 64 interrupts determined by mappings. */
273 u32 status1_write_1_to_clear[4];
274 u32 enable1_write_1_to_set[4];
275 u32 enable1_write_1_to_clear[4];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200276 CLIB_PAD_FROM_TO (0xac0, 0xad0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200277 u32 status1_enable_auto_clear[4];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200278 CLIB_PAD_FROM_TO (0xae0, 0x1000);
Damjan Marionb4d89272016-05-12 22:14:45 +0200279 } interrupt;
280
281 ixge_dma_regs_t rx_dma0[64];
282
Damjan Marion00a9dca2016-08-17 17:05:46 +0200283 CLIB_PAD_FROM_TO (0x2000, 0x2140);
Damjan Marionb4d89272016-05-12 22:14:45 +0200284 u32 dcb_rx_packet_plane_t4_config[8];
285 u32 dcb_rx_packet_plane_t4_status[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200286 CLIB_PAD_FROM_TO (0x2180, 0x2300);
Damjan Marionb4d89272016-05-12 22:14:45 +0200287
288 /* reg i defines mapping for 4 rx queues starting at 4*i + 0. */
289 u32 rx_queue_stats_mapping[32];
290 u32 rx_queue_stats_control;
291
Damjan Marion00a9dca2016-08-17 17:05:46 +0200292 CLIB_PAD_FROM_TO (0x2384, 0x2410);
Damjan Marionb4d89272016-05-12 22:14:45 +0200293 u32 fc_user_descriptor_ptr[2];
294 u32 fc_buffer_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200295 CLIB_PAD_FROM_TO (0x241c, 0x2420);
Damjan Marionb4d89272016-05-12 22:14:45 +0200296 u32 fc_rx_dma;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200297 CLIB_PAD_FROM_TO (0x2424, 0x2430);
Damjan Marionb4d89272016-05-12 22:14:45 +0200298 u32 dcb_packet_plane_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200299 CLIB_PAD_FROM_TO (0x2434, 0x2f00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200300
301 u32 rx_dma_control;
302 u32 pf_queue_drop_enable;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200303 CLIB_PAD_FROM_TO (0x2f08, 0x2f20);
Damjan Marionb4d89272016-05-12 22:14:45 +0200304 u32 rx_dma_descriptor_cache_config;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200305 CLIB_PAD_FROM_TO (0x2f24, 0x3000);
Damjan Marionb4d89272016-05-12 22:14:45 +0200306
307 /* 1 bit. */
308 u32 rx_enable;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200309 CLIB_PAD_FROM_TO (0x3004, 0x3008);
Damjan Marionb4d89272016-05-12 22:14:45 +0200310 /* [15:0] ether type (little endian)
311 [31:16] opcode (big endian) */
312 u32 flow_control_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200313 CLIB_PAD_FROM_TO (0x300c, 0x3020);
Damjan Marionb4d89272016-05-12 22:14:45 +0200314 /* 3 bit traffic class for each of 8 priorities. */
315 u32 rx_priority_to_traffic_class;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200316 CLIB_PAD_FROM_TO (0x3024, 0x3028);
Damjan Marionb4d89272016-05-12 22:14:45 +0200317 u32 rx_coallesce_data_buffer_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200318 CLIB_PAD_FROM_TO (0x302c, 0x3190);
Damjan Marionb4d89272016-05-12 22:14:45 +0200319 u32 rx_packet_buffer_flush_detect;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200320 CLIB_PAD_FROM_TO (0x3194, 0x3200);
321 u32 flow_control_tx_timers[4]; /* 2 timer values */
322 CLIB_PAD_FROM_TO (0x3210, 0x3220);
Damjan Marionb4d89272016-05-12 22:14:45 +0200323 u32 flow_control_rx_threshold_lo[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200324 CLIB_PAD_FROM_TO (0x3240, 0x3260);
Damjan Marionb4d89272016-05-12 22:14:45 +0200325 u32 flow_control_rx_threshold_hi[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200326 CLIB_PAD_FROM_TO (0x3280, 0x32a0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200327 u32 flow_control_refresh_threshold;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200328 CLIB_PAD_FROM_TO (0x32a4, 0x3c00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200329 /* For each of 8 traffic classes (units of bytes). */
330 u32 rx_packet_buffer_size[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200331 CLIB_PAD_FROM_TO (0x3c20, 0x3d00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200332 u32 flow_control_config;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200333 CLIB_PAD_FROM_TO (0x3d04, 0x4200);
Damjan Marionb4d89272016-05-12 22:14:45 +0200334
Damjan Marion00a9dca2016-08-17 17:05:46 +0200335 struct
336 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200337 u32 pcs_config;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200338 CLIB_PAD_FROM_TO (0x4204, 0x4208);
Damjan Marionb4d89272016-05-12 22:14:45 +0200339 u32 link_control;
340 u32 link_status;
341 u32 pcs_debug[2];
342 u32 auto_negotiation;
343 u32 link_partner_ability;
344 u32 auto_negotiation_tx_next_page;
345 u32 auto_negotiation_link_partner_next_page;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200346 CLIB_PAD_FROM_TO (0x4228, 0x4240);
Damjan Marionb4d89272016-05-12 22:14:45 +0200347 } gige_mac;
348
Damjan Marion00a9dca2016-08-17 17:05:46 +0200349 struct
350 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200351 /* [0] tx crc enable
352 [2] enable frames up to max frame size register [31:16]
353 [10] pad frames < 64 bytes if specified by user
354 [15] loopback enable
355 [16] mdc hi speed
356 [17] turn off mdc between mdio packets */
357 u32 control;
358
359 /* [5] rx symbol error (all bits clear on read)
360 [6] rx illegal symbol
361 [7] rx idle error
362 [8] rx local fault
363 [9] rx remote fault */
364 u32 status;
365
366 u32 pause_and_pace_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200367 CLIB_PAD_FROM_TO (0x424c, 0x425c);
Damjan Marionb4d89272016-05-12 22:14:45 +0200368 u32 phy_command;
369 u32 phy_data;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200370 CLIB_PAD_FROM_TO (0x4264, 0x4268);
Damjan Marionb4d89272016-05-12 22:14:45 +0200371
372 /* [31:16] max frame size in bytes. */
373 u32 rx_max_frame_size;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200374 CLIB_PAD_FROM_TO (0x426c, 0x4288);
Damjan Marionb4d89272016-05-12 22:14:45 +0200375
376 /* [0]
Damjan Marion00a9dca2016-08-17 17:05:46 +0200377 [2] pcs receive link up? (latch lo)
378 [7] local fault
Damjan Marionb4d89272016-05-12 22:14:45 +0200379 [1]
Damjan Marion00a9dca2016-08-17 17:05:46 +0200380 [0] pcs 10g base r capable
381 [1] pcs 10g base x capable
382 [2] pcs 10g base w capable
383 [10] rx local fault
384 [11] tx local fault
385 [15:14] 2 => device present at this address (else not present) */
Damjan Marionb4d89272016-05-12 22:14:45 +0200386 u32 xgxs_status[2];
387
388 u32 base_x_pcs_status;
389
390 /* [0] pass unrecognized flow control frames
391 [1] discard pause frames
392 [2] rx priority flow control enable (only in dcb mode)
393 [3] rx flow control enable. */
394 u32 flow_control;
395
396 /* [3:0] tx lanes change polarity
397 [7:4] rx lanes change polarity
398 [11:8] swizzle tx lanes
399 [15:12] swizzle rx lanes
400 4 x 2 bit tx lane swap
401 4 x 2 bit rx lane swap. */
402 u32 serdes_control;
403
404 u32 fifo_control;
405
406 /* [0] force link up
407 [1] autoneg ack2 bit to transmit
408 [6:2] autoneg selector field to transmit
409 [8:7] 10g pma/pmd type 0 => xaui, 1 kx4, 2 cx4
410 [9] 1g pma/pmd type 0 => sfi, 1 => kx/bx
411 [10] disable 10g on without main power
412 [11] restart autoneg on transition to dx power state
413 [12] restart autoneg
414 [15:13] link mode:
Damjan Marion00a9dca2016-08-17 17:05:46 +0200415 0 => 1g no autoneg
416 1 => 10g kx4 parallel link no autoneg
417 2 => 1g bx autoneg
418 3 => 10g sfi serdes
419 4 => kx4/kx/kr
420 5 => xgmii 1g/100m
421 6 => kx4/kx/kr 1g an
422 7 kx4/kx/kr sgmii.
Damjan Marionb4d89272016-05-12 22:14:45 +0200423 [16] kr support
424 [17] fec requested
425 [18] fec ability
426 etc. */
427 u32 auto_negotiation_control;
428
429 /* [0] signal detect 1g/100m
430 [1] fec signal detect
431 [2] 10g serial pcs fec block lock
432 [3] 10g serial high error rate
433 [4] 10g serial pcs block lock
434 [5] kx/kx4/kr autoneg next page received
435 [6] kx/kx4/kr backplane autoneg next page received
436 [7] link status clear to read
437 [11:8] 10g signal detect (4 lanes) (for serial just lane 0)
438 [12] 10g serial signal detect
439 [16:13] 10g parallel lane sync status
440 [17] 10g parallel align status
441 [18] 1g sync status
442 [19] kx/kx4/kr backplane autoneg is idle
443 [20] 1g autoneg enabled
444 [21] 1g pcs enabled for sgmii
445 [22] 10g xgxs enabled
446 [23] 10g serial fec enabled (forward error detection)
447 [24] 10g kr pcs enabled
448 [25] sgmii enabled
449 [27:26] mac link mode
Damjan Marion00a9dca2016-08-17 17:05:46 +0200450 0 => 1g
451 1 => 10g parallel
452 2 => 10g serial
453 3 => autoneg
Damjan Marionb4d89272016-05-12 22:14:45 +0200454 [29:28] link speed
Damjan Marion00a9dca2016-08-17 17:05:46 +0200455 1 => 100m
456 2 => 1g
457 3 => 10g
Damjan Marionb4d89272016-05-12 22:14:45 +0200458 [30] link is up
459 [31] kx/kx4/kr backplane autoneg completed successfully. */
460 u32 link_status;
461
462 /* [17:16] pma/pmd for 10g serial
Damjan Marion00a9dca2016-08-17 17:05:46 +0200463 0 => kr, 2 => sfi
Damjan Marionb4d89272016-05-12 22:14:45 +0200464 [18] disable dme pages */
465 u32 auto_negotiation_control2;
466
Damjan Marion00a9dca2016-08-17 17:05:46 +0200467 CLIB_PAD_FROM_TO (0x42ac, 0x42b0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200468 u32 link_partner_ability[2];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200469 CLIB_PAD_FROM_TO (0x42b8, 0x42d0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200470 u32 manageability_control;
471 u32 link_partner_next_page[2];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200472 CLIB_PAD_FROM_TO (0x42dc, 0x42e0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200473 u32 kr_pcs_control;
474 u32 kr_pcs_status;
475 u32 fec_status[2];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200476 CLIB_PAD_FROM_TO (0x42f0, 0x4314);
Damjan Marionb4d89272016-05-12 22:14:45 +0200477 u32 sgmii_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200478 CLIB_PAD_FROM_TO (0x4318, 0x4324);
Damjan Marionb4d89272016-05-12 22:14:45 +0200479 u32 link_status2;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200480 CLIB_PAD_FROM_TO (0x4328, 0x4900);
Damjan Marionb4d89272016-05-12 22:14:45 +0200481 } xge_mac;
482
483 u32 tx_dcb_control;
484 u32 tx_dcb_descriptor_plane_queue_select;
485 u32 tx_dcb_descriptor_plane_t1_config;
486 u32 tx_dcb_descriptor_plane_t1_status;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200487 CLIB_PAD_FROM_TO (0x4910, 0x4950);
Damjan Marionb4d89272016-05-12 22:14:45 +0200488
489 /* For each TC in units of 1k bytes. */
490 u32 tx_packet_buffer_thresholds[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200491 CLIB_PAD_FROM_TO (0x4970, 0x4980);
492 struct
493 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200494 u32 mmw;
495 u32 config;
496 u32 status;
497 u32 rate_drift;
498 } dcb_tx_rate_scheduler;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200499 CLIB_PAD_FROM_TO (0x4990, 0x4a80);
Damjan Marionb4d89272016-05-12 22:14:45 +0200500 u32 tx_dma_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200501 CLIB_PAD_FROM_TO (0x4a84, 0x4a88);
Damjan Marionb4d89272016-05-12 22:14:45 +0200502 u32 tx_dma_tcp_flags_control[2];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200503 CLIB_PAD_FROM_TO (0x4a90, 0x4b00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200504 u32 pf_mailbox[64];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200505 CLIB_PAD_FROM_TO (0x4c00, 0x5000);
Damjan Marionb4d89272016-05-12 22:14:45 +0200506
507 /* RX */
508 u32 checksum_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200509 CLIB_PAD_FROM_TO (0x5004, 0x5008);
Damjan Marionb4d89272016-05-12 22:14:45 +0200510 u32 rx_filter_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200511 CLIB_PAD_FROM_TO (0x500c, 0x5010);
Damjan Marionb4d89272016-05-12 22:14:45 +0200512 u32 management_vlan_tag[8];
513 u32 management_udp_tcp_ports[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200514 CLIB_PAD_FROM_TO (0x5050, 0x5078);
Damjan Marionb4d89272016-05-12 22:14:45 +0200515 /* little endian. */
516 u32 extended_vlan_ether_type;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200517 CLIB_PAD_FROM_TO (0x507c, 0x5080);
Damjan Marionb4d89272016-05-12 22:14:45 +0200518 /* [1] store/dma bad packets
519 [8] accept all multicast
520 [9] accept all unicast
521 [10] accept all broadcast. */
522 u32 filter_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200523 CLIB_PAD_FROM_TO (0x5084, 0x5088);
Damjan Marionb4d89272016-05-12 22:14:45 +0200524 /* [15:0] vlan ethernet type (0x8100) little endian
525 [28] cfi bit expected
526 [29] drop packets with unexpected cfi bit
527 [30] vlan filter enable. */
528 u32 vlan_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200529 CLIB_PAD_FROM_TO (0x508c, 0x5090);
Damjan Marionb4d89272016-05-12 22:14:45 +0200530 /* [1:0] hi bit of ethernet address for 12 bit index into multicast table
Damjan Marion00a9dca2016-08-17 17:05:46 +0200531 0 => 47, 1 => 46, 2 => 45, 3 => 43.
Damjan Marionb4d89272016-05-12 22:14:45 +0200532 [2] enable multicast filter
533 */
534 u32 multicast_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200535 CLIB_PAD_FROM_TO (0x5094, 0x5100);
Damjan Marionb4d89272016-05-12 22:14:45 +0200536 u32 fcoe_rx_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200537 CLIB_PAD_FROM_TO (0x5104, 0x5108);
Damjan Marionb4d89272016-05-12 22:14:45 +0200538 u32 fc_flt_context;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200539 CLIB_PAD_FROM_TO (0x510c, 0x5110);
Damjan Marionb4d89272016-05-12 22:14:45 +0200540 u32 fc_filter_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200541 CLIB_PAD_FROM_TO (0x5114, 0x5120);
Damjan Marionb4d89272016-05-12 22:14:45 +0200542 u32 rx_message_type_lo;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200543 CLIB_PAD_FROM_TO (0x5124, 0x5128);
Damjan Marionb4d89272016-05-12 22:14:45 +0200544 /* [15:0] ethernet type (little endian)
545 [18:16] matche pri in vlan tag
546 [19] priority match enable
547 [25:20] virtualization pool
548 [26] pool enable
549 [27] is fcoe
550 [30] ieee 1588 timestamp enable
551 [31] filter enable.
552 (See ethernet_type_queue_select.) */
553 u32 ethernet_type_queue_filter[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200554 CLIB_PAD_FROM_TO (0x5148, 0x5160);
Damjan Marionb4d89272016-05-12 22:14:45 +0200555 /* [7:0] l2 ethernet type and
556 [15:8] l2 ethernet type or */
557 u32 management_decision_filters1[8];
558 u32 vf_vm_tx_switch_loopback_enable[2];
559 u32 rx_time_sync_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200560 CLIB_PAD_FROM_TO (0x518c, 0x5190);
Damjan Marionb4d89272016-05-12 22:14:45 +0200561 u32 management_ethernet_type_filters[4];
562 u32 rx_timestamp_attributes_lo;
563 u32 rx_timestamp_hi;
564 u32 rx_timestamp_attributes_hi;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200565 CLIB_PAD_FROM_TO (0x51ac, 0x51b0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200566 u32 pf_virtual_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200567 CLIB_PAD_FROM_TO (0x51b4, 0x51d8);
Damjan Marionb4d89272016-05-12 22:14:45 +0200568 u32 fc_offset_parameter;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200569 CLIB_PAD_FROM_TO (0x51dc, 0x51e0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200570 u32 vf_rx_enable[2];
571 u32 rx_timestamp_lo;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200572 CLIB_PAD_FROM_TO (0x51ec, 0x5200);
Damjan Marionb4d89272016-05-12 22:14:45 +0200573 /* 12 bits determined by multicast_control
574 lookup bits in this vector. */
575 u32 multicast_enable[128];
576
577 /* [0] ethernet address [31:0]
578 [1] [15:0] ethernet address [47:32]
Damjan Marion00a9dca2016-08-17 17:05:46 +0200579 [31] valid bit.
Damjan Marionb4d89272016-05-12 22:14:45 +0200580 Index 0 is read from eeprom after reset. */
581 u32 rx_ethernet_address0[16][2];
582
Damjan Marion00a9dca2016-08-17 17:05:46 +0200583 CLIB_PAD_FROM_TO (0x5480, 0x5800);
Damjan Marionb4d89272016-05-12 22:14:45 +0200584 u32 wake_up_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200585 CLIB_PAD_FROM_TO (0x5804, 0x5808);
Damjan Marionb4d89272016-05-12 22:14:45 +0200586 u32 wake_up_filter_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200587 CLIB_PAD_FROM_TO (0x580c, 0x5818);
Damjan Marionb4d89272016-05-12 22:14:45 +0200588 u32 multiple_rx_queue_command_82598;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200589 CLIB_PAD_FROM_TO (0x581c, 0x5820);
Damjan Marionb4d89272016-05-12 22:14:45 +0200590 u32 management_control;
591 u32 management_filter_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200592 CLIB_PAD_FROM_TO (0x5828, 0x5838);
Damjan Marionb4d89272016-05-12 22:14:45 +0200593 u32 wake_up_ip4_address_valid;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200594 CLIB_PAD_FROM_TO (0x583c, 0x5840);
Damjan Marionb4d89272016-05-12 22:14:45 +0200595 u32 wake_up_ip4_address_table[4];
596 u32 management_control_to_host;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200597 CLIB_PAD_FROM_TO (0x5854, 0x5880);
Damjan Marionb4d89272016-05-12 22:14:45 +0200598 u32 wake_up_ip6_address_table[4];
599
600 /* unicast_and broadcast_and vlan_and ip_address_and
601 etc. */
602 u32 management_decision_filters[8];
603
604 u32 management_ip4_or_ip6_address_filters[4][4];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200605 CLIB_PAD_FROM_TO (0x58f0, 0x5900);
Damjan Marionb4d89272016-05-12 22:14:45 +0200606 u32 wake_up_packet_length;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200607 CLIB_PAD_FROM_TO (0x5904, 0x5910);
Damjan Marionb4d89272016-05-12 22:14:45 +0200608 u32 management_ethernet_address_filters[4][2];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200609 CLIB_PAD_FROM_TO (0x5930, 0x5a00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200610 u32 wake_up_packet_memory[32];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200611 CLIB_PAD_FROM_TO (0x5a80, 0x5c00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200612 u32 redirection_table_82598[32];
613 u32 rss_random_keys_82598[10];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200614 CLIB_PAD_FROM_TO (0x5ca8, 0x6000);
Damjan Marionb4d89272016-05-12 22:14:45 +0200615
616 ixge_dma_regs_t tx_dma[128];
617
618 u32 pf_vm_vlan_insert[64];
619 u32 tx_dma_tcp_max_alloc_size_requests;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200620 CLIB_PAD_FROM_TO (0x8104, 0x8110);
Damjan Marionb4d89272016-05-12 22:14:45 +0200621 u32 vf_tx_enable[2];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200622 CLIB_PAD_FROM_TO (0x8118, 0x8120);
Damjan Marionb4d89272016-05-12 22:14:45 +0200623 /* [0] dcb mode enable
624 [1] virtualization mode enable
625 [3:2] number of tcs/qs per pool. */
626 u32 multiple_tx_queues_command;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200627 CLIB_PAD_FROM_TO (0x8124, 0x8200);
Damjan Marionb4d89272016-05-12 22:14:45 +0200628 u32 pf_vf_anti_spoof[8];
629 u32 pf_dma_tx_switch_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200630 CLIB_PAD_FROM_TO (0x8224, 0x82e0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200631 u32 tx_strict_low_latency_queues[4];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200632 CLIB_PAD_FROM_TO (0x82f0, 0x8600);
Damjan Marionb4d89272016-05-12 22:14:45 +0200633 u32 tx_queue_stats_mapping_82599[32];
634 u32 tx_queue_packet_counts[32];
635 u32 tx_queue_byte_counts[32][2];
636
Damjan Marion00a9dca2016-08-17 17:05:46 +0200637 struct
638 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200639 u32 control;
640 u32 status;
641 u32 buffer_almost_full;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200642 CLIB_PAD_FROM_TO (0x880c, 0x8810);
Damjan Marionb4d89272016-05-12 22:14:45 +0200643 u32 buffer_min_ifg;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200644 CLIB_PAD_FROM_TO (0x8814, 0x8900);
Damjan Marionb4d89272016-05-12 22:14:45 +0200645 } tx_security;
646
Damjan Marion00a9dca2016-08-17 17:05:46 +0200647 struct
648 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200649 u32 index;
650 u32 salt;
651 u32 key[4];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200652 CLIB_PAD_FROM_TO (0x8918, 0x8a00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200653 } tx_ipsec;
654
Damjan Marion00a9dca2016-08-17 17:05:46 +0200655 struct
656 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200657 u32 capabilities;
658 u32 control;
659 u32 tx_sci[2];
660 u32 sa;
661 u32 sa_pn[2];
662 u32 key[2][4];
663 /* untagged packets, encrypted packets, protected packets,
664 encrypted bytes, protected bytes */
665 u32 stats[5];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200666 CLIB_PAD_FROM_TO (0x8a50, 0x8c00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200667 } tx_link_security;
668
Damjan Marion00a9dca2016-08-17 17:05:46 +0200669 struct
670 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200671 u32 control;
672 u32 timestamp_value[2];
673 u32 system_time[2];
674 u32 increment_attributes;
675 u32 time_adjustment_offset[2];
676 u32 aux_control;
677 u32 target_time[2][2];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200678 CLIB_PAD_FROM_TO (0x8c34, 0x8c3c);
Damjan Marionb4d89272016-05-12 22:14:45 +0200679 u32 aux_time_stamp[2][2];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200680 CLIB_PAD_FROM_TO (0x8c4c, 0x8d00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200681 } tx_timesync;
682
Damjan Marion00a9dca2016-08-17 17:05:46 +0200683 struct
684 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200685 u32 control;
686 u32 status;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200687 CLIB_PAD_FROM_TO (0x8d08, 0x8e00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200688 } rx_security;
689
Damjan Marion00a9dca2016-08-17 17:05:46 +0200690 struct
691 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200692 u32 index;
693 u32 ip_address[4];
694 u32 spi;
695 u32 ip_index;
696 u32 key[4];
697 u32 salt;
698 u32 mode;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200699 CLIB_PAD_FROM_TO (0x8e34, 0x8f00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200700 } rx_ipsec;
701
Damjan Marion00a9dca2016-08-17 17:05:46 +0200702 struct
703 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200704 u32 capabilities;
705 u32 control;
706 u32 sci[2];
707 u32 sa[2];
708 u32 sa_pn[2];
709 u32 key[2][4];
710 /* see datasheet */
711 u32 stats[17];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200712 CLIB_PAD_FROM_TO (0x8f84, 0x9000);
Damjan Marionb4d89272016-05-12 22:14:45 +0200713 } rx_link_security;
714
715 /* 4 wake up, 2 management, 2 wake up. */
716 u32 flexible_filters[8][16][4];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200717 CLIB_PAD_FROM_TO (0x9800, 0xa000);
Damjan Marionb4d89272016-05-12 22:14:45 +0200718
719 /* 4096 bits. */
720 u32 vlan_filter[128];
721
722 /* [0] ethernet address [31:0]
723 [1] [15:0] ethernet address [47:32]
724 [31] valid bit.
725 Index 0 is read from eeprom after reset. */
726 u32 rx_ethernet_address1[128][2];
727
728 /* select one of 64 pools for each rx address. */
729 u32 rx_ethernet_address_pool_select[128][2];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200730 CLIB_PAD_FROM_TO (0xaa00, 0xc800);
Damjan Marionb4d89272016-05-12 22:14:45 +0200731 u32 tx_priority_to_traffic_class;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200732 CLIB_PAD_FROM_TO (0xc804, 0xcc00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200733
734 /* In bytes units of 1k. Total packet buffer is 160k. */
735 u32 tx_packet_buffer_size[8];
736
Damjan Marion00a9dca2016-08-17 17:05:46 +0200737 CLIB_PAD_FROM_TO (0xcc20, 0xcd10);
Damjan Marionb4d89272016-05-12 22:14:45 +0200738 u32 tx_manageability_tc_mapping;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200739 CLIB_PAD_FROM_TO (0xcd14, 0xcd20);
Damjan Marionb4d89272016-05-12 22:14:45 +0200740 u32 dcb_tx_packet_plane_t2_config[8];
741 u32 dcb_tx_packet_plane_t2_status[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200742 CLIB_PAD_FROM_TO (0xcd60, 0xce00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200743
744 u32 tx_flow_control_status;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200745 CLIB_PAD_FROM_TO (0xce04, 0xd000);
Damjan Marionb4d89272016-05-12 22:14:45 +0200746
747 ixge_dma_regs_t rx_dma1[64];
748
Damjan Marion00a9dca2016-08-17 17:05:46 +0200749 struct
750 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200751 /* Bigendian ip4 src/dst address. */
752 u32 src_address[128];
753 u32 dst_address[128];
754
755 /* TCP/UDP ports [15:0] src [31:16] dst; bigendian. */
756 u32 tcp_udp_port[128];
757
758 /* [1:0] protocol tcp, udp, sctp, other
759 [4:2] match priority (highest wins)
760 [13:8] pool
761 [25] src address match disable
762 [26] dst address match disable
763 [27] src port match disable
764 [28] dst port match disable
765 [29] protocol match disable
766 [30] pool match disable
767 [31] enable. */
768 u32 control[128];
769
770 /* [12] size bypass
771 [19:13] must be 0x80
772 [20] low-latency interrupt
773 [27:21] rx queue. */
774 u32 interrupt[128];
775 } ip4_filters;
776
Damjan Marion00a9dca2016-08-17 17:05:46 +0200777 CLIB_PAD_FROM_TO (0xea00, 0xeb00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200778 /* 4 bit rss output index indexed by 7 bit hash.
779 128 8 bit fields = 32 registers. */
780 u32 redirection_table_82599[32];
781
782 u32 rss_random_key_82599[10];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200783 CLIB_PAD_FROM_TO (0xeba8, 0xec00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200784 /* [15:0] reserved
785 [22:16] rx queue index
786 [29] low-latency interrupt on match
787 [31] enable */
788 u32 ethernet_type_queue_select[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200789 CLIB_PAD_FROM_TO (0xec20, 0xec30);
Damjan Marionb4d89272016-05-12 22:14:45 +0200790 u32 syn_packet_queue_filter;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200791 CLIB_PAD_FROM_TO (0xec34, 0xec60);
Damjan Marionb4d89272016-05-12 22:14:45 +0200792 u32 immediate_interrupt_rx_vlan_priority;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200793 CLIB_PAD_FROM_TO (0xec64, 0xec70);
Damjan Marionb4d89272016-05-12 22:14:45 +0200794 u32 rss_queues_per_traffic_class;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200795 CLIB_PAD_FROM_TO (0xec74, 0xec90);
Damjan Marionb4d89272016-05-12 22:14:45 +0200796 u32 lli_size_threshold;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200797 CLIB_PAD_FROM_TO (0xec94, 0xed00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200798
Damjan Marion00a9dca2016-08-17 17:05:46 +0200799 struct
800 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200801 u32 control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200802 CLIB_PAD_FROM_TO (0xed04, 0xed10);
Damjan Marionb4d89272016-05-12 22:14:45 +0200803 u32 table[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200804 CLIB_PAD_FROM_TO (0xed30, 0xee00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200805 } fcoe_redirection;
806
Damjan Marion00a9dca2016-08-17 17:05:46 +0200807 struct
808 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200809 /* [1:0] packet buffer allocation 0 => disabled, else 64k*2^(f-1)
810 [3] packet buffer initialization done
811 [4] perfetch match mode
812 [5] report status in rss field of rx descriptors
813 [7] report status always
814 [14:8] drop queue
815 [20:16] flex 2 byte packet offset (units of 2 bytes)
816 [27:24] max linked list length
817 [31:28] full threshold. */
818 u32 control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200819 CLIB_PAD_FROM_TO (0xee04, 0xee0c);
Damjan Marionb4d89272016-05-12 22:14:45 +0200820
821 u32 data[8];
822
823 /* [1:0] 0 => no action, 1 => add, 2 => remove, 3 => query.
824 [2] valid filter found by query command
825 [3] filter update override
826 [4] ip6 adress table
827 [6:5] l4 protocol reserved, udp, tcp, sctp
828 [7] is ip6
829 [8] clear head/tail
830 [9] packet drop action
831 [10] matched packet generates low-latency interrupt
832 [11] last in linked list
833 [12] collision
834 [15] rx queue enable
835 [22:16] rx queue
836 [29:24] pool. */
837 u32 command;
838
Damjan Marion00a9dca2016-08-17 17:05:46 +0200839 CLIB_PAD_FROM_TO (0xee30, 0xee3c);
Damjan Marionb4d89272016-05-12 22:14:45 +0200840 /* ip4 dst/src address, tcp ports, udp ports.
841 set bits mean bit is ignored. */
842 u32 ip4_masks[4];
843 u32 filter_length;
844 u32 usage_stats;
845 u32 failed_usage_stats;
846 u32 filters_match_stats;
847 u32 filters_miss_stats;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200848 CLIB_PAD_FROM_TO (0xee60, 0xee68);
Damjan Marionb4d89272016-05-12 22:14:45 +0200849 /* Lookup, signature. */
850 u32 hash_keys[2];
851 /* [15:0] ip6 src address 1 bit per byte
852 [31:16] ip6 dst address. */
853 u32 ip6_mask;
854 /* [0] vlan id
855 [1] vlan priority
856 [2] pool
857 [3] ip protocol
858 [4] flex
859 [5] dst ip6. */
860 u32 other_mask;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200861 CLIB_PAD_FROM_TO (0xee78, 0xf000);
Damjan Marionb4d89272016-05-12 22:14:45 +0200862 } flow_director;
863
Damjan Marion00a9dca2016-08-17 17:05:46 +0200864 struct
865 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200866 u32 l2_control[64];
867 u32 vlan_pool_filter[64];
868 u32 vlan_pool_filter_bitmap[128];
869 u32 dst_ethernet_address[128];
870 u32 mirror_rule[4];
871 u32 mirror_rule_vlan[8];
872 u32 mirror_rule_pool[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200873 CLIB_PAD_FROM_TO (0xf650, 0x10010);
Damjan Marionb4d89272016-05-12 22:14:45 +0200874 } pf_bar;
875
876 u32 eeprom_flash_control;
877 /* [0] start
878 [1] done
879 [15:2] address
880 [31:16] read data. */
881 u32 eeprom_read;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200882 CLIB_PAD_FROM_TO (0x10018, 0x1001c);
Damjan Marionb4d89272016-05-12 22:14:45 +0200883 u32 flash_access;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200884 CLIB_PAD_FROM_TO (0x10020, 0x10114);
Damjan Marionb4d89272016-05-12 22:14:45 +0200885 u32 flash_data;
886 u32 flash_control;
887 u32 flash_read_data;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200888 CLIB_PAD_FROM_TO (0x10120, 0x1013c);
Damjan Marionb4d89272016-05-12 22:14:45 +0200889 u32 flash_opcode;
890 u32 software_semaphore;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200891 CLIB_PAD_FROM_TO (0x10144, 0x10148);
Damjan Marionb4d89272016-05-12 22:14:45 +0200892 u32 firmware_semaphore;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200893 CLIB_PAD_FROM_TO (0x1014c, 0x10160);
Damjan Marionb4d89272016-05-12 22:14:45 +0200894 u32 software_firmware_sync;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200895 CLIB_PAD_FROM_TO (0x10164, 0x10200);
Damjan Marionb4d89272016-05-12 22:14:45 +0200896 u32 general_rx_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200897 CLIB_PAD_FROM_TO (0x10204, 0x11000);
Damjan Marionb4d89272016-05-12 22:14:45 +0200898
Damjan Marion00a9dca2016-08-17 17:05:46 +0200899 struct
900 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200901 u32 control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200902 CLIB_PAD_FROM_TO (0x11004, 0x11010);
Damjan Marionb4d89272016-05-12 22:14:45 +0200903 /* [3:0] enable counters
904 [7:4] leaky bucket counter mode
905 [29] reset
906 [30] stop
907 [31] start. */
908 u32 counter_control;
909 /* [7:0],[15:8],[23:16],[31:24] event for counters 0-3.
910 event codes:
911 0x0 bad tlp
912 0x10 reqs that reached timeout
913 etc. */
914 u32 counter_event;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200915 CLIB_PAD_FROM_TO (0x11018, 0x11020);
Damjan Marionb4d89272016-05-12 22:14:45 +0200916 u32 counters_clear_on_read[4];
917 u32 counter_config[4];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200918 struct
919 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200920 u32 address;
921 u32 data;
922 } indirect_access;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200923 CLIB_PAD_FROM_TO (0x11048, 0x11050);
Damjan Marionb4d89272016-05-12 22:14:45 +0200924 u32 extended_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200925 CLIB_PAD_FROM_TO (0x11054, 0x11064);
Damjan Marionb4d89272016-05-12 22:14:45 +0200926 u32 mirrored_revision_id;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200927 CLIB_PAD_FROM_TO (0x11068, 0x11070);
Damjan Marionb4d89272016-05-12 22:14:45 +0200928 u32 dca_requester_id_information;
929
930 /* [0] global disable
931 [4:1] mode: 0 => legacy, 1 => dca 1.0. */
932 u32 dca_control;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200933 CLIB_PAD_FROM_TO (0x11078, 0x110b0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200934 /* [0] pci completion abort
935 [1] unsupported i/o address
936 [2] wrong byte enable
937 [3] pci timeout */
938 u32 pcie_interrupt_status;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200939 CLIB_PAD_FROM_TO (0x110b4, 0x110b8);
Damjan Marionb4d89272016-05-12 22:14:45 +0200940 u32 pcie_interrupt_enable;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200941 CLIB_PAD_FROM_TO (0x110bc, 0x110c0);
Damjan Marionb4d89272016-05-12 22:14:45 +0200942 u32 msi_x_pba_clear[8];
Damjan Marion00a9dca2016-08-17 17:05:46 +0200943 CLIB_PAD_FROM_TO (0x110e0, 0x12300);
Damjan Marionb4d89272016-05-12 22:14:45 +0200944 } pcie;
945
Damjan Marion00a9dca2016-08-17 17:05:46 +0200946 u32 interrupt_throttle1[128 - 24];
947 CLIB_PAD_FROM_TO (0x124a0, 0x14f00);
Damjan Marionb4d89272016-05-12 22:14:45 +0200948
949 u32 core_analog_config;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200950 CLIB_PAD_FROM_TO (0x14f04, 0x14f10);
Damjan Marionb4d89272016-05-12 22:14:45 +0200951 u32 core_common_config;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200952 CLIB_PAD_FROM_TO (0x14f14, 0x15f14);
Damjan Marionb4d89272016-05-12 22:14:45 +0200953
954 u32 link_sec_software_firmware_interface;
955} ixge_regs_t;
956
Damjan Marion00a9dca2016-08-17 17:05:46 +0200957typedef union
958{
959 struct
960 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200961 /* Addresses bigendian. */
Damjan Marion00a9dca2016-08-17 17:05:46 +0200962 union
963 {
964 struct
965 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200966 ip6_address_t src_address;
967 u32 unused[1];
968 } ip6;
Damjan Marion00a9dca2016-08-17 17:05:46 +0200969 struct
970 {
Damjan Marionb4d89272016-05-12 22:14:45 +0200971 u32 unused[3];
972 ip4_address_t src_address, dst_address;
973 } ip4;
974 };
975
976 /* [15:0] src port (little endian).
977 [31:16] dst port. */
978 u32 tcp_udp_ports;
979
980 /* [15:0] vlan (cfi bit set to 0).
981 [31:16] flex bytes. bigendian. */
982 u32 vlan_and_flex_word;
983
984 /* [14:0] hash
985 [15] bucket valid
986 [31:16] signature (signature filers)/sw-index (perfect match). */
987 u32 hash;
988 };
989
990 u32 as_u32[8];
991} ixge_flow_director_key_t;
992
993always_inline void
994ixge_throttle_queue_interrupt (ixge_regs_t * r,
995 u32 queue_interrupt_index,
996 f64 inter_interrupt_interval_in_secs)
997{
Damjan Marion00a9dca2016-08-17 17:05:46 +0200998 volatile u32 *tr =
Damjan Marionb4d89272016-05-12 22:14:45 +0200999 (queue_interrupt_index < ARRAY_LEN (r->interrupt.throttle0)
1000 ? &r->interrupt.throttle0[queue_interrupt_index]
1001 : &r->interrupt_throttle1[queue_interrupt_index]);
1002 ASSERT (queue_interrupt_index < 128);
1003 u32 v;
1004 i32 i, mask = (1 << 9) - 1;
1005
1006 i = flt_round_nearest (inter_interrupt_interval_in_secs / 2e-6);
1007 i = i < 1 ? 1 : i;
1008 i = i >= mask ? mask : i;
1009
1010 v = tr[0];
1011 v &= ~(mask << 3);
1012 v |= i << 3;
1013 tr[0] = v;
1014}
1015
1016#define foreach_ixge_counter \
1017 _ (0x40d0, rx_total_packets) \
1018 _64 (0x40c0, rx_total_bytes) \
1019 _ (0x41b0, rx_good_packets_before_filtering) \
1020 _64 (0x41b4, rx_good_bytes_before_filtering) \
1021 _ (0x2f50, rx_dma_good_packets) \
1022 _64 (0x2f54, rx_dma_good_bytes) \
1023 _ (0x2f5c, rx_dma_duplicated_good_packets) \
1024 _64 (0x2f60, rx_dma_duplicated_good_bytes) \
1025 _ (0x2f68, rx_dma_good_loopback_packets) \
1026 _64 (0x2f6c, rx_dma_good_loopback_bytes) \
1027 _ (0x2f74, rx_dma_good_duplicated_loopback_packets) \
1028 _64 (0x2f78, rx_dma_good_duplicated_loopback_bytes) \
1029 _ (0x4074, rx_good_packets) \
1030 _64 (0x4088, rx_good_bytes) \
1031 _ (0x407c, rx_multicast_packets) \
1032 _ (0x4078, rx_broadcast_packets) \
1033 _ (0x405c, rx_64_byte_packets) \
1034 _ (0x4060, rx_65_127_byte_packets) \
1035 _ (0x4064, rx_128_255_byte_packets) \
1036 _ (0x4068, rx_256_511_byte_packets) \
1037 _ (0x406c, rx_512_1023_byte_packets) \
1038 _ (0x4070, rx_gt_1023_byte_packets) \
1039 _ (0x4000, rx_crc_errors) \
1040 _ (0x4120, rx_ip_checksum_errors) \
1041 _ (0x4004, rx_illegal_symbol_errors) \
1042 _ (0x4008, rx_error_symbol_errors) \
1043 _ (0x4034, rx_mac_local_faults) \
1044 _ (0x4038, rx_mac_remote_faults) \
1045 _ (0x4040, rx_length_errors) \
1046 _ (0x41a4, rx_xons) \
1047 _ (0x41a8, rx_xoffs) \
1048 _ (0x40a4, rx_undersize_packets) \
1049 _ (0x40a8, rx_fragments) \
1050 _ (0x40ac, rx_oversize_packets) \
1051 _ (0x40b0, rx_jabbers) \
1052 _ (0x40b4, rx_management_packets) \
1053 _ (0x40b8, rx_management_drops) \
1054 _ (0x3fa0, rx_missed_packets_pool_0) \
1055 _ (0x40d4, tx_total_packets) \
1056 _ (0x4080, tx_good_packets) \
1057 _64 (0x4090, tx_good_bytes) \
1058 _ (0x40f0, tx_multicast_packets) \
1059 _ (0x40f4, tx_broadcast_packets) \
1060 _ (0x87a0, tx_dma_good_packets) \
1061 _64 (0x87a4, tx_dma_good_bytes) \
1062 _ (0x40d8, tx_64_byte_packets) \
1063 _ (0x40dc, tx_65_127_byte_packets) \
1064 _ (0x40e0, tx_128_255_byte_packets) \
1065 _ (0x40e4, tx_256_511_byte_packets) \
1066 _ (0x40e8, tx_512_1023_byte_packets) \
1067 _ (0x40ec, tx_gt_1023_byte_packets) \
1068 _ (0x4010, tx_undersize_drops) \
1069 _ (0x8780, switch_security_violation_packets) \
1070 _ (0x5118, fc_crc_errors) \
1071 _ (0x241c, fc_rx_drops) \
1072 _ (0x2424, fc_last_error_count) \
1073 _ (0x2428, fcoe_rx_packets) \
1074 _ (0x242c, fcoe_rx_dwords) \
1075 _ (0x8784, fcoe_tx_packets) \
1076 _ (0x8788, fcoe_tx_dwords) \
1077 _ (0x1030, queue_0_rx_count) \
1078 _ (0x1430, queue_0_drop_count) \
1079 _ (0x1070, queue_1_rx_count) \
1080 _ (0x1470, queue_1_drop_count) \
1081 _ (0x10b0, queue_2_rx_count) \
1082 _ (0x14b0, queue_2_drop_count) \
1083 _ (0x10f0, queue_3_rx_count) \
1084 _ (0x14f0, queue_3_drop_count) \
1085 _ (0x1130, queue_4_rx_count) \
1086 _ (0x1530, queue_4_drop_count) \
1087 _ (0x1170, queue_5_rx_count) \
1088 _ (0x1570, queue_5_drop_count) \
1089 _ (0x11b0, queue_6_rx_count) \
1090 _ (0x15b0, queue_6_drop_count) \
1091 _ (0x11f0, queue_7_rx_count) \
1092 _ (0x15f0, queue_7_drop_count) \
1093 _ (0x1230, queue_8_rx_count) \
1094 _ (0x1630, queue_8_drop_count) \
1095 _ (0x1270, queue_9_rx_count) \
1096 _ (0x1270, queue_9_drop_count)
1097
1098
1099
1100
Damjan Marion00a9dca2016-08-17 17:05:46 +02001101typedef enum
1102{
Damjan Marionb4d89272016-05-12 22:14:45 +02001103#define _(a,f) IXGE_COUNTER_##f,
1104#define _64(a,f) _(a,f)
1105 foreach_ixge_counter
1106#undef _
1107#undef _64
Damjan Marion00a9dca2016-08-17 17:05:46 +02001108 IXGE_N_COUNTER,
Damjan Marionb4d89272016-05-12 22:14:45 +02001109} ixge_counter_type_t;
1110
Damjan Marion00a9dca2016-08-17 17:05:46 +02001111typedef struct
1112{
Damjan Marionb4d89272016-05-12 22:14:45 +02001113 u32 mdio_address;
1114
1115 /* 32 bit ID read from ID registers. */
1116 u32 id;
1117} ixge_phy_t;
1118
Damjan Marion00a9dca2016-08-17 17:05:46 +02001119typedef struct
1120{
Damjan Marionb4d89272016-05-12 22:14:45 +02001121 /* Cache aligned descriptors. */
Damjan Marion00a9dca2016-08-17 17:05:46 +02001122 ixge_descriptor_t *descriptors;
Damjan Marionb4d89272016-05-12 22:14:45 +02001123
1124 /* Number of descriptors in table. */
1125 u32 n_descriptors;
1126
1127 /* Software head and tail pointers into descriptor ring. */
1128 u32 head_index, tail_index;
1129
1130 /* Index into dma_queues vector. */
1131 u32 queue_index;
1132
1133 /* Buffer indices corresponding to each active descriptor. */
Damjan Marion00a9dca2016-08-17 17:05:46 +02001134 u32 *descriptor_buffer_indices;
Damjan Marionb4d89272016-05-12 22:14:45 +02001135
Damjan Marion00a9dca2016-08-17 17:05:46 +02001136 union
1137 {
1138 struct
1139 {
1140 u32 *volatile head_index_write_back;
Damjan Marionb4d89272016-05-12 22:14:45 +02001141
1142 u32 n_buffers_on_ring;
1143 } tx;
1144
Damjan Marion00a9dca2016-08-17 17:05:46 +02001145 struct
1146 {
Damjan Marionb4d89272016-05-12 22:14:45 +02001147 /* Buffer indices to use to replenish each descriptor. */
Damjan Marion00a9dca2016-08-17 17:05:46 +02001148 u32 *replenish_buffer_indices;
Damjan Marionb4d89272016-05-12 22:14:45 +02001149
Damjan Marion00a9dca2016-08-17 17:05:46 +02001150 vlib_node_runtime_t *node;
Damjan Marionb4d89272016-05-12 22:14:45 +02001151 u32 next_index;
1152
1153 u32 saved_start_of_packet_buffer_index;
1154
1155 u32 saved_start_of_packet_next_index;
1156 u32 saved_last_buffer_index;
1157
1158 u32 is_start_of_packet;
1159
1160 u32 n_descriptors_done_total;
1161
1162 u32 n_descriptors_done_this_call;
1163
1164 u32 n_bytes;
1165 } rx;
1166 };
1167} ixge_dma_queue_t;
1168
1169#define foreach_ixge_pci_device_id \
1170 _ (82598, 0x10b6) \
1171 _ (82598_bx, 0x1508) \
1172 _ (82598af_dual_port, 0x10c6) \
1173 _ (82598af_single_port, 0x10c7) \
1174 _ (82598at, 0x10c8) \
1175 _ (82598at2, 0x150b) \
1176 _ (82598eb_sfp_lom, 0x10db) \
1177 _ (82598eb_cx4, 0x10dd) \
1178 _ (82598_cx4_dual_port, 0x10ec) \
1179 _ (82598_da_dual_port, 0x10f1) \
1180 _ (82598_sr_dual_port_em, 0x10e1) \
1181 _ (82598eb_xf_lr, 0x10f4) \
1182 _ (82599_kx4, 0x10f7) \
1183 _ (82599_kx4_mezz, 0x1514) \
1184 _ (82599_kr, 0x1517) \
1185 _ (82599_combo_backplane, 0x10f8) \
1186 _ (82599_cx4, 0x10f9) \
1187 _ (82599_sfp, 0x10fb) \
1188 _ (82599_backplane_fcoe, 0x152a) \
1189 _ (82599_sfp_fcoe, 0x1529) \
1190 _ (82599_sfp_em, 0x1507) \
1191 _ (82599_xaui_lom, 0x10fc) \
1192 _ (82599_t3_lom, 0x151c) \
1193 _ (x540t, 0x1528)
1194
Damjan Marion00a9dca2016-08-17 17:05:46 +02001195typedef enum
1196{
Damjan Marionb4d89272016-05-12 22:14:45 +02001197#define _(f,n) IXGE_##f = n,
1198 foreach_ixge_pci_device_id
1199#undef _
1200} ixge_pci_device_id_t;
1201
Damjan Marion00a9dca2016-08-17 17:05:46 +02001202typedef struct
1203{
Damjan Marionb4d89272016-05-12 22:14:45 +02001204 /* registers */
Damjan Marion00a9dca2016-08-17 17:05:46 +02001205 ixge_regs_t *regs;
Damjan Marionb4d89272016-05-12 22:14:45 +02001206
1207 /* Specific next index when using dynamic redirection */
1208 u32 per_interface_next_index;
1209
1210 /* PCI bus info. */
1211 vlib_pci_device_t pci_device;
1212
1213 /* From PCI config space header. */
1214 ixge_pci_device_id_t device_id;
1215
1216 u16 device_index;
1217
1218 /* 0 or 1. */
1219 u16 pci_function;
1220
1221 /* VLIB interface for this instance. */
1222 u32 vlib_hw_if_index, vlib_sw_if_index;
1223
Damjan Marion00a9dca2016-08-17 17:05:46 +02001224 ixge_dma_queue_t *dma_queues[VLIB_N_RX_TX];
Damjan Marionb4d89272016-05-12 22:14:45 +02001225
1226 /* Phy index (0 or 1) and address on MDI bus. */
1227 u32 phy_index;
1228 ixge_phy_t phys[2];
1229
1230 /* Value of link_status register at last link change. */
1231 u32 link_status_at_last_link_change;
1232
1233 i2c_bus_t i2c_bus;
1234 sfp_eeprom_t sfp_eeprom;
1235
1236 /* Counters. */
1237 u64 counters[IXGE_N_COUNTER], counters_last_clear[IXGE_N_COUNTER];
1238} ixge_device_t;
1239
Damjan Marion00a9dca2016-08-17 17:05:46 +02001240typedef struct
1241{
1242 vlib_main_t *vlib_main;
Damjan Marionb4d89272016-05-12 22:14:45 +02001243
1244 /* Vector of devices. */
Damjan Marion00a9dca2016-08-17 17:05:46 +02001245 ixge_device_t *devices;
Damjan Marionb4d89272016-05-12 22:14:45 +02001246
1247 /* Descriptor ring sizes. */
1248 u32 n_descriptors[VLIB_N_RX_TX];
1249
1250 /* RX buffer size. Must be at least 1k; will be rounded to
1251 next largest 1k size. */
1252 u32 n_bytes_in_rx_buffer;
1253
1254 u32 n_descriptors_per_cache_line;
1255
1256 u32 vlib_buffer_free_list_index;
1257
1258 u32 process_node_index;
1259
1260 /* Template and mask for initializing/validating TX descriptors. */
1261 ixge_tx_descriptor_t tx_descriptor_template, tx_descriptor_template_mask;
1262
1263 /* Vector of buffers for which TX is done and can be freed. */
Damjan Marion00a9dca2016-08-17 17:05:46 +02001264 u32 *tx_buffers_pending_free;
Damjan Marionb4d89272016-05-12 22:14:45 +02001265
Damjan Marion00a9dca2016-08-17 17:05:46 +02001266 u32 *rx_buffers_to_add;
Damjan Marionb4d89272016-05-12 22:14:45 +02001267
1268 f64 time_last_stats_update;
1269} ixge_main_t;
1270
1271ixge_main_t ixge_main;
1272vnet_device_class_t ixge_device_class;
1273
Damjan Marion00a9dca2016-08-17 17:05:46 +02001274typedef enum
1275{
Damjan Marionb4d89272016-05-12 22:14:45 +02001276 IXGE_RX_NEXT_IP4_INPUT,
1277 IXGE_RX_NEXT_IP6_INPUT,
1278 IXGE_RX_NEXT_ETHERNET_INPUT,
1279 IXGE_RX_NEXT_DROP,
1280 IXGE_RX_N_NEXT,
1281} ixge_rx_next_t;
1282
1283void ixge_set_next_node (ixge_rx_next_t, char *);
1284
1285#endif /* included_ixge_h */
Damjan Marion00a9dca2016-08-17 17:05:46 +02001286
1287/*
1288 * fd.io coding-style-patch-verification: ON
1289 *
1290 * Local Variables:
1291 * eval: (c-set-style "gnu")
1292 * End:
1293 */