9b69980eded618a87ffa3250f345e84a71674eb0
[dpdk.git] / drivers / net / ipn3ke / ipn3ke_ethdev.h
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2019 Intel Corporation
3  */
4
5 #ifndef _IPN3KE_ETHDEV_H_
6 #define _IPN3KE_ETHDEV_H_
7
8 #include <stdbool.h>
9 #include <stddef.h>
10 #include <stdint.h>
11 #include <limits.h>
12 #include <net/if.h>
13 #include <netinet/in.h>
14 #include <sys/queue.h>
15
16 #include <rte_mbuf.h>
17 #include <rte_flow_driver.h>
18 #include <rte_ethdev_driver.h>
19 #include <rte_ethdev_vdev.h>
20 #include <rte_malloc.h>
21 #include <rte_memcpy.h>
22 #include <rte_bus_vdev.h>
23 #include <rte_kvargs.h>
24 #include <rte_spinlock.h>
25
26 #include <rte_cycles.h>
27 #include <rte_bus_ifpga.h>
28 #include <rte_tm_driver.h>
29
30 #define IPN3KE_TM_SCRATCH_RW 0
31
32 /* TM Levels */
33 enum ipn3ke_tm_node_level {
34         IPN3KE_TM_NODE_LEVEL_PORT,
35         IPN3KE_TM_NODE_LEVEL_VT,
36         IPN3KE_TM_NODE_LEVEL_COS,
37         IPN3KE_TM_NODE_LEVEL_MAX,
38 };
39
40 /* TM Shaper Profile */
41 struct ipn3ke_tm_shaper_profile {
42         uint32_t valid;
43         uint32_t m;
44         uint32_t e;
45         uint64_t rate;
46         struct rte_tm_shaper_params params;
47 };
48
49 TAILQ_HEAD(ipn3ke_tm_shaper_profile_list, ipn3ke_tm_shaper_profile);
50
51
52 #define IPN3KE_TDROP_TH1_MASK  0x1ffffff
53 #define IPN3KE_TDROP_TH1_SHIFT (25)
54 #define IPN3KE_TDROP_TH2_MASK  0x1ffffff
55
56 /* TM TDROP Profile */
57 struct ipn3ke_tm_tdrop_profile {
58         uint32_t tdrop_profile_id;
59         uint32_t th1;
60         uint32_t th2;
61         uint32_t n_users;
62         uint32_t valid;
63         struct rte_tm_wred_params params;
64 };
65
66 /* TM node priority */
67 enum ipn3ke_tm_node_state {
68         IPN3KE_TM_NODE_STATE_IDLE = 0,
69         IPN3KE_TM_NODE_STATE_CONFIGURED_ADD,
70         IPN3KE_TM_NODE_STATE_CONFIGURED_DEL,
71         IPN3KE_TM_NODE_STATE_COMMITTED,
72         IPN3KE_TM_NODE_STATE_MAX,
73 };
74
75 TAILQ_HEAD(ipn3ke_tm_node_list, ipn3ke_tm_node);
76
77 /* IPN3KE TM Node */
78 struct ipn3ke_tm_node {
79         TAILQ_ENTRY(ipn3ke_tm_node) node;
80         uint32_t node_index;
81         uint32_t level;
82         uint32_t tm_id;
83         enum ipn3ke_tm_node_state node_state;
84         uint32_t parent_node_id;
85         uint32_t priority;
86         uint32_t weight;
87         struct ipn3ke_tm_node *parent_node;
88         struct ipn3ke_tm_shaper_profile shaper_profile;
89         struct ipn3ke_tm_tdrop_profile *tdrop_profile;
90         struct rte_tm_node_params params;
91         struct rte_tm_node_stats stats;
92         uint32_t n_children;
93         struct ipn3ke_tm_node_list children_node_list;
94 };
95
96 /* IPN3KE TM Hierarchy Specification */
97 struct ipn3ke_tm_hierarchy {
98         struct ipn3ke_tm_node *port_node;
99         /*struct ipn3ke_tm_node_list vt_node_list;*/
100         /*struct ipn3ke_tm_node_list cos_node_list;*/
101
102         uint32_t n_shaper_profiles;
103         /*uint32_t n_shared_shapers;*/
104         uint32_t n_tdrop_profiles;
105         uint32_t n_vt_nodes;
106         uint32_t n_cos_nodes;
107
108         struct ipn3ke_tm_node *port_commit_node;
109         struct ipn3ke_tm_node_list vt_commit_node_list;
110         struct ipn3ke_tm_node_list cos_commit_node_list;
111
112         /*uint32_t n_tm_nodes[IPN3KE_TM_NODE_LEVEL_MAX];*/
113 };
114
115 struct ipn3ke_tm_internals {
116         /** Hierarchy specification
117          *
118          *     -Hierarchy is unfrozen at init and when port is stopped.
119          *     -Hierarchy is frozen on successful hierarchy commit.
120          *     -Run-time hierarchy changes are not allowed, therefore it makes
121          *      sense to keep the hierarchy frozen after the port is started.
122          */
123         struct ipn3ke_tm_hierarchy h;
124         int hierarchy_frozen;
125         int tm_started;
126         uint32_t tm_id;
127 };
128
129 #define IPN3KE_TM_COS_NODE_NUM      (64 * 1024)
130 #define IPN3KE_TM_VT_NODE_NUM       (IPN3KE_TM_COS_NODE_NUM / 8)
131 #define IPN3KE_TM_10G_PORT_NODE_NUM (8)
132 #define IPN3KE_TM_25G_PORT_NODE_NUM (4)
133
134 #define IPN3KE_TM_NODE_LEVEL_MOD    (100000)
135 #define IPN3KE_TM_NODE_MOUNT_MAX    (8)
136
137 #define IPN3KE_TM_TDROP_PROFILE_NUM (2 * 1024)
138
139 /* TM node priority */
140 enum ipn3ke_tm_node_priority {
141         IPN3KE_TM_NODE_PRIORITY_NORMAL0 = 0,
142         IPN3KE_TM_NODE_PRIORITY_LOW,
143         IPN3KE_TM_NODE_PRIORITY_NORMAL1,
144         IPN3KE_TM_NODE_PRIORITY_HIGHEST,
145 };
146
147 #define IPN3KE_TM_NODE_WEIGHT_MAX UINT8_MAX
148
149 /** Set a bit in the uint32 variable */
150 #define IPN3KE_BIT_SET(var, pos) \
151         ((var) |= ((uint32_t)1 << ((pos))))
152
153 /** Reset the bit in the variable */
154 #define IPN3KE_BIT_RESET(var, pos) \
155         ((var) &= ~((uint32_t)1 << ((pos))))
156
157 /** Check the bit is set in the variable */
158 #define IPN3KE_BIT_ISSET(var, pos) \
159         (((var) & ((uint32_t)1 << ((pos)))) ? 1 : 0)
160
161 struct ipn3ke_hw;
162
163 #define IPN3KE_HW_BASE               0x4000000
164
165 #define IPN3KE_CAPABILITY_REGISTERS_BLOCK_OFFSET \
166         (IPN3KE_HW_BASE + hw->hw_cap.capability_registers_block_offset)
167
168 #define IPN3KE_STATUS_REGISTERS_BLOCK_OFFSET \
169         (IPN3KE_HW_BASE + hw->hw_cap.status_registers_block_offset)
170
171 #define IPN3KE_CTRL_RESET \
172         (IPN3KE_HW_BASE + hw->hw_cap.control_registers_block_offset)
173
174 #define IPN3KE_CTRL_MTU \
175         (IPN3KE_HW_BASE + hw->hw_cap.control_registers_block_offset + 4)
176
177 #define IPN3KE_CLASSIFY_OFFSET \
178         (IPN3KE_HW_BASE + hw->hw_cap.classify_offset)
179
180 #define IPN3KE_POLICER_OFFSET \
181         (IPN3KE_HW_BASE + hw->hw_cap.policer_offset)
182
183 #define IPN3KE_RSS_KEY_ARRAY_OFFSET \
184         (IPN3KE_HW_BASE + hw->hw_cap.rss_key_array_offset)
185
186 #define IPN3KE_RSS_INDIRECTION_TABLE_ARRAY_OFFSET \
187         (IPN3KE_HW_BASE + hw->hw_cap.rss_indirection_table_array_offset)
188
189 #define IPN3KE_DMAC_MAP_OFFSET \
190         (IPN3KE_HW_BASE + hw->hw_cap.dmac_map_offset)
191
192 #define IPN3KE_QM_OFFSET \
193         (IPN3KE_HW_BASE + hw->hw_cap.qm_offset)
194
195 #define IPN3KE_CCB_OFFSET \
196         (IPN3KE_HW_BASE + hw->hw_cap.ccb_offset)
197
198 #define IPN3KE_QOS_OFFSET \
199         (IPN3KE_HW_BASE + hw->hw_cap.qos_offset)
200
201 struct ipn3ke_hw_cap {
202         uint32_t version_number;
203         uint32_t capability_registers_block_offset;
204         uint32_t status_registers_block_offset;
205         uint32_t control_registers_block_offset;
206         uint32_t classify_offset;
207         uint32_t classy_size;
208         uint32_t policer_offset;
209         uint32_t policer_entry_size;
210         uint32_t rss_key_array_offset;
211         uint32_t rss_key_entry_size;
212         uint32_t rss_indirection_table_array_offset;
213         uint32_t rss_indirection_table_entry_size;
214         uint32_t dmac_map_offset;
215         uint32_t dmac_map_size;
216         uint32_t qm_offset;
217         uint32_t qm_size;
218         uint32_t ccb_offset;
219         uint32_t ccb_entry_size;
220         uint32_t qos_offset;
221         uint32_t qos_size;
222
223         uint32_t num_rx_flow;    /* Default: 64K */
224         uint32_t num_rss_blocks; /* Default: 512 */
225         uint32_t num_dmac_map;   /* Default: 1K */
226         uint32_t num_tx_flow;    /* Default: 64K */
227         uint32_t num_smac_map;   /* Default: 1K */
228
229         uint32_t link_speed_mbps;
230 };
231
232 /**
233  * Strucute to store private data for each representor instance
234  */
235 struct ipn3ke_rpst {
236         TAILQ_ENTRY(ipn3ke_rpst) next;       /**< Next in device list. */
237         uint16_t switch_domain_id;
238         /**< Switch ID */
239         uint16_t port_id;
240         struct rte_eth_dev *ethdev;
241         /**< Port ID */
242         struct ipn3ke_hw *hw;
243         struct rte_eth_dev *i40e_pf_eth;
244         uint16_t i40e_pf_eth_port_id;
245         struct rte_eth_link ori_linfo;
246         struct ipn3ke_tm_internals tm;
247         /**< Private data store of assocaiated physical function */
248         struct rte_ether_addr mac_addr;
249 };
250
251 /* UUID IDs */
252 #define MAP_UUID_10G_LOW                0xffffffffffffffff
253 #define MAP_UUID_10G_HIGH               0xffffffffffffffff
254 #define IPN3KE_UUID_10G_LOW             0xc000c9660d824272
255 #define IPN3KE_UUID_10G_HIGH            0x9aeffe5f84570612
256 #define IPN3KE_UUID_VBNG_LOW            0x8991165349d23ff9
257 #define IPN3KE_UUID_VBNG_HIGH           0xb74cf419d15a481f
258 #define IPN3KE_UUID_25G_LOW             0xb7d9bac566bfbc80
259 #define IPN3KE_UUID_25G_HIGH            0xb07bac1aeef54d67
260
261 #define IPN3KE_AFU_BUF_SIZE_MIN         1024
262 #define IPN3KE_AFU_FRAME_SIZE_MAX       9728
263
264 #define IPN3KE_RAWDEV_ATTR_LEN_MAX      (64)
265
266 typedef int (*ipn3ke_indirect_mac_read_t)(struct ipn3ke_hw *hw,
267         uint32_t *rd_data, uint32_t addr, uint32_t mac_num,
268         uint32_t eth_wrapper_sel);
269
270 typedef int (*ipn3ke_indirect_mac_write_t)(struct ipn3ke_hw *hw,
271         uint32_t wr_data, uint32_t addr, uint32_t mac_num,
272         uint32_t eth_wrapper_sel);
273
274 struct ipn3ke_hw {
275         struct rte_eth_dev *eth_dev;
276
277         /* afu info */
278         struct rte_afu_id afu_id;
279         struct rte_rawdev *rawdev;
280
281         struct ipn3ke_hw_cap hw_cap;
282
283         struct ifpga_rawdevg_retimer_info retimer;
284
285         uint16_t switch_domain_id;
286         uint16_t port_num;
287
288         uint32_t tm_hw_enable;
289         uint32_t flow_hw_enable;
290
291         uint32_t acc_tm;
292         uint32_t acc_flow;
293
294         struct ipn3ke_flow_list flow_list;
295         uint32_t flow_max_entries;
296         uint32_t flow_num_entries;
297
298         struct ipn3ke_tm_node *nodes;
299         struct ipn3ke_tm_node *port_nodes;
300         struct ipn3ke_tm_node *vt_nodes;
301         struct ipn3ke_tm_node *cos_nodes;
302
303         struct ipn3ke_tm_tdrop_profile *tdrop_profile;
304         uint32_t tdrop_profile_num;
305
306         uint32_t ccb_status;
307         uint32_t ccb_seg_free;
308         uint32_t ccb_seg_num;
309         uint32_t ccb_seg_k;
310
311         uint8_t *eth_group_bar[2];
312         /**< MAC Register read */
313         ipn3ke_indirect_mac_read_t f_mac_read;
314         /**< MAC Register write */
315         ipn3ke_indirect_mac_write_t f_mac_write;
316
317         uint8_t *hw_addr;
318 };
319
320 /**
321  * @internal
322  * Helper macro for drivers that need to convert to struct rte_afu_device.
323  */
324 #define RTE_DEV_TO_AFU(ptr) \
325         container_of(ptr, struct rte_afu_device, device)
326
327 #define RTE_DEV_TO_AFU_CONST(ptr) \
328         container_of(ptr, const struct rte_afu_device, device)
329
330 #define RTE_ETH_DEV_TO_AFU(eth_dev) \
331         RTE_DEV_TO_AFU((eth_dev)->device)
332
333 /**
334  * PCIe MMIO Access
335  */
336
337 #define IPN3KE_PCI_REG(reg)    rte_read32(reg)
338 #define IPN3KE_PCI_REG_ADDR(a, reg) \
339         ((volatile uint32_t *)((char *)(a)->hw_addr + (reg)))
340 static inline uint32_t ipn3ke_read_addr(volatile void *addr)
341 {
342         return rte_le_to_cpu_32(IPN3KE_PCI_REG(addr));
343 }
344
345 #define WCMD 0x8000000000000000
346 #define RCMD 0x4000000000000000
347 #define INDRCT_CTRL 0x30
348 #define INDRCT_STS 0x38
349 static inline uint32_t _ipn3ke_indrct_read(struct ipn3ke_hw *hw,
350                 uint32_t addr)
351 {
352         uint64_t word_offset;
353         uint64_t read_data = 0;
354         uint64_t indirect_value;
355         volatile void *indirect_addrs;
356
357         word_offset = (addr & 0x1FFFFFF) >> 2;
358         indirect_value = RCMD | word_offset << 32;
359         indirect_addrs = hw->hw_addr + (uint32_t)(INDRCT_CTRL);
360
361         rte_delay_us(10);
362
363         rte_write64((rte_cpu_to_le_64(indirect_value)), indirect_addrs);
364
365         indirect_addrs = hw->hw_addr + (uint32_t)(INDRCT_STS);
366         while ((read_data >> 32) != 1)
367                 read_data = rte_read64(indirect_addrs);
368
369         return rte_le_to_cpu_32(read_data);
370 }
371
372 static inline void _ipn3ke_indrct_write(struct ipn3ke_hw *hw,
373                 uint32_t addr, uint32_t value)
374 {
375         uint64_t word_offset;
376         uint64_t indirect_value;
377         volatile void *indirect_addrs = 0;
378
379         word_offset = (addr & 0x1FFFFFF) >> 2;
380         indirect_value = WCMD | word_offset << 32 | value;
381         indirect_addrs = hw->hw_addr + (uint32_t)(INDRCT_CTRL);
382
383         rte_write64((rte_cpu_to_le_64(indirect_value)), indirect_addrs);
384         rte_delay_us(10);
385 }
386
387 #define IPN3KE_PCI_REG_WRITE(reg, value) \
388         rte_write32((rte_cpu_to_le_32(value)), reg)
389
390 #define IPN3KE_PCI_REG_WRITE_RELAXED(reg, value) \
391         rte_write32_relaxed((rte_cpu_to_le_32(value)), reg)
392
393 #define IPN3KE_READ_REG(hw, reg) \
394         _ipn3ke_indrct_read((hw), (reg))
395
396 #define IPN3KE_WRITE_REG(hw, reg, value) \
397         _ipn3ke_indrct_write((hw), (reg), (value))
398
399 #define IPN3KE_MASK_READ_REG(hw, reg, x, mask) \
400         ((mask) & IPN3KE_READ_REG((hw), ((reg) + (0x4 * (x)))))
401
402 #define IPN3KE_MASK_WRITE_REG(hw, reg, x, value, mask) \
403         IPN3KE_WRITE_REG((hw), ((reg) + (0x4 * (x))), ((mask) & (value)))
404
405 #define IPN3KE_DEV_PRIVATE_TO_HW(dev) \
406         (((struct ipn3ke_rpst *)(dev)->data->dev_private)->hw)
407
408 #define IPN3KE_DEV_PRIVATE_TO_RPST(dev) \
409         ((struct ipn3ke_rpst *)(dev)->data->dev_private)
410
411 #define IPN3KE_DEV_PRIVATE_TO_TM(dev) \
412         (&(((struct ipn3ke_rpst *)(dev)->data->dev_private)->tm))
413
414 #define IPN3KE_VBNG_INIT_DONE                      (0x3)
415 #define IPN3KE_VBNG_INIT_STS                      (0x204)
416
417 /* Byte address of IPN3KE internal module */
418 #define IPN3KE_TM_VERSION                     (IPN3KE_QM_OFFSET + 0x0000)
419 #define IPN3KE_TM_SCRATCH                     (IPN3KE_QM_OFFSET + 0x0004)
420 #define IPN3KE_TM_STATUS                      (IPN3KE_QM_OFFSET + 0x0008)
421 #define IPN3KE_TM_MISC_STATUS                 (IPN3KE_QM_OFFSET + 0x0010)
422 #define IPN3KE_TM_MISC_WARNING_0              (IPN3KE_QM_OFFSET + 0x0040)
423 #define IPN3KE_TM_MISC_MON_0                  (IPN3KE_QM_OFFSET + 0x0048)
424 #define IPN3KE_TM_MISC_FATAL_0                (IPN3KE_QM_OFFSET + 0x0050)
425 #define IPN3KE_TM_BW_MON_CTRL_1               (IPN3KE_QM_OFFSET + 0x0080)
426 #define IPN3KE_TM_BW_MON_CTRL_2               (IPN3KE_QM_OFFSET + 0x0084)
427 #define IPN3KE_TM_BW_MON_RATE                 (IPN3KE_QM_OFFSET + 0x0088)
428 #define IPN3KE_TM_STATS_CTRL                  (IPN3KE_QM_OFFSET + 0x0100)
429 #define IPN3KE_TM_STATS_DATA_0                (IPN3KE_QM_OFFSET + 0x0110)
430 #define IPN3KE_TM_STATS_DATA_1                (IPN3KE_QM_OFFSET + 0x0114)
431 #define IPN3KE_QM_UID_CONFIG_CTRL             (IPN3KE_QM_OFFSET + 0x0200)
432 #define IPN3KE_QM_UID_CONFIG_DATA             (IPN3KE_QM_OFFSET + 0x0204)
433
434 #define IPN3KE_BM_VERSION                     (IPN3KE_QM_OFFSET + 0x4000)
435 #define IPN3KE_BM_STATUS                      (IPN3KE_QM_OFFSET + 0x4008)
436 #define IPN3KE_BM_STORE_CTRL                  (IPN3KE_QM_OFFSET + 0x4010)
437 #define IPN3KE_BM_STORE_STATUS                (IPN3KE_QM_OFFSET + 0x4018)
438 #define IPN3KE_BM_STORE_MON                   (IPN3KE_QM_OFFSET + 0x4028)
439 #define IPN3KE_BM_WARNING_0                   (IPN3KE_QM_OFFSET + 0x4040)
440 #define IPN3KE_BM_MON_0                       (IPN3KE_QM_OFFSET + 0x4048)
441 #define IPN3KE_BM_FATAL_0                     (IPN3KE_QM_OFFSET + 0x4050)
442 #define IPN3KE_BM_DRAM_ACCESS_CTRL            (IPN3KE_QM_OFFSET + 0x4100)
443 #define IPN3KE_BM_DRAM_ACCESS_DATA_0          (IPN3KE_QM_OFFSET + 0x4120)
444 #define IPN3KE_BM_DRAM_ACCESS_DATA_1          (IPN3KE_QM_OFFSET + 0x4124)
445 #define IPN3KE_BM_DRAM_ACCESS_DATA_2          (IPN3KE_QM_OFFSET + 0x4128)
446 #define IPN3KE_BM_DRAM_ACCESS_DATA_3          (IPN3KE_QM_OFFSET + 0x412C)
447 #define IPN3KE_BM_DRAM_ACCESS_DATA_4          (IPN3KE_QM_OFFSET + 0x4130)
448 #define IPN3KE_BM_DRAM_ACCESS_DATA_5          (IPN3KE_QM_OFFSET + 0x4134)
449 #define IPN3KE_BM_DRAM_ACCESS_DATA_6          (IPN3KE_QM_OFFSET + 0x4138)
450
451 #define IPN3KE_QM_VERSION                     (IPN3KE_QM_OFFSET + 0x8000)
452 #define IPN3KE_QM_STATUS                      (IPN3KE_QM_OFFSET + 0x8008)
453 #define IPN3KE_QM_LL_TABLE_MON                (IPN3KE_QM_OFFSET + 0x8018)
454 #define IPN3KE_QM_WARNING_0                   (IPN3KE_QM_OFFSET + 0x8040)
455 #define IPN3KE_QM_MON_0                       (IPN3KE_QM_OFFSET + 0x8048)
456 #define IPN3KE_QM_FATAL_0                     (IPN3KE_QM_OFFSET + 0x8050)
457 #define IPN3KE_QM_FATAL_1                     (IPN3KE_QM_OFFSET + 0x8054)
458 #define IPN3KE_LL_TABLE_ACCESS_CTRL           (IPN3KE_QM_OFFSET + 0x8100)
459 #define IPN3KE_LL_TABLE_ACCESS_DATA_0         (IPN3KE_QM_OFFSET + 0x8110)
460 #define IPN3KE_LL_TABLE_ACCESS_DATA_1         (IPN3KE_QM_OFFSET + 0x8114)
461
462 #define IPN3KE_CCB_ERROR                      (IPN3KE_CCB_OFFSET + 0x0008)
463 #define IPN3KE_CCB_NSEGFREE                   (IPN3KE_CCB_OFFSET + 0x200000)
464 #define IPN3KE_CCB_NSEGFREE_MASK               0x3FFFFF
465 #define IPN3KE_CCB_PSEGMAX_COEF               (IPN3KE_CCB_OFFSET + 0x200008)
466 #define IPN3KE_CCB_PSEGMAX_COEF_MASK           0xFFFFF
467 #define IPN3KE_CCB_NSEG_P                     (IPN3KE_CCB_OFFSET + 0x200080)
468 #define IPN3KE_CCB_NSEG_MASK                   0x3FFFFF
469 #define IPN3KE_CCB_QPROFILE_Q                 (IPN3KE_CCB_OFFSET + 0x240000)
470 #define IPN3KE_CCB_QPROFILE_MASK               0x7FF
471 #define IPN3KE_CCB_PROFILE_P                  (IPN3KE_CCB_OFFSET + 0x280000)
472 #define IPN3KE_CCB_PROFILE_MASK                0x1FFFFFF
473 #define IPN3KE_CCB_PROFILE_MS                 (IPN3KE_CCB_OFFSET + 0xC)
474 #define IPN3KE_CCB_PROFILE_MS_MASK             0x1FFFFFF
475 #define IPN3KE_CCB_LR_LB_DBG_CTRL             (IPN3KE_CCB_OFFSET + 0x2C0000)
476 #define IPN3KE_CCB_LR_LB_DBG_DONE             (IPN3KE_CCB_OFFSET + 0x2C0004)
477 #define IPN3KE_CCB_LR_LB_DBG_RDATA            (IPN3KE_CCB_OFFSET + 0x2C000C)
478
479 #define IPN3KE_QOS_MAP_L1_X                   (IPN3KE_QOS_OFFSET + 0x000000)
480 #define IPN3KE_QOS_MAP_L1_MASK                 0x1FFF
481 #define IPN3KE_QOS_MAP_L2_X                   (IPN3KE_QOS_OFFSET + 0x040000)
482 #define IPN3KE_QOS_MAP_L2_MASK                 0x7
483 #define IPN3KE_QOS_TYPE_MASK                   0x3
484 #define IPN3KE_QOS_TYPE_L1_X                  (IPN3KE_QOS_OFFSET + 0x200000)
485 #define IPN3KE_QOS_TYPE_L2_X                  (IPN3KE_QOS_OFFSET + 0x240000)
486 #define IPN3KE_QOS_TYPE_L3_X                  (IPN3KE_QOS_OFFSET + 0x280000)
487 #define IPN3KE_QOS_SCH_WT_MASK                 0xFF
488 #define IPN3KE_QOS_SCH_WT_L1_X                (IPN3KE_QOS_OFFSET + 0x400000)
489 #define IPN3KE_QOS_SCH_WT_L2_X                (IPN3KE_QOS_OFFSET + 0x440000)
490 #define IPN3KE_QOS_SCH_WT_L3_X                (IPN3KE_QOS_OFFSET + 0x480000)
491 #define IPN3KE_QOS_SHAP_WT_MASK                0x3FFF
492 #define IPN3KE_QOS_SHAP_WT_L1_X               (IPN3KE_QOS_OFFSET + 0x600000)
493 #define IPN3KE_QOS_SHAP_WT_L2_X               (IPN3KE_QOS_OFFSET + 0x640000)
494 #define IPN3KE_QOS_SHAP_WT_L3_X               (IPN3KE_QOS_OFFSET + 0x680000)
495
496 #define IPN3KE_CLF_BASE_DST_MAC_ADDR_HI       (IPN3KE_CLASSIFY_OFFSET + 0x0000)
497 #define IPN3KE_CLF_BASE_DST_MAC_ADDR_LOW      (IPN3KE_CLASSIFY_OFFSET + 0x0004)
498 #define IPN3KE_CLF_QINQ_STAG                  (IPN3KE_CLASSIFY_OFFSET + 0x0008)
499 #define IPN3KE_CLF_LKUP_ENABLE                (IPN3KE_CLASSIFY_OFFSET + 0x000C)
500 #define IPN3KE_CLF_DFT_FLOW_ID                (IPN3KE_CLASSIFY_OFFSET + 0x0040)
501 #define IPN3KE_CLF_RX_PARSE_CFG               (IPN3KE_CLASSIFY_OFFSET + 0x0080)
502 #define IPN3KE_CLF_RX_STATS_CFG               (IPN3KE_CLASSIFY_OFFSET + 0x00C0)
503 #define IPN3KE_CLF_RX_STATS_RPT               (IPN3KE_CLASSIFY_OFFSET + 0x00C4)
504 #define IPN3KE_CLF_RX_TEST                    (IPN3KE_CLASSIFY_OFFSET + 0x0400)
505
506 #define IPN3KE_CLF_EM_VERSION       (IPN3KE_CLASSIFY_OFFSET + 0x40000 + 0x0000)
507 #define IPN3KE_CLF_EM_NUM           (IPN3KE_CLASSIFY_OFFSET + 0x40000 + 0x0008)
508 #define IPN3KE_CLF_EM_KEY_WDTH      (IPN3KE_CLASSIFY_OFFSET + 0x40000 + 0x000C)
509 #define IPN3KE_CLF_EM_RES_WDTH      (IPN3KE_CLASSIFY_OFFSET + 0x40000 + 0x0010)
510 #define IPN3KE_CLF_EM_ALARMS        (IPN3KE_CLASSIFY_OFFSET + 0x40000 + 0x0014)
511 #define IPN3KE_CLF_EM_DRC_RLAT      (IPN3KE_CLASSIFY_OFFSET + 0x40000 + 0x0018)
512
513 #define IPN3KE_CLF_MHL_VERSION      (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x0000)
514 #define IPN3KE_CLF_MHL_GEN_CTRL     (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x0018)
515 #define IPN3KE_CLF_MHL_MGMT_CTRL    (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x0020)
516 #define IPN3KE_CLF_MHL_MGMT_CTRL_BIT_BUSY      31
517 #define IPN3KE_CLF_MHL_MGMT_CTRL_FLUSH         0x0
518 #define IPN3KE_CLF_MHL_MGMT_CTRL_INSERT        0x1
519 #define IPN3KE_CLF_MHL_MGMT_CTRL_DELETE        0x2
520 #define IPN3KE_CLF_MHL_MGMT_CTRL_SEARCH        0x3
521 #define IPN3KE_CLF_MHL_FATAL_0     (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x0050)
522 #define IPN3KE_CLF_MHL_MON_0       (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x0060)
523 #define IPN3KE_CLF_MHL_TOTAL_ENTRIES   (IPN3KE_CLASSIFY_OFFSET + \
524                                         0x50000 + 0x0080)
525 #define IPN3KE_CLF_MHL_ONEHIT_BUCKETS  (IPN3KE_CLASSIFY_OFFSET + \
526                                         0x50000 + 0x0084)
527 #define IPN3KE_CLF_MHL_KEY_MASK         0xFFFFFFFF
528 #define IPN3KE_CLF_MHL_KEY_0       (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x1000)
529 #define IPN3KE_CLF_MHL_KEY_1       (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x1004)
530 #define IPN3KE_CLF_MHL_KEY_2       (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x1008)
531 #define IPN3KE_CLF_MHL_KEY_3       (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x100C)
532 #define IPN3KE_CLF_MHL_RES_MASK    0xFFFFFFFF
533 #define IPN3KE_CLF_MHL_RES         (IPN3KE_CLASSIFY_OFFSET + 0x50000 + 0x2000)
534
535 int
536 ipn3ke_rpst_dev_set_link_up(struct rte_eth_dev *dev);
537 int
538 ipn3ke_rpst_dev_set_link_down(struct rte_eth_dev *dev);
539 int
540 ipn3ke_rpst_link_update(struct rte_eth_dev *ethdev,
541         __rte_unused int wait_to_complete);
542 void
543 ipn3ke_rpst_promiscuous_enable(struct rte_eth_dev *ethdev);
544 void
545 ipn3ke_rpst_promiscuous_disable(struct rte_eth_dev *ethdev);
546 void
547 ipn3ke_rpst_allmulticast_enable(struct rte_eth_dev *ethdev);
548 void
549 ipn3ke_rpst_allmulticast_disable(struct rte_eth_dev *ethdev);
550 int
551 ipn3ke_rpst_mac_addr_set(struct rte_eth_dev *ethdev,
552                 struct rte_ether_addr *mac_addr);
553 int
554 ipn3ke_rpst_mtu_set(struct rte_eth_dev *ethdev, uint16_t mtu);
555
556 int
557 ipn3ke_rpst_init(struct rte_eth_dev *ethdev, void *init_params);
558 int
559 ipn3ke_rpst_uninit(struct rte_eth_dev *ethdev);
560 int
561 ipn3ke_hw_tm_init(struct ipn3ke_hw *hw);
562 void
563 ipn3ke_tm_init(struct ipn3ke_rpst *rpst);
564 int
565 ipn3ke_tm_ops_get(struct rte_eth_dev *ethdev,
566                 void *arg);
567
568
569 /* IPN3KE_MASK is a macro used on 32 bit registers */
570 #define IPN3KE_MASK(mask, shift) ((mask) << (shift))
571
572 #define IPN3KE_MAC_CTRL_BASE_0    0x00000000
573 #define IPN3KE_MAC_CTRL_BASE_1    0x00008000
574
575 #define IPN3KE_MAC_STATS_MASK    0xFFFFFFFFF
576
577 /* All the address are in 4Bytes*/
578 #define IPN3KE_MAC_PRIMARY_MAC_ADDR0    0x0010
579 #define IPN3KE_MAC_PRIMARY_MAC_ADDR1    0x0011
580
581 #define IPN3KE_MAC_MAC_RESET_CONTROL    0x001F
582 #define IPN3KE_MAC_MAC_RESET_CONTROL_TX_SHIFT    0
583 #define IPN3KE_MAC_MAC_RESET_CONTROL_TX_MASK \
584         IPN3KE_MASK(0x1, IPN3KE_MAC_MAC_RESET_CONTROL_TX_SHIFT)
585
586 #define IPN3KE_MAC_MAC_RESET_CONTROL_RX_SHIFT    8
587 #define IPN3KE_MAC_MAC_RESET_CONTROL_RX_MASK \
588         IPN3KE_MASK(0x1, IPN3KE_MAC_MAC_RESET_CONTROL_RX_SHIFT)
589
590 #define IPN3KE_MAC_TX_PACKET_CONTROL    0x0020
591 #define IPN3KE_MAC_TX_PACKET_CONTROL_SHIFT    0
592 #define IPN3KE_MAC_TX_PACKET_CONTROL_MASK \
593         IPN3KE_MASK(0x1, IPN3KE_MAC_TX_PACKET_CONTROL_SHIFT)
594
595 #define IPN3KE_MAC_TX_SRC_ADDR_OVERRIDE    0x002A
596 #define IPN3KE_MAC_TX_SRC_ADDR_OVERRIDE_SHIFT    0
597 #define IPN3KE_MAC_TX_SRC_ADDR_OVERRIDE_MASK \
598         IPN3KE_MASK(0x1, IPN3KE_MAC_TX_SRC_ADDR_OVERRIDE_SHIFT)
599
600 #define IPN3KE_MAC_TX_FRAME_MAXLENGTH    0x002C
601 #define IPN3KE_MAC_TX_FRAME_MAXLENGTH_SHIFT    0
602 #define IPN3KE_MAC_TX_FRAME_MAXLENGTH_MASK \
603         IPN3KE_MASK(0xFFFF, IPN3KE_MAC_TX_FRAME_MAXLENGTH_SHIFT)
604
605 #define IPN3KE_MAC_TX_PAUSEFRAME_CONTROL    0x0040
606 #define IPN3KE_MAC_TX_PAUSEFRAME_CONTROL_SHIFT    0
607 #define IPN3KE_MAC_TX_PAUSEFRAME_CONTROL_MASK \
608         IPN3KE_MASK(0x3, IPN3KE_MAC_TX_PAUSEFRAME_CONTROL_SHIFT)
609
610 #define IPN3KE_MAC_TX_PAUSEFRAME_QUANTA    0x0042
611 #define IPN3KE_MAC_TX_PAUSEFRAME_QUANTA_SHIFT    0
612 #define IPN3KE_MAC_TX_PAUSEFRAME_QUANTA_MASK \
613         IPN3KE_MASK(0xFFFF, IPN3KE_MAC_TX_PAUSEFRAME_QUANTA_SHIFT)
614
615 #define IPN3KE_MAC_TX_PAUSEFRAME_HOLDOFF_QUANTA    0x0043
616 #define IPN3KE_MAC_TX_PAUSEFRAME_HOLDOFF_QUANTA_SHIFT    0
617 #define IPN3KE_MAC_TX_PAUSEFRAME_HOLDOFF_QUANTA_MASK \
618         IPN3KE_MASK(0xFFFF, IPN3KE_MAC_TX_PAUSEFRAME_HOLDOFF_QUANTA_SHIFT)
619
620 #define IPN3KE_MAC_TX_PAUSEFRAME_ENABLE    0x0044
621 #define IPN3KE_MAC_TX_PAUSEFRAME_ENABLE_CFG_SHIFT    0
622 #define IPN3KE_MAC_TX_PAUSEFRAME_ENABLE_CFG_MASK \
623         IPN3KE_MASK(0x1, IPN3KE_MAC_TX_PAUSEFRAME_ENABLE_CFG_SHIFT)
624
625 #define IPN3KE_MAC_TX_PAUSEFRAME_ENABLE_TYPE_SHIFT    1
626 #define IPN3KE_MAC_TX_PAUSEFRAME_ENABLE_TYPE_MASK \
627         IPN3KE_MASK(0x3, IPN3KE_MAC_TX_PAUSEFRAME_ENABLE_TYPE_SHIFT)
628
629 #define IPN3KE_MAC_RX_TRANSFER_CONTROL    0x00A0
630 #define IPN3KE_MAC_RX_TRANSFER_CONTROL_SHIFT    0x0
631 #define IPN3KE_MAC_RX_TRANSFER_CONTROL_MASK \
632         IPN3KE_MASK(0x1, IPN3KE_MAC_RX_TRANSFER_CONTROL_SHIFT)
633
634 #define IPN3KE_MAC_RX_FRAME_CONTROL    0x00AC
635 #define IPN3KE_MAC_RX_FRAME_CONTROL_EN_ALLUCAST_SHIFT    0x0
636 #define IPN3KE_MAC_RX_FRAME_CONTROL_EN_ALLUCAST_MASK \
637         IPN3KE_MASK(0x1, IPN3KE_MAC_RX_FRAME_CONTROL_EN_ALLUCAST_SHIFT)
638
639 #define IPN3KE_MAC_RX_FRAME_CONTROL_EN_ALLMCAST_SHIFT    0x1
640 #define IPN3KE_MAC_RX_FRAME_CONTROL_EN_ALLMCAST_MASK \
641         IPN3KE_MASK(0x1, IPN3KE_MAC_RX_FRAME_CONTROL_EN_ALLMCAST_SHIFT)
642
643 #define IPN3KE_VLAN_TAG_SIZE    4
644 /**
645  * The overhead from MTU to max frame size.
646  * Considering QinQ packet, the VLAN tag needs to be counted twice.
647  */
648 #define IPN3KE_ETH_OVERHEAD \
649         (RTE_ETHER_HDR_LEN + RTE_ETHER_CRC_LEN + IPN3KE_VLAN_TAG_SIZE * 2)
650
651 #define IPN3KE_MAC_FRAME_SIZE_MAX    9728
652 #define IPN3KE_MAC_RX_FRAME_MAXLENGTH    0x00AE
653 #define IPN3KE_MAC_RX_FRAME_MAXLENGTH_SHIFT    0
654 #define IPN3KE_MAC_RX_FRAME_MAXLENGTH_MASK \
655         IPN3KE_MASK(0xFFFF, IPN3KE_MAC_RX_FRAME_MAXLENGTH_SHIFT)
656
657 #define IPN3KE_MAC_TX_STATS_CLR    0x0140
658 #define IPN3KE_MAC_TX_STATS_CLR_CLEAR_SHIFT    0
659 #define IPN3KE_MAC_TX_STATS_CLR_CLEAR_MASK \
660         IPN3KE_MASK(0x1, IPN3KE_MAC_TX_STATS_CLR_CLEAR_SHIFT)
661
662 #define IPN3KE_MAC_RX_STATS_CLR    0x01C0
663 #define IPN3KE_MAC_RX_STATS_CLR_CLEAR_SHIFT    0
664 #define IPN3KE_MAC_RX_STATS_CLR_CLEAR_MASK \
665         IPN3KE_MASK(0x1, IPN3KE_MAC_RX_STATS_CLR_CLEAR_SHIFT)
666
667 /*tx_stats_framesOK*/
668 #define IPN3KE_MAC_TX_STATS_FRAMESOK_HI  0x0142
669 #define IPN3KE_MAC_TX_STATS_FRAMESOK_LOW 0x0143
670
671 /*rx_stats_framesOK*/
672 #define IPN3KE_MAC_RX_STATS_FRAMESOK_HI  0x01C2
673 #define IPN3KE_MAC_RX_STATS_FRAMESOK_LOW 0x01C3
674
675 /*tx_stats_framesErr*/
676 #define IPN3KE_MAC_TX_STATS_FRAMESERR_HI  0x0144
677 #define IPN3KE_MAC_TX_STATS_FRAMESERR_LOW 0x0145
678
679 /*rx_stats_framesErr*/
680 #define IPN3KE_MAC_RX_STATS_FRAMESERR_HI  0x01C4
681 #define IPN3KE_MAC_RX_STATS_FRAMESERR_LOW 0x01C5
682
683 /*rx_stats_framesCRCErr*/
684 #define IPN3KE_MAC_RX_STATS_FRAMESCRCERR_HI  0x01C6
685 #define IPN3KE_MAC_RX_STATS_FRAMESCRCERR_LOW 0x01C7
686
687 /*tx_stats_octetsOK 64b*/
688 #define IPN3KE_MAC_TX_STATS_OCTETSOK_HI  0x0148
689 #define IPN3KE_MAC_TX_STATS_OCTETSOK_LOW 0x0149
690
691 /*rx_stats_octetsOK 64b*/
692 #define IPN3KE_MAC_RX_STATS_OCTETSOK_HI  0x01C8
693 #define IPN3KE_MAC_RX_STATS_OCTETSOK_LOW 0x01C9
694
695 /*tx_stats_pauseMACCtrl_Frames*/
696 #define IPN3KE_MAC_TX_STATS_PAUSEMACCTRL_FRAMES_HI  0x014A
697 #define IPN3KE_MAC_TX_STATS_PAUSEMACCTRL_FRAMES_LOW 0x014B
698
699 /*rx_stats_pauseMACCtrl_Frames*/
700 #define IPN3KE_MAC_RX_STATS_PAUSEMACCTRL_FRAMES_HI  0x01CA
701 #define IPN3KE_MAC_RX_STATS_PAUSEMACCTRL_FRAMES_LOW 0x01CB
702
703 /*tx_stats_ifErrors*/
704 #define IPN3KE_MAC_TX_STATS_IFERRORS_HI  0x014C
705 #define IPN3KE_MAC_TX_STATS_IFERRORS_LOW 0x014D
706
707 /*rx_stats_ifErrors*/
708 #define IPN3KE_MAC_RX_STATS_IFERRORS_HI  0x01CC
709 #define IPN3KE_MAC_RX_STATS_IFERRORS_LOW 0x01CD
710
711 /*tx_stats_unicast_FramesOK*/
712 #define IPN3KE_MAC_TX_STATS_UNICAST_FRAMESOK_HI  0x014E
713 #define IPN3KE_MAC_TX_STATS_UNICAST_FRAMESOK_LOW 0x014F
714
715 /*rx_stats_unicast_FramesOK*/
716 #define IPN3KE_MAC_RX_STATS_UNICAST_FRAMESOK_HI  0x01CE
717 #define IPN3KE_MAC_RX_STATS_UNICAST_FRAMESOK_LOW 0x01CF
718
719 /*tx_stats_unicast_FramesErr*/
720 #define IPN3KE_MAC_TX_STATS_UNICAST_FRAMESERR_HI  0x0150
721 #define IPN3KE_MAC_TX_STATS_UNICAST_FRAMESERR_LOW 0x0151
722
723 /*rx_stats_unicast_FramesErr*/
724 #define IPN3KE_MAC_RX_STATS_UNICAST_FRAMESERR_HI  0x01D0
725 #define IPN3KE_MAC_RX_STATS_UNICAST_FRAMESERR_LOW 0x01D1
726
727 /*tx_stats_multicast_FramesOK*/
728 #define IPN3KE_MAC_TX_STATS_MULTICAST_FRAMESOK_HI  0x0152
729 #define IPN3KE_MAC_TX_STATS_MULTICAST_FRAMESOK_LOW 0x0153
730
731 /*rx_stats_multicast_FramesOK*/
732 #define IPN3KE_MAC_RX_STATS_MULTICAST_FRAMESOK_HI  0x01D2
733 #define IPN3KE_MAC_RX_STATS_MULTICAST_FRAMESOK_LOW 0x01D3
734
735 /*tx_stats_multicast_FramesErr*/
736 #define IPN3KE_MAC_TX_STATS_MULTICAST_FRAMESERR_HI  0x0154
737 #define IPN3KE_MAC_TX_STATS_MULTICAST_FRAMESERR_LOW 0x0155
738
739 /*rx_stats_multicast_FramesErr*/
740 #define IPN3KE_MAC_RX_STATS_MULTICAST_FRAMESERR_HI  0x01D4
741 #define IPN3KE_MAC_RX_STATS_MULTICAST_FRAMESERR_LOW 0x01D5
742
743 /*tx_stats_broadcast_FramesOK*/
744 #define IPN3KE_MAC_TX_STATS_BROADCAST_FRAMESOK_HI  0x0156
745 #define IPN3KE_MAC_TX_STATS_BROADCAST_FRAMESOK_LOW 0x0157
746
747 /*rx_stats_broadcast_FramesOK*/
748 #define IPN3KE_MAC_RX_STATS_BROADCAST_FRAMESOK_HI  0x01D6
749 #define IPN3KE_MAC_RX_STATS_BROADCAST_FRAMESOK_LOW 0x01D7
750
751 /*tx_stats_broadcast_FramesErr*/
752 #define IPN3KE_MAC_TX_STATS_BROADCAST_FRAMESERR_HI  0x0158
753 #define IPN3KE_MAC_TX_STATS_BROADCAST_FRAMESERR_LOW 0x0159
754
755 /*rx_stats_broadcast_FramesErr*/
756 #define IPN3KE_MAC_RX_STATS_BROADCAST_FRAMESERR_HI  0x01D8
757 #define IPN3KE_MAC_RX_STATS_BROADCAST_FRAMESERR_LOW 0x01D9
758
759 /*tx_stats_etherStatsOctets 64b*/
760 #define IPN3KE_MAC_TX_STATS_ETHERSTATSOCTETS_HI  0x015A
761 #define IPN3KE_MAC_TX_STATS_ETHERSTATSOCTETS_LOW 0x015B
762
763 /*rx_stats_etherStatsOctets 64b*/
764 #define IPN3KE_MAC_RX_STATS_ETHERSTATSOCTETS_HI  0x01DA
765 #define IPN3KE_MAC_RX_STATS_ETHERSTATSOCTETS_LOW 0x01DB
766
767 /*tx_stats_etherStatsPkts*/
768 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS_HI  0x015C
769 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS_LOW 0x015D
770
771 /*rx_stats_etherStatsPkts*/
772 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS_HI  0x01DC
773 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS_LOW 0x01DD
774
775 /*tx_stats_etherStatsUndersizePkts*/
776 #define IPN3KE_MAC_TX_STATS_ETHERSTATSUNDERSIZEPKTS_HI  0x015E
777 #define IPN3KE_MAC_TX_STATS_ETHERSTATSUNDERSIZEPKTS_LOW 0x015F
778
779 /*rx_stats_etherStatsUndersizePkts*/
780 #define IPN3KE_MAC_RX_STATS_ETHERSTATSUNDERSIZEPKTS_HI  0x01DE
781 #define IPN3KE_MAC_RX_STATS_ETHERSTATSUNDERSIZEPKTS_LOW 0x01DF
782
783 /*tx_stats_etherStatsOversizePkts*/
784 #define IPN3KE_MAC_TX_STATS_ETHERSTATSOVERSIZEPKTS_HI  0x0160
785 #define IPN3KE_MAC_TX_STATS_ETHERSTATSOVERSIZEPKTS_LOW 0x0161
786
787 /*rx_stats_etherStatsOversizePkts*/
788 #define IPN3KE_MAC_RX_STATS_ETHERSTATSOVERSIZEPKTS_HI  0x01E0
789 #define IPN3KE_MAC_RX_STATS_ETHERSTATSOVERSIZEPKTS_LOW 0x01E1
790
791 /*tx_stats_etherStatsPkts64Octets*/
792 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS64OCTETS_HI  0x0162
793 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS64OCTETS_LOW 0x0163
794
795 /*rx_stats_etherStatsPkts64Octets*/
796 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS64OCTETS_HI  0x01E2
797 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS64OCTETS_LOW 0x01E3
798
799 /*tx_stats_etherStatsPkts65to127Octets*/
800 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS65TO127OCTETS_HI  0x0164
801 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS65TO127OCTETS_LOW 0x0165
802
803 /*rx_stats_etherStatsPkts65to127Octets*/
804 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS65TO127OCTETS_HI  0x01E4
805 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS65TO127OCTETS_LOW 0x01E5
806
807 /*tx_stats_etherStatsPkts128to255Octets*/
808 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS128TO255OCTETS_HI  0x0166
809 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS128TO255OCTETS_LOW 0x0167
810
811 /*rx_stats_etherStatsPkts128to255Octets*/
812 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS128TO255OCTETS_HI  0x01E6
813 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS128TO255OCTETS_LOW 0x01E7
814
815 /*tx_stats_etherStatsPkts256to511Octet*/
816 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS256TO511OCTET_HI  0x0168
817 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS256TO511OCTET_LOW 0x0169
818
819 /*rx_stats_etherStatsPkts256to511Octets*/
820 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS256TO511OCTETS_HI  0x01E8
821 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS256TO511OCTETS_LOW 0x01E9
822
823 /*tx_stats_etherStatsPkts512to1023Octets*/
824 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS512TO1023OCTETS_HI  0x016A
825 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS512TO1023OCTETS_LOW 0x016B
826
827 /*rx_stats_etherStatsPkts512to1023Octets*/
828 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS512TO1023OCTETS_HI  0x01EA
829 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS512TO1023OCTETS_LOW 0x01EB
830
831 /*tx_stats_etherStatPkts1024to1518Octets*/
832 #define IPN3KE_MAC_TX_STATS_ETHERSTATPKTS1024TO1518OCTETS_HI  0x016C
833 #define IPN3KE_MAC_TX_STATS_ETHERSTATPKTS1024TO1518OCTETS_LOW 0x016D
834
835 /*rx_stats_etherStatPkts1024to1518Octets*/
836 #define IPN3KE_MAC_RX_STATS_ETHERSTATPKTS1024TO1518OCTETS_HI  0x01EC
837 #define IPN3KE_MAC_RX_STATS_ETHERSTATPKTS1024TO1518OCTETS_LOW 0x01ED
838
839 /*tx_stats_etherStatsPkts1519toXOctets*/
840 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS1519TOXOCTETS_HI  0x016E
841 #define IPN3KE_MAC_TX_STATS_ETHERSTATSPKTS1519TOXOCTETS_LOW 0x016F
842
843 /*rx_stats_etherStatsPkts1519toXOctets*/
844 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS1519TOXOCTETS_HI  0x01EE
845 #define IPN3KE_MAC_RX_STATS_ETHERSTATSPKTS1519TOXOCTETS_LOW 0x01EF
846
847 /*rx_stats_etherStatsFragments*/
848 #define IPN3KE_MAC_RX_STATS_ETHERSTATSFRAGMENTS_HI  0x01F0
849 #define IPN3KE_MAC_RX_STATS_ETHERSTATSFRAGMENTS_LOW 0x01F1
850
851 /*rx_stats_etherStatsJabbers*/
852 #define IPN3KE_MAC_RX_STATS_ETHERSTATSJABBERS_HI  0x01F2
853 #define IPN3KE_MAC_RX_STATS_ETHERSTATSJABBERS_LOW 0x01F3
854
855 /*rx_stats_etherStatsCRCErr*/
856 #define IPN3KE_MAC_RX_STATS_ETHERSTATSCRCERR_HI  0x01F4
857 #define IPN3KE_MAC_RX_STATS_ETHERSTATSCRCERR_LOW 0x01F5
858
859 /*tx_stats_unicastMACCtrlFrames*/
860 #define IPN3KE_MAC_TX_STATS_UNICASTMACCTRLFRAMES_HI  0x0176
861 #define IPN3KE_MAC_TX_STATS_UNICASTMACCTRLFRAMES_LOW 0x0177
862
863 /*rx_stats_unicastMACCtrlFrames*/
864 #define IPN3KE_MAC_RX_STATS_UNICASTMACCTRLFRAMES_HI  0x01F6
865 #define IPN3KE_MAC_RX_STATS_UNICASTMACCTRLFRAMES_LOW 0x01F7
866
867 /*tx_stats_multicastMACCtrlFrames*/
868 #define IPN3KE_MAC_TX_STATS_MULTICASTMACCTRLFRAMES_HI  0x0178
869 #define IPN3KE_MAC_TX_STATS_MULTICASTMACCTRLFRAMES_LOW 0x0179
870
871 /*rx_stats_multicastMACCtrlFrames*/
872 #define IPN3KE_MAC_RX_STATS_MULTICASTMACCTRLFRAMES_HI  0x01F8
873 #define IPN3KE_MAC_RX_STATS_MULTICASTMACCTRLFRAMES_LOW 0x01F9
874
875 /*tx_stats_broadcastMACCtrlFrames*/
876 #define IPN3KE_MAC_TX_STATS_BROADCASTMACCTRLFRAMES_HI  0x017A
877 #define IPN3KE_MAC_TX_STATS_BROADCASTMACCTRLFRAMES_LOW 0x017B
878
879 /*rx_stats_broadcastMACCtrlFrames*/
880 #define IPN3KE_MAC_RX_STATS_BROADCASTMACCTRLFRAMES_HI  0x01FA
881 #define IPN3KE_MAC_RX_STATS_BROADCASTMACCTRLFRAMES_LOW 0x01FB
882
883 /*tx_stats_PFCMACCtrlFrames*/
884 #define IPN3KE_MAC_TX_STATS_PFCMACCTRLFRAMES_HI  0x017C
885 #define IPN3KE_MAC_TX_STATS_PFCMACCTRLFRAMES_LOW 0x017D
886
887 /*rx_stats_PFCMACCtrlFrames*/
888 #define IPN3KE_MAC_RX_STATS_PFCMACCTRLFRAMES_HI  0x01FC
889 #define IPN3KE_MAC_RX_STATS_PFCMACCTRLFRAMES_LOW 0x01FD
890
891 static inline void ipn3ke_xmac_tx_enable(struct ipn3ke_hw *hw,
892                 uint32_t mac_num, uint32_t eth_group_sel)
893 {
894 #define IPN3KE_XMAC_TX_ENABLE (0 & (IPN3KE_MAC_TX_PACKET_CONTROL_MASK))
895
896         (*hw->f_mac_write)(hw,
897                                         IPN3KE_XMAC_TX_ENABLE,
898                                         IPN3KE_MAC_TX_PACKET_CONTROL,
899                                         mac_num,
900                                         eth_group_sel);
901 }
902
903 static inline void ipn3ke_xmac_tx_disable(struct ipn3ke_hw *hw,
904                 uint32_t mac_num, uint32_t eth_group_sel)
905 {
906 #define IPN3KE_XMAC_TX_DISABLE (1 & (IPN3KE_MAC_TX_PACKET_CONTROL_MASK))
907
908         (*hw->f_mac_write)(hw,
909                                         IPN3KE_XMAC_TX_DISABLE,
910                                         IPN3KE_MAC_TX_PACKET_CONTROL,
911                                         mac_num,
912                                         eth_group_sel);
913 }
914
915 static inline void ipn3ke_xmac_rx_enable(struct ipn3ke_hw *hw,
916                 uint32_t mac_num, uint32_t eth_group_sel)
917 {
918 #define IPN3KE_XMAC_RX_ENABLE (0 & (IPN3KE_MAC_RX_TRANSFER_CONTROL_MASK))
919
920         (*hw->f_mac_write)(hw,
921                                         IPN3KE_XMAC_RX_ENABLE,
922                                         IPN3KE_MAC_RX_TRANSFER_CONTROL,
923                                         mac_num,
924                                         eth_group_sel);
925 }
926
927 static inline void ipn3ke_xmac_rx_disable(struct ipn3ke_hw *hw,
928                 uint32_t mac_num, uint32_t eth_group_sel)
929 {
930 #define IPN3KE_XMAC_RX_DISABLE (1 & (IPN3KE_MAC_RX_TRANSFER_CONTROL_MASK))
931
932         (*hw->f_mac_write)(hw,
933                                         IPN3KE_XMAC_RX_DISABLE,
934                                         IPN3KE_MAC_RX_TRANSFER_CONTROL,
935                                         mac_num,
936                                         eth_group_sel);
937 }
938
939 static inline void ipn3ke_xmac_smac_ovd_dis(struct ipn3ke_hw *hw,
940         uint32_t mac_num, uint32_t eth_group_sel)
941 {
942 #define IPN3KE_XMAC_SMAC_OVERRIDE_DISABLE (0 & \
943         (IPN3KE_MAC_TX_SRC_ADDR_OVERRIDE_MASK))
944
945         (*hw->f_mac_write)(hw,
946                                         IPN3KE_XMAC_SMAC_OVERRIDE_DISABLE,
947                                         IPN3KE_MAC_TX_SRC_ADDR_OVERRIDE,
948                                         mac_num,
949                                         eth_group_sel);
950 }
951
952 static inline void ipn3ke_xmac_tx_clr_stcs(struct ipn3ke_hw *hw,
953         uint32_t mac_num, uint32_t eth_group_sel)
954 {
955 #define IPN3KE_XMAC_TX_CLR_STCS (1 & \
956         (IPN3KE_MAC_TX_STATS_CLR_CLEAR_MASK))
957
958         (*hw->f_mac_write)(hw,
959                                         IPN3KE_XMAC_TX_CLR_STCS,
960                                         IPN3KE_MAC_TX_STATS_CLR,
961                                         mac_num,
962                                         eth_group_sel);
963 }
964
965 static inline void ipn3ke_xmac_rx_clr_stcs(struct ipn3ke_hw *hw,
966         uint32_t mac_num, uint32_t eth_group_sel)
967 {
968 #define IPN3KE_XMAC_RX_CLR_STCS (1 & \
969         (IPN3KE_MAC_RX_STATS_CLR_CLEAR_MASK))
970
971         (*hw->f_mac_write)(hw,
972                                         IPN3KE_XMAC_RX_CLR_STCS,
973                                         IPN3KE_MAC_RX_STATS_CLR,
974                                         mac_num,
975                                         eth_group_sel);
976 }
977
978
979 #endif /* _IPN3KE_ETHDEV_H_ */