1 /*-
2 * Copyright (c) 2017 Chelsio Communications, Inc.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 *
14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24 * SUCH DAMAGE.
25 *
26 * $FreeBSD$
27 *
28 */
29
30 #ifndef __CUDBG_ENTITY_H__
31 #define __CUDBG_ENTITY_H__
32
33 #ifdef __GNUC__
34 #define ATTRIBUTE_UNUSED __attribute__ ((unused))
35 #else
36 #define ATTRIBUTE_UNUSED
37 #endif
38
39 #define MC0_FLAG 1
40 #define MC1_FLAG 2
41 #define EDC0_FLAG 3
42 #define EDC1_FLAG 4
43
44 #define NUM_PCIE_CONFIG_REGS 0x61
45 #define CUDBG_CTXT_SIZE_BYTES 24
46 #define CUDBG_MAX_INGRESS_QIDS 65536
47 #define CUDBG_MAX_FL_QIDS 2048
48 #define CUDBG_MAX_CNM_QIDS 1024
49 #define CUDBG_LOWMEM_MAX_CTXT_QIDS 256
50 #define ETH_ALEN 6
51 #define CUDBG_MAX_RPLC_SIZE 128
52 #define CUDBG_NUM_REQ_REGS 17
53 #define CUDBG_MAX_TCAM_TID 0x800
54 #define CUDBG_NUM_ULPTX 11
55 #define CUDBG_NUM_ULPTX_READ 512
56
57 #define SN_REG_ADDR 0x183f
58 #define BN_REG_ADDR 0x1819
59 #define NA_REG_ADDR 0x185a
60 #define MN_REG_ADDR 0x1803
61
62 #define A_MPS_VF_RPLCT_MAP0 0x1111c
63 #define A_MPS_VF_RPLCT_MAP1 0x11120
64 #define A_MPS_VF_RPLCT_MAP2 0x11124
65 #define A_MPS_VF_RPLCT_MAP3 0x11128
66 #define A_MPS_VF_RPLCT_MAP4 0x11300
67 #define A_MPS_VF_RPLCT_MAP5 0x11304
68 #define A_MPS_VF_RPLCT_MAP6 0x11308
69 #define A_MPS_VF_RPLCT_MAP7 0x1130c
70
71 #define PORT_TYPE_ADDR 0x1869
72 #define PORT_TYPE_LEN 8
73
74 /* For T6 */
75 #define SN_T6_ADDR 0x83f
76 #define BN_T6_ADDR 0x819
77 #define NA_T6_ADDR 0x85a
78 #define MN_T6_ADDR 0x803
79
80 #define SN_MAX_LEN 24
81 #define BN_MAX_LEN 16
82 #define NA_MAX_LEN 12
83 #define MN_MAX_LEN 16
84 #define MAX_VPD_DATA_LEN 32
85
86 #define VPD_VER_ADDR 0x18c7
87 #define VPD_VER_LEN 2
88 #define SCFG_VER_ADDR 0x06
89 #define SCFG_VER_LEN 4
90
91 #define CUDBG_CIM_BUSY_BIT (1 << 17)
92
93 #define CUDBG_CHAC_PBT_ADDR 0x2800
94 #define CUDBG_CHAC_PBT_LRF 0x3000
95 #define CUDBG_CHAC_PBT_DATA 0x3800
96 #define CUDBG_PBT_DYNAMIC_ENTRIES 8
97 #define CUDBG_PBT_STATIC_ENTRIES 16
98 #define CUDBG_LRF_ENTRIES 8
99 #define CUDBG_PBT_DATA_ENTRIES 512
100
101 #define CUDBG_ENTITY_SIGNATURE 0xCCEDB001
102 #define CUDBG_TID_INFO_REV 1
103 #define CUDBG_MAC_STATS_REV 1
104
105 #ifndef ARRAY_SIZE
106 #define ARRAY_SIZE(_a) (sizeof((_a)) / sizeof((_a)[0]))
107 #endif
108
109 struct cudbg_pbt_tables {
110 u32 pbt_dynamic[CUDBG_PBT_DYNAMIC_ENTRIES];
111 u32 pbt_static[CUDBG_PBT_STATIC_ENTRIES];
112 u32 lrf_table[CUDBG_LRF_ENTRIES];
113 u32 pbt_data[CUDBG_PBT_DATA_ENTRIES];
114 };
115
116 struct card_mem {
117 u16 size_mc0;
118 u16 size_mc1;
119 u16 size_edc0;
120 u16 size_edc1;
121 u16 mem_flag;
122 u16 res;
123 };
124
125 struct rss_pf_conf {
126 u32 rss_pf_map;
127 u32 rss_pf_mask;
128 u32 rss_pf_config;
129 };
130
131 struct cudbg_ch_cntxt {
132 uint32_t cntxt_type;
133 uint32_t cntxt_id;
134 uint32_t data[SGE_CTXT_SIZE / 4];
135 };
136
137 struct cudbg_tcam {
138 u32 filter_start;
139 u32 server_start;
140 u32 clip_start;
141 u32 routing_start;
142 u32 tid_hash_base;
143 u32 max_tid;
144 };
145
146 #if 0
147 struct cudbg_mbox_log {
148 struct mbox_cmd entry;
149 u32 hi[MBOX_LEN / 8];
150 u32 lo[MBOX_LEN / 8];
151 };
152 #endif
153
154 struct cudbg_tid_data {
155 u32 tid;
156 u32 dbig_cmd;
157 u32 dbig_conf;
158 u32 dbig_rsp_stat;
159 u32 data[CUDBG_NUM_REQ_REGS];
160 };
161
162 struct cudbg_cntxt_field {
163 char *name;
164 u32 start_bit;
165 u32 end_bit;
166 u32 shift;
167 u32 islog2;
168 };
169
170 struct cudbg_mps_tcam {
171 u64 mask;
172 u32 rplc[8];
173 u32 idx;
174 u32 cls_lo;
175 u32 cls_hi;
176 u32 rplc_size;
177 u32 vniy;
178 u32 vnix;
179 u32 dip_hit;
180 u32 vlan_vld;
181 u32 repli;
182 u16 ivlan;
183 u8 addr[ETH_ALEN];
184 u8 lookup_type;
185 u8 port_num;
186 u8 reserved[2];
187 };
188
189 struct rss_vf_conf {
190 u32 rss_vf_vfl;
191 u32 rss_vf_vfh;
192 };
193
194 struct rss_config {
195 u32 tp_rssconf; /* A_TP_RSS_CONFIG */
196 u32 tp_rssconf_tnl; /* A_TP_RSS_CONFIG_TNL */
197 u32 tp_rssconf_ofd; /* A_TP_RSS_CONFIG_OFD */
198 u32 tp_rssconf_syn; /* A_TP_RSS_CONFIG_SYN */
199 u32 tp_rssconf_vrt; /* A_TP_RSS_CONFIG_VRT */
200 u32 tp_rssconf_cng; /* A_TP_RSS_CONFIG_CNG */
201 u32 chip;
202 };
203
204 struct struct_pm_stats {
205 u32 tx_cnt[T6_PM_NSTATS];
206 u32 rx_cnt[T6_PM_NSTATS];
207 u64 tx_cyc[T6_PM_NSTATS];
208 u64 rx_cyc[T6_PM_NSTATS];
209 };
210
211 struct struct_hw_sched {
212 u32 kbps[NTX_SCHED];
213 u32 ipg[NTX_SCHED];
214 u32 pace_tab[NTX_SCHED];
215 u32 mode;
216 u32 map;
217 };
218
219 struct struct_tcp_stats {
220 struct tp_tcp_stats v4, v6;
221 };
222
223 struct struct_tp_err_stats {
224 struct tp_err_stats stats;
225 u32 nchan;
226 };
227
228 struct struct_tp_fcoe_stats {
229 struct tp_fcoe_stats stats[4];
230 u32 nchan;
231 };
232
233 struct struct_mac_stats {
234 u32 port_count;
235 struct port_stats stats[4];
236 };
237
238 struct struct_mac_stats_rev1 {
239 struct cudbg_ver_hdr ver_hdr;
240 u32 port_count;
241 u32 reserved;
242 struct port_stats stats[4];
243 };
244
245 struct struct_tp_cpl_stats {
246 struct tp_cpl_stats stats;
247 u32 nchan;
248 };
249
250 struct struct_wc_stats {
251 u32 wr_cl_success;
252 u32 wr_cl_fail;
253 };
254
255 struct struct_ulptx_la {
256 u32 rdptr[CUDBG_NUM_ULPTX];
257 u32 wrptr[CUDBG_NUM_ULPTX];
258 u32 rddata[CUDBG_NUM_ULPTX];
259 u32 rd_data[CUDBG_NUM_ULPTX][CUDBG_NUM_ULPTX_READ];
260 };
261
262 struct struct_ulprx_la {
263 u32 data[ULPRX_LA_SIZE * 8];
264 u32 size;
265 };
266
267 struct struct_cim_qcfg {
268 u8 chip;
269 u16 base[CIM_NUM_IBQ + CIM_NUM_OBQ_T5];
270 u16 size[CIM_NUM_IBQ + CIM_NUM_OBQ_T5];
271 u16 thres[CIM_NUM_IBQ];
272 u32 obq_wr[2 * CIM_NUM_OBQ_T5];
273 u32 stat[4 * (CIM_NUM_IBQ + CIM_NUM_OBQ_T5)];
274 };
275
276 enum region_index {
277 REGN_DBQ_CONTEXS_IDX,
278 REGN_IMSG_CONTEXTS_IDX,
279 REGN_FLM_CACHE_IDX,
280 REGN_TCBS_IDX,
281 REGN_PSTRUCT_IDX,
282 REGN_TIMERS_IDX,
283 REGN_RX_FL_IDX,
284 REGN_TX_FL_IDX,
285 REGN_PSTRUCT_FL_IDX,
286 REGN_TX_PAYLOAD_IDX,
287 REGN_RX_PAYLOAD_IDX,
288 REGN_LE_HASH_IDX,
289 REGN_ISCSI_IDX,
290 REGN_TDDP_IDX,
291 REGN_TPT_IDX,
292 REGN_STAG_IDX,
293 REGN_RQ_IDX,
294 REGN_RQUDP_IDX,
295 REGN_PBL_IDX,
296 REGN_TXPBL_IDX,
297 REGN_DBVFIFO_IDX,
298 REGN_ULPRX_STATE_IDX,
299 REGN_ULPTX_STATE_IDX,
300 #ifndef __NO_DRIVER_OCQ_SUPPORT__
301 REGN_ON_CHIP_Q_IDX,
302 #endif
303 };
304
305 static const char * const region[] = {
306 "DBQ contexts:", "IMSG contexts:", "FLM cache:", "TCBs:",
307 "Pstructs:", "Timers:", "Rx FL:", "Tx FL:", "Pstruct FL:",
308 "Tx payload:", "Rx payload:", "LE hash:", "iSCSI region:",
309 "TDDP region:", "TPT region:", "STAG region:", "RQ region:",
310 "RQUDP region:", "PBL region:", "TXPBL region:",
311 "DBVFIFO region:", "ULPRX state:", "ULPTX state:",
312 #ifndef __NO_DRIVER_OCQ_SUPPORT__
313 "On-chip queues:"
314 #endif
315 };
316
317 /* Info relative to memory region (i.e. wrt 0). */
318 struct struct_region_info {
319 bool exist; /* Does region exists in current memory region? */
320 u32 start; /* Start wrt 0 */
321 u32 end; /* End wrt 0 */
322 };
323
324 struct struct_port_usage {
325 u32 id;
326 u32 used;
327 u32 alloc;
328 };
329
330 struct struct_lpbk_usage {
331 u32 id;
332 u32 used;
333 u32 alloc;
334 };
335
336 struct struct_mem_desc {
337 u32 base;
338 u32 limit;
339 u32 idx;
340 };
341
342 enum string_size_units {
343 STRING_UNITS_10, /* use powers of 10^3 (standard SI) */
344 STRING_UNITS_2, /* use binary powers of 2^10 */
345 };
346
347 struct struct_meminfo {
348 struct struct_mem_desc avail[4];
349 struct struct_mem_desc mem[ARRAY_SIZE(region) + 3];
350 u32 avail_c;
351 u32 mem_c;
352 u32 up_ram_lo;
353 u32 up_ram_hi;
354 u32 up_extmem2_lo;
355 u32 up_extmem2_hi;
356 u32 rx_pages_data[3];
357 u32 tx_pages_data[4];
358 u32 p_structs;
359 struct struct_port_usage port_data[4];
360 u32 port_used[4];
361 u32 port_alloc[4];
362 u32 loopback_used[NCHAN];
363 u32 loopback_alloc[NCHAN];
364 };
365
366 #ifndef __GNUC__
367 #pragma warning(disable : 4200)
368 #endif
369
370 struct struct_lb_stats {
371 int nchan;
372 struct lb_port_stats s[0];
373 };
374
375 struct struct_clk_info {
376 u64 retransmit_min;
377 u64 retransmit_max;
378 u64 persist_timer_min;
379 u64 persist_timer_max;
380 u64 keepalive_idle_timer;
381 u64 keepalive_interval;
382 u64 initial_srtt;
383 u64 finwait2_timer;
384 u32 dack_timer;
385 u32 res;
386 u32 cclk_ps;
387 u32 tre;
388 u32 dack_re;
389 char core_clk_period[32];
390 char tp_timer_tick[32];
391 char tcp_tstamp_tick[32];
392 char dack_tick[32];
393 };
394
395 struct cim_pif_la {
396 int size;
397 u8 data[0];
398 };
399
400 struct struct_tp_la {
401 u32 size;
402 u32 mode;
403 u8 data[0];
404 };
405
406 struct field_desc {
407 const char *name;
408 u32 start;
409 u32 width;
410 };
411
412 struct tp_mib_type {
413 char *key;
414 u32 addr;
415 u32 value;
416 };
417
418 struct wtp_type_0 {
419 u32 sop;
420 u32 eop;
421 };
422
423 struct wtp_type_1 {
424 u32 sop[2];
425 u32 eop[2];
426 };
427
428 struct wtp_type_2 {
429 u32 sop[4];
430 u32 eop[4];
431 };
432
433 struct wtp_type_3 {
434 u32 sop[4];
435 u32 eop[4];
436 u32 drops;
437 };
438
439 struct wtp_data {
440 /*TX path, Request Work request sub-path:*/
441
442 struct wtp_type_1 sge_pcie_cmd_req; /*SGE_DEBUG PC_Req_xOPn*/
443 struct wtp_type_1 pcie_core_cmd_req; /*PCIE_CMDR_REQ_CNT*/
444
445
446 /*TX path, Work request to uP sub-path*/
447 struct wtp_type_1 core_pcie_cmd_rsp; /*PCIE_CMDR_RSP_CNT*/
448 struct wtp_type_1 pcie_sge_cmd_rsp; /*SGE_DEBUG PC_Rsp_xOPn*/
449 struct wtp_type_1 sge_cim; /*SGE_DEBUG CIM_xOPn*/
450
451 /*TX path, Data request path from ULP_TX to core*/
452 struct wtp_type_2 utx_sge_dma_req; /*SGE UD_Rx_xOPn*/
453 struct wtp_type_2 sge_pcie_dma_req; /*SGE PD_Req_Rdn (no eops)*/
454 struct wtp_type_2 pcie_core_dma_req; /*PCIE_DMAR_REQ_CNT (no eops)*/
455
456 /*Main TX path, from core to wire*/
457 struct wtp_type_2 core_pcie_dma_rsp; /*PCIE_DMAR_RSP_SOP_CNT/
458 PCIE_DMAR_EOP_CNT*/
459 struct wtp_type_2 pcie_sge_dma_rsp; /*SGE_DEBUG PD_Rsp_xOPn*/
460 struct wtp_type_2 sge_utx; /*SGE_DEBUG U_Tx_xOPn*/
461 struct wtp_type_2 utx_tp; /*ULP_TX_SE_CNT_CHn[xOP_CNT_ULP2TP]*/
462 struct wtp_type_2 utx_tpcside; /*TP_DBG_CSIDE_RXn[RxXoPCnt]*/
463
464 struct wtp_type_2 tpcside_rxpld;
465 struct wtp_type_2 tpcside_rxarb; /*TP_DBG_CSIDE_RXn[RxArbXopCnt]*/
466 struct wtp_type_2 tpcside_rxcpl;
467
468 struct wtp_type_2 tpeside_mps; /*TP_DBG_ESDIE_PKT0[TxXoPCnt]*/
469 struct wtp_type_2 tpeside_pm;
470 struct wtp_type_2 tpeside_pld;
471
472 /*Tx path, PCIE t5 DMA stat*/
473 struct wtp_type_2 pcie_t5_dma_stat3;
474
475 /*Tx path, SGE debug data high index 6*/
476 struct wtp_type_2 sge_debug_data_high_index_6;
477
478 /*Tx path, SGE debug data high index 3*/
479 struct wtp_type_2 sge_debug_data_high_index_3;
480
481 /*Tx path, ULP SE CNT CHx*/
482 struct wtp_type_2 ulp_se_cnt_chx;
483
484 /*pcie cmd stat 2*/
485 struct wtp_type_2 pcie_cmd_stat2;
486
487 /*pcie cmd stat 3*/
488 struct wtp_type_2 pcie_cmd_stat3;
489
490 struct wtp_type_2 pcie_dma1_stat2_core;
491
492 struct wtp_type_1 sge_work_req_pkt;
493
494 struct wtp_type_2 sge_debug_data_high_indx5;
495
496 /*Tx path, mac portx pkt count*/
497 struct wtp_type_2 mac_portx_pkt_count;
498
499 /*Rx path, mac porrx pkt count*/
500 struct wtp_type_2 mac_porrx_pkt_count;
501
502 /*Rx path, PCIE T5 dma1 stat 2*/
503 struct wtp_type_2 pcie_dma1_stat2;
504
505 /*Rx path, sge debug data high index 7*/
506 struct wtp_type_2 sge_debug_data_high_indx7;
507
508 /*Rx path, sge debug data high index 1*/
509 struct wtp_type_1 sge_debug_data_high_indx1;
510
511 /*Rx path, TP debug CSIDE Tx register*/
512 struct wtp_type_1 utx_tpcside_tx;
513
514 /*Rx path, LE DB response count*/
515 struct wtp_type_0 le_db_rsp_cnt;
516
517 /*Rx path, TP debug Eside PKTx*/
518 struct wtp_type_2 tp_dbg_eside_pktx;
519
520 /*Rx path, sge debug data high index 9*/
521 struct wtp_type_1 sge_debug_data_high_indx9;
522
523 /*Tx path, mac portx aFramesTransmittesok*/
524 struct wtp_type_2 mac_portx_aframestra_ok;
525
526 /*Rx path, mac portx aFramesTransmittesok*/
527 struct wtp_type_2 mac_porrx_aframestra_ok;
528
529 /*Tx path, MAC_PORT_MTIP_1G10G_RX_etherStatsPkts*/
530 struct wtp_type_1 mac_portx_etherstatspkts;
531
532 /*Rx path, MAC_PORT_MTIP_1G10G_RX_etherStatsPkts*/
533 struct wtp_type_1 mac_porrx_etherstatspkts;
534
535 struct wtp_type_3 tp_mps; /*MPS_TX_SE_CNT_TP01 and
536 MPS_TX_SE_CNT_TP34*/
537 struct wtp_type_3 mps_xgm; /*MPS_TX_SE_CNT_MAC01 and
538 MPS_TX_SE_CNT_MAC34*/
539 struct wtp_type_2 tx_xgm_xgm; /*XGMAC_PORT_PKT_CNT_PORT_n*/
540 struct wtp_type_2 xgm_wire; /*XGMAC_PORT_XGM_STAT_TX_FRAME_LOW_PORT_N
541 (clear on read)*/
542
543 /*RX path, from wire to core.*/
544 struct wtp_type_2 wire_xgm; /*XGMAC_PORT_XGM_STAT_RX_FRAMES_LOW_PORT_N
545 (clear on read)*/
546 struct wtp_type_2 rx_xgm_xgm; /*XGMAC_PORT_PKT_CNT_PORT_n*/
547 struct _xgm_mps { /*MPS_RX_SE_CNT_INn*/
548 u32 sop[8]; /* => undef,*/
549 u32 eop[8]; /* => undef,*/
550 u32 drop; /* => undef,*/
551 u32 cls_drop; /* => undef,*/
552 u32 err; /* => undef,*/
553 u32 bp; /* => undef,*/
554 } xgm_mps;
555
556 struct wtp_type_3 mps_tp; /*MPS_RX_SE_CNT_OUT01 and
557 MPS_RX_SE_CNT_OUT23*/
558 struct wtp_type_2 mps_tpeside; /*TP_DBG_ESIDE_PKTn*/
559 struct wtp_type_1 tpeside_pmrx; /*???*/
560 struct wtp_type_2 pmrx_ulprx; /*ULP_RX_SE_CNT_CHn[xOP_CNT_INn]*/
561 struct wtp_type_2 ulprx_tpcside; /*ULP_RX_SE_CNT_CHn[xOP_CNT_OUTn]*/
562 struct wtp_type_2 tpcside_csw; /*TP_DBG_CSIDE_TXn[TxSopCnt]*/
563 struct wtp_type_2 tpcside_pm;
564 struct wtp_type_2 tpcside_uturn;
565 struct wtp_type_2 tpcside_txcpl;
566 struct wtp_type_1 tp_csw; /*SGE_DEBUG CPLSW_TP_Rx_xOPn*/
567 struct wtp_type_1 csw_sge; /*SGE_DEBUG T_Rx_xOPn*/
568 struct wtp_type_2 sge_pcie; /*SGE_DEBUG PD_Req_SopN -
569 PD_Req_RdN - PD_ReqIntN*/
570 struct wtp_type_2 sge_pcie_ints; /*SGE_DEBUG PD_Req_IntN*/
571 struct wtp_type_2 pcie_core_dmaw; /*PCIE_DMAW_SOP_CNT and
572 PCIE_DMAW_EOP_CNT*/
573 struct wtp_type_2 pcie_core_dmai; /*PCIE_DMAI_CNT*/
574
575 };
576
577 struct tp_mib_data {
578 struct tp_mib_type TP_MIB_MAC_IN_ERR_0;
579 struct tp_mib_type TP_MIB_MAC_IN_ERR_1;
580 struct tp_mib_type TP_MIB_MAC_IN_ERR_2;
581 struct tp_mib_type TP_MIB_MAC_IN_ERR_3;
582 struct tp_mib_type TP_MIB_HDR_IN_ERR_0;
583 struct tp_mib_type TP_MIB_HDR_IN_ERR_1;
584 struct tp_mib_type TP_MIB_HDR_IN_ERR_2;
585 struct tp_mib_type TP_MIB_HDR_IN_ERR_3;
586 struct tp_mib_type TP_MIB_TCP_IN_ERR_0;
587 struct tp_mib_type TP_MIB_TCP_IN_ERR_1;
588 struct tp_mib_type TP_MIB_TCP_IN_ERR_2;
589 struct tp_mib_type TP_MIB_TCP_IN_ERR_3;
590 struct tp_mib_type TP_MIB_TCP_OUT_RST;
591 struct tp_mib_type TP_MIB_TCP_IN_SEG_HI;
592 struct tp_mib_type TP_MIB_TCP_IN_SEG_LO;
593 struct tp_mib_type TP_MIB_TCP_OUT_SEG_HI;
594 struct tp_mib_type TP_MIB_TCP_OUT_SEG_LO;
595 struct tp_mib_type TP_MIB_TCP_RXT_SEG_HI;
596 struct tp_mib_type TP_MIB_TCP_RXT_SEG_LO;
597 struct tp_mib_type TP_MIB_TNL_CNG_DROP_0;
598 struct tp_mib_type TP_MIB_TNL_CNG_DROP_1;
599 struct tp_mib_type TP_MIB_TNL_CNG_DROP_2;
600 struct tp_mib_type TP_MIB_TNL_CNG_DROP_3;
601 struct tp_mib_type TP_MIB_OFD_CHN_DROP_0;
602 struct tp_mib_type TP_MIB_OFD_CHN_DROP_1;
603 struct tp_mib_type TP_MIB_OFD_CHN_DROP_2;
604 struct tp_mib_type TP_MIB_OFD_CHN_DROP_3;
605 struct tp_mib_type TP_MIB_TNL_OUT_PKT_0;
606 struct tp_mib_type TP_MIB_TNL_OUT_PKT_1;
607 struct tp_mib_type TP_MIB_TNL_OUT_PKT_2;
608 struct tp_mib_type TP_MIB_TNL_OUT_PKT_3;
609 struct tp_mib_type TP_MIB_TNL_IN_PKT_0;
610 struct tp_mib_type TP_MIB_TNL_IN_PKT_1;
611 struct tp_mib_type TP_MIB_TNL_IN_PKT_2;
612 struct tp_mib_type TP_MIB_TNL_IN_PKT_3;
613 struct tp_mib_type TP_MIB_TCP_V6IN_ERR_0;
614 struct tp_mib_type TP_MIB_TCP_V6IN_ERR_1;
615 struct tp_mib_type TP_MIB_TCP_V6IN_ERR_2;
616 struct tp_mib_type TP_MIB_TCP_V6IN_ERR_3;
617 struct tp_mib_type TP_MIB_TCP_V6OUT_RST;
618 struct tp_mib_type TP_MIB_TCP_V6IN_SEG_HI;
619 struct tp_mib_type TP_MIB_TCP_V6IN_SEG_LO;
620 struct tp_mib_type TP_MIB_TCP_V6OUT_SEG_HI;
621 struct tp_mib_type TP_MIB_TCP_V6OUT_SEG_LO;
622 struct tp_mib_type TP_MIB_TCP_V6RXT_SEG_HI;
623 struct tp_mib_type TP_MIB_TCP_V6RXT_SEG_LO;
624 struct tp_mib_type TP_MIB_OFD_ARP_DROP;
625 struct tp_mib_type TP_MIB_OFD_DFR_DROP;
626 struct tp_mib_type TP_MIB_CPL_IN_REQ_0;
627 struct tp_mib_type TP_MIB_CPL_IN_REQ_1;
628 struct tp_mib_type TP_MIB_CPL_IN_REQ_2;
629 struct tp_mib_type TP_MIB_CPL_IN_REQ_3;
630 struct tp_mib_type TP_MIB_CPL_OUT_RSP_0;
631 struct tp_mib_type TP_MIB_CPL_OUT_RSP_1;
632 struct tp_mib_type TP_MIB_CPL_OUT_RSP_2;
633 struct tp_mib_type TP_MIB_CPL_OUT_RSP_3;
634 struct tp_mib_type TP_MIB_TNL_LPBK_0;
635 struct tp_mib_type TP_MIB_TNL_LPBK_1;
636 struct tp_mib_type TP_MIB_TNL_LPBK_2;
637 struct tp_mib_type TP_MIB_TNL_LPBK_3;
638 struct tp_mib_type TP_MIB_TNL_DROP_0;
639 struct tp_mib_type TP_MIB_TNL_DROP_1;
640 struct tp_mib_type TP_MIB_TNL_DROP_2;
641 struct tp_mib_type TP_MIB_TNL_DROP_3;
642 struct tp_mib_type TP_MIB_FCOE_DDP_0;
643 struct tp_mib_type TP_MIB_FCOE_DDP_1;
644 struct tp_mib_type TP_MIB_FCOE_DDP_2;
645 struct tp_mib_type TP_MIB_FCOE_DDP_3;
646 struct tp_mib_type TP_MIB_FCOE_DROP_0;
647 struct tp_mib_type TP_MIB_FCOE_DROP_1;
648 struct tp_mib_type TP_MIB_FCOE_DROP_2;
649 struct tp_mib_type TP_MIB_FCOE_DROP_3;
650 struct tp_mib_type TP_MIB_FCOE_BYTE_0_HI;
651 struct tp_mib_type TP_MIB_FCOE_BYTE_0_LO;
652 struct tp_mib_type TP_MIB_FCOE_BYTE_1_HI;
653 struct tp_mib_type TP_MIB_FCOE_BYTE_1_LO;
654 struct tp_mib_type TP_MIB_FCOE_BYTE_2_HI;
655 struct tp_mib_type TP_MIB_FCOE_BYTE_2_LO;
656 struct tp_mib_type TP_MIB_FCOE_BYTE_3_HI;
657 struct tp_mib_type TP_MIB_FCOE_BYTE_3_LO;
658 struct tp_mib_type TP_MIB_OFD_VLN_DROP_0;
659 struct tp_mib_type TP_MIB_OFD_VLN_DROP_1;
660 struct tp_mib_type TP_MIB_OFD_VLN_DROP_2;
661 struct tp_mib_type TP_MIB_OFD_VLN_DROP_3;
662 struct tp_mib_type TP_MIB_USM_PKTS;
663 struct tp_mib_type TP_MIB_USM_DROP;
664 struct tp_mib_type TP_MIB_USM_BYTES_HI;
665 struct tp_mib_type TP_MIB_USM_BYTES_LO;
666 struct tp_mib_type TP_MIB_TID_DEL;
667 struct tp_mib_type TP_MIB_TID_INV;
668 struct tp_mib_type TP_MIB_TID_ACT;
669 struct tp_mib_type TP_MIB_TID_PAS;
670 struct tp_mib_type TP_MIB_RQE_DFR_MOD;
671 struct tp_mib_type TP_MIB_RQE_DFR_PKT;
672 };
673
674 struct cudbg_reg_info {
675 const char *name;
676 unsigned int addr;
677 unsigned int len;
678 };
679
680 struct tp1_reg_info {
681 char addr[10];
682 char name[40];
683 };
684
685 struct ireg_field {
686 u32 ireg_addr;
687 u32 ireg_data;
688 u32 ireg_local_offset;
689 u32 ireg_offset_range;
690 };
691
692 struct ireg_buf {
693 struct ireg_field tp_pio;
694 u32 outbuf[32];
695 };
696
697 struct tx_rate {
698 u64 nrate[NCHAN];
699 u64 orate[NCHAN];
700 u32 nchan;
701 };
702
703 struct tid_info_region {
704 u32 ntids;
705 u32 nstids;
706 u32 stid_base;
707 u32 hash_base;
708
709 u32 natids;
710 u32 nftids;
711 u32 ftid_base;
712 u32 aftid_base;
713 u32 aftid_end;
714
715 /* Server filter region */
716 u32 sftid_base;
717 u32 nsftids;
718
719 /* UO context range */
720 u32 uotid_base;
721 u32 nuotids;
722
723 u32 sb;
724 u32 flags;
725 u32 le_db_conf;
726 u32 IP_users;
727 u32 IPv6_users;
728
729 u32 hpftid_base;
730 u32 nhpftids;
731 };
732
733 struct tid_info_region_rev1 {
734 struct cudbg_ver_hdr ver_hdr;
735 struct tid_info_region tid;
736 u32 tid_start;
737 u32 reserved[16];
738 };
739
740 struct struct_vpd_data {
741 u8 sn[SN_MAX_LEN + 1];
742 u8 bn[BN_MAX_LEN + 1];
743 u8 na[NA_MAX_LEN + 1];
744 u8 mn[MN_MAX_LEN + 1];
745 u16 fw_major;
746 u16 fw_minor;
747 u16 fw_micro;
748 u16 fw_build;
749 u32 scfg_vers;
750 u32 vpd_vers;
751 };
752
753 struct sw_state {
754 u32 fw_state;
755 u8 caller_string[100];
756 u8 os_type;
757 u8 reserved[3];
758 u32 reserved1[16];
759 };
760
761 static u32 ATTRIBUTE_UNUSED t6_tp_pio_array[][4] = {
762 {0x7e40, 0x7e44, 0x020, 28}, /* t6_tp_pio_regs_20_to_3b */
763 {0x7e40, 0x7e44, 0x040, 10}, /* t6_tp_pio_regs_40_to_49 */
764 {0x7e40, 0x7e44, 0x050, 10}, /* t6_tp_pio_regs_50_to_59 */
765 {0x7e40, 0x7e44, 0x060, 14}, /* t6_tp_pio_regs_60_to_6d */
766 {0x7e40, 0x7e44, 0x06F, 1}, /* t6_tp_pio_regs_6f */
767 {0x7e40, 0x7e44, 0x070, 6}, /* t6_tp_pio_regs_70_to_75 */
768 {0x7e40, 0x7e44, 0x130, 18}, /* t6_tp_pio_regs_130_to_141 */
769 {0x7e40, 0x7e44, 0x145, 19}, /* t6_tp_pio_regs_145_to_157 */
770 {0x7e40, 0x7e44, 0x160, 1}, /* t6_tp_pio_regs_160 */
771 {0x7e40, 0x7e44, 0x230, 25}, /* t6_tp_pio_regs_230_to_248 */
772 {0x7e40, 0x7e44, 0x24a, 3}, /* t6_tp_pio_regs_24c */
773 {0x7e40, 0x7e44, 0x8C0, 1} /* t6_tp_pio_regs_8c0 */
774 };
775
776 static u32 ATTRIBUTE_UNUSED t5_tp_pio_array[][4] = {
777 {0x7e40, 0x7e44, 0x020, 28}, /* t5_tp_pio_regs_20_to_3b */
778 {0x7e40, 0x7e44, 0x040, 19}, /* t5_tp_pio_regs_40_to_52 */
779 {0x7e40, 0x7e44, 0x054, 2}, /* t5_tp_pio_regs_54_to_55 */
780 {0x7e40, 0x7e44, 0x060, 13}, /* t5_tp_pio_regs_60_to_6c */
781 {0x7e40, 0x7e44, 0x06F, 1}, /* t5_tp_pio_regs_6f */
782 {0x7e40, 0x7e44, 0x120, 4}, /* t5_tp_pio_regs_120_to_123 */
783 {0x7e40, 0x7e44, 0x12b, 2}, /* t5_tp_pio_regs_12b_to_12c */
784 {0x7e40, 0x7e44, 0x12f, 21}, /* t5_tp_pio_regs_12f_to_143 */
785 {0x7e40, 0x7e44, 0x145, 19}, /* t5_tp_pio_regs_145_to_157 */
786 {0x7e40, 0x7e44, 0x230, 25}, /* t5_tp_pio_regs_230_to_248 */
787 {0x7e40, 0x7e44, 0x8C0, 1} /* t5_tp_pio_regs_8c0 */
788 };
789
790 static u32 ATTRIBUTE_UNUSED t6_ma_ireg_array[][4] = {
791 {0x78f8, 0x78fc, 0xa000, 23}, /* t6_ma_regs_a000_to_a016 */
792 {0x78f8, 0x78fc, 0xa400, 30}, /* t6_ma_regs_a400_to_a41e */
793 {0x78f8, 0x78fc, 0xa800, 20} /* t6_ma_regs_a800_to_a813 */
794 };
795
796 static u32 ATTRIBUTE_UNUSED t6_ma_ireg_array2[][4] = {
797 {0x78f8, 0x78fc, 0xe400, 17}, /* t6_ma_regs_e400_to_e600 */
798 {0x78f8, 0x78fc, 0xe640, 13} /* t6_ma_regs_e640_to_e7c0 */
799 };
800
801 static u32 ATTRIBUTE_UNUSED t6_hma_ireg_array[][4] = {
802 {0x51320, 0x51324, 0xa000, 32} /* t6_hma_regs_a000_to_a01f */
803 };
804 static u32 ATTRIBUTE_UNUSED t5_pcie_pdbg_array[][4] = {
805 {0x5a04, 0x5a0c, 0x00, 0x20}, /* t5_pcie_pdbg_regs_00_to_20 */
806 {0x5a04, 0x5a0c, 0x21, 0x20}, /* t5_pcie_pdbg_regs_21_to_40 */
807 {0x5a04, 0x5a0c, 0x41, 0x10}, /* t5_pcie_pdbg_regs_41_to_50 */
808 };
809
810 static u32 ATTRIBUTE_UNUSED t5_pcie_config_array[][2] = {
811 {0x0, 0x34},
812 {0x3c, 0x40},
813 {0x50, 0x64},
814 {0x70, 0x80},
815 {0x94, 0xa0},
816 {0xb0, 0xb8},
817 {0xd0, 0xd4},
818 {0x100, 0x128},
819 {0x140, 0x148},
820 {0x150, 0x164},
821 {0x170, 0x178},
822 {0x180, 0x194},
823 {0x1a0, 0x1b8},
824 {0x1c0, 0x208},
825 };
826
827 static u32 ATTRIBUTE_UNUSED t5_pcie_cdbg_array[][4] = {
828 {0x5a10, 0x5a18, 0x00, 0x20}, /* t5_pcie_cdbg_regs_00_to_20 */
829 {0x5a10, 0x5a18, 0x21, 0x18}, /* t5_pcie_cdbg_regs_21_to_37 */
830 };
831
832 static u32 ATTRIBUTE_UNUSED t6_tp_tm_pio_array[1][4] = {
833 {0x7e18, 0x7e1c, 0x0, 12}
834 };
835
836 static u32 ATTRIBUTE_UNUSED t5_tp_tm_pio_array[1][4] = {
837 {0x7e18, 0x7e1c, 0x0, 12}
838 };
839
840 static u32 ATTRIBUTE_UNUSED t5_pm_rx_array[][4] = {
841 {0x8FD0, 0x8FD4, 0x10000, 0x20}, /* t5_pm_rx_regs_10000_to_10020 */
842 {0x8FD0, 0x8FD4, 0x10021, 0x0D}, /* t5_pm_rx_regs_10021_to_1002c */
843 };
844
845 static u32 ATTRIBUTE_UNUSED t5_pm_tx_array[][4] = {
846 {0x8FF0, 0x8FF4, 0x10000, 0x20}, /* t5_pm_tx_regs_10000_to_10020 */
847 {0x8FF0, 0x8FF4, 0x10021, 0x1D}, /* t5_pm_tx_regs_10021_to_1003c */
848 };
849
850 static u32 ATTRIBUTE_UNUSED t6_tp_mib_index_array[6][4] = {
851 {0x7e50, 0x7e54, 0x0, 13},
852 {0x7e50, 0x7e54, 0x10, 6},
853 {0x7e50, 0x7e54, 0x18, 21},
854 {0x7e50, 0x7e54, 0x30, 32},
855 {0x7e50, 0x7e54, 0x50, 22},
856 {0x7e50, 0x7e54, 0x68, 12}
857 };
858
859 static u32 ATTRIBUTE_UNUSED t5_tp_mib_index_array[9][4] = {
860 {0x7e50, 0x7e54, 0x0, 13},
861 {0x7e50, 0x7e54, 0x10, 6},
862 {0x7e50, 0x7e54, 0x18, 8},
863 {0x7e50, 0x7e54, 0x20, 13},
864 {0x7e50, 0x7e54, 0x30, 16},
865 {0x7e50, 0x7e54, 0x40, 16},
866 {0x7e50, 0x7e54, 0x50, 16},
867 {0x7e50, 0x7e54, 0x60, 6},
868 {0x7e50, 0x7e54, 0x68, 4}
869 };
870
871 static u32 ATTRIBUTE_UNUSED t5_sge_dbg_index_array[9][4] = {
872 {0x10cc, 0x10d0, 0x0, 16},
873 {0x10cc, 0x10d4, 0x0, 16},
874 };
875
876 static u32 ATTRIBUTE_UNUSED t6_up_cim_reg_array[][4] = {
877 {0x7b50, 0x7b54, 0x2000, 0x20}, /* up_cim_2000_to_207c */
878 {0x7b50, 0x7b54, 0x2080, 0x1d}, /* up_cim_2080_to_20fc */
879 {0x7b50, 0x7b54, 0x00, 0x20}, /* up_cim_00_to_7c */
880 {0x7b50, 0x7b54, 0x80, 0x20}, /* up_cim_80_to_fc */
881 {0x7b50, 0x7b54, 0x100, 0x11}, /* up_cim_100_to_14c */
882 {0x7b50, 0x7b54, 0x200, 0x10}, /* up_cim_200_to_23c */
883 {0x7b50, 0x7b54, 0x240, 0x2}, /* up_cim_240_to_244 */
884 {0x7b50, 0x7b54, 0x250, 0x2}, /* up_cim_250_to_254 */
885 {0x7b50, 0x7b54, 0x260, 0x2}, /* up_cim_260_to_264 */
886 {0x7b50, 0x7b54, 0x270, 0x2}, /* up_cim_270_to_274 */
887 {0x7b50, 0x7b54, 0x280, 0x20}, /* up_cim_280_to_2fc */
888 {0x7b50, 0x7b54, 0x300, 0x20}, /* up_cim_300_to_37c */
889 {0x7b50, 0x7b54, 0x380, 0x14}, /* up_cim_380_to_3cc */
890
891 };
892
893 static u32 ATTRIBUTE_UNUSED t5_up_cim_reg_array[][4] = {
894 {0x7b50, 0x7b54, 0x2000, 0x20}, /* up_cim_2000_to_207c */
895 {0x7b50, 0x7b54, 0x2080, 0x19}, /* up_cim_2080_to_20ec */
896 {0x7b50, 0x7b54, 0x00, 0x20}, /* up_cim_00_to_7c */
897 {0x7b50, 0x7b54, 0x80, 0x20}, /* up_cim_80_to_fc */
898 {0x7b50, 0x7b54, 0x100, 0x11}, /* up_cim_100_to_14c */
899 {0x7b50, 0x7b54, 0x200, 0x10}, /* up_cim_200_to_23c */
900 {0x7b50, 0x7b54, 0x240, 0x2}, /* up_cim_240_to_244 */
901 {0x7b50, 0x7b54, 0x250, 0x2}, /* up_cim_250_to_254 */
902 {0x7b50, 0x7b54, 0x260, 0x2}, /* up_cim_260_to_264 */
903 {0x7b50, 0x7b54, 0x270, 0x2}, /* up_cim_270_to_274 */
904 {0x7b50, 0x7b54, 0x280, 0x20}, /* up_cim_280_to_2fc */
905 {0x7b50, 0x7b54, 0x300, 0x20}, /* up_cim_300_to_37c */
906 {0x7b50, 0x7b54, 0x380, 0x14}, /* up_cim_380_to_3cc */
907 };
908
909 #endif
Cache object: 760e0e80d1a4a938224da9949cb4295b
|