xref: /OK3568_Linux_fs/external/rkwifibt/drivers/infineon/include/etd.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Extended Trap data component interface file.
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Portions of this code are copyright (c) 2021 Cypress Semiconductor Corporation
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * Copyright (C) 1999-2017, Broadcom Corporation
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  *      Unless you and Broadcom execute a separate written software license
9*4882a593Smuzhiyun  * agreement governing use of this software, this software is licensed to you
10*4882a593Smuzhiyun  * under the terms of the GNU General Public License version 2 (the "GPL"),
11*4882a593Smuzhiyun  * available at http://www.broadcom.com/licenses/GPLv2.php, with the
12*4882a593Smuzhiyun  * following added to such license:
13*4882a593Smuzhiyun  *
14*4882a593Smuzhiyun  *      As a special exception, the copyright holders of this software give you
15*4882a593Smuzhiyun  * permission to link this software with independent modules, and to copy and
16*4882a593Smuzhiyun  * distribute the resulting executable under terms of your choice, provided that
17*4882a593Smuzhiyun  * you also meet, for each linked independent module, the terms and conditions of
18*4882a593Smuzhiyun  * the license of that module.  An independent module is a module which is not
19*4882a593Smuzhiyun  * derived from this software.  The special exception does not apply to any
20*4882a593Smuzhiyun  * modifications of the software.
21*4882a593Smuzhiyun  *
22*4882a593Smuzhiyun  *      Notwithstanding the above, under no circumstances may you combine this
23*4882a593Smuzhiyun  * software in any way with any other Broadcom software provided under a license
24*4882a593Smuzhiyun  * other than the GPL, without Broadcom's express prior written consent.
25*4882a593Smuzhiyun  *
26*4882a593Smuzhiyun  *
27*4882a593Smuzhiyun  * <<Broadcom-WL-IPTag/Open:>>
28*4882a593Smuzhiyun  *
29*4882a593Smuzhiyun  * $Id$
30*4882a593Smuzhiyun  */
31*4882a593Smuzhiyun 
32*4882a593Smuzhiyun #ifndef _ETD_H_
33*4882a593Smuzhiyun #define _ETD_H_
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun #if defined(ETD) && !defined(WLETD)
36*4882a593Smuzhiyun #include <hnd_trap.h>
37*4882a593Smuzhiyun #endif // endif
38*4882a593Smuzhiyun #include <bcmutils.h>
39*4882a593Smuzhiyun /* Tags for structures being used by etd info iovar.
40*4882a593Smuzhiyun  * Related structures are defined in wlioctl.h.
41*4882a593Smuzhiyun  */
42*4882a593Smuzhiyun #define ETD_TAG_JOIN_CLASSIFICATION_INFO 10 /* general information about join request */
43*4882a593Smuzhiyun #define ETD_TAG_JOIN_TARGET_CLASSIFICATION_INFO 11	/* per target (AP) join information */
44*4882a593Smuzhiyun #define ETD_TAG_ASSOC_STATE 12 /* current state of the Device association state machine */
45*4882a593Smuzhiyun #define ETD_TAG_CHANNEL 13	/* current channel on which the association was performed */
46*4882a593Smuzhiyun #define ETD_TAG_TOTAL_NUM_OF_JOIN_ATTEMPTS 14 /* number of join attempts (bss_retries) */
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun #define  PSMDBG_REG_READ_CNT_FOR_PSMWDTRAP_V1	3
49*4882a593Smuzhiyun #define  PSMDBG_REG_READ_CNT_FOR_PSMWDTRAP_V2	6
50*4882a593Smuzhiyun 
51*4882a593Smuzhiyun #ifndef _LANGUAGE_ASSEMBLY
52*4882a593Smuzhiyun 
53*4882a593Smuzhiyun #define HND_EXTENDED_TRAP_VERSION  1
54*4882a593Smuzhiyun #define HND_EXTENDED_TRAP_BUFLEN   512
55*4882a593Smuzhiyun 
56*4882a593Smuzhiyun typedef struct hnd_ext_trap_hdr {
57*4882a593Smuzhiyun 	uint8 version;    /* Extended trap version info */
58*4882a593Smuzhiyun 	uint8 reserved;   /* currently unused */
59*4882a593Smuzhiyun 	uint16 len;       /* Length of data excluding this header */
60*4882a593Smuzhiyun 	uint8 data[];     /* TLV data */
61*4882a593Smuzhiyun } hnd_ext_trap_hdr_t;
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun typedef enum {
64*4882a593Smuzhiyun 	TAG_TRAP_NONE		 = 0,  /* None trap type */
65*4882a593Smuzhiyun 	TAG_TRAP_SIGNATURE       = 1,  /* Processor register dumps */
66*4882a593Smuzhiyun 	TAG_TRAP_STACK           = 2,  /* Processor stack dump (possible code locations) */
67*4882a593Smuzhiyun 	TAG_TRAP_MEMORY          = 3,  /* Memory subsystem dump */
68*4882a593Smuzhiyun 	TAG_TRAP_DEEPSLEEP       = 4,  /* Deep sleep health check failures */
69*4882a593Smuzhiyun 	TAG_TRAP_PSM_WD          = 5,  /* PSM watchdog information */
70*4882a593Smuzhiyun 	TAG_TRAP_PHY             = 6,  /* Phy related issues */
71*4882a593Smuzhiyun 	TAG_TRAP_BUS             = 7,  /* Bus level issues */
72*4882a593Smuzhiyun 	TAG_TRAP_MAC_SUSP        = 8,  /* Mac level suspend issues */
73*4882a593Smuzhiyun 	TAG_TRAP_BACKPLANE       = 9,  /* Backplane related errors */
74*4882a593Smuzhiyun 	/* Values 10 through 14 are in use by etd_data info iovar */
75*4882a593Smuzhiyun 	TAG_TRAP_PCIE_Q         = 15,  /* PCIE Queue state during memory trap */
76*4882a593Smuzhiyun 	TAG_TRAP_WLC_STATE      = 16,  /* WLAN state during memory trap */
77*4882a593Smuzhiyun 	TAG_TRAP_MAC_WAKE       = 17,  /* Mac level wake issues */
78*4882a593Smuzhiyun 	TAG_TRAP_PHYTXERR_THRESH = 18, /* Phy Tx Err */
79*4882a593Smuzhiyun 	TAG_TRAP_HC_DATA        = 19,  /* Data collected by HC module */
80*4882a593Smuzhiyun 	TAG_TRAP_LOG_DATA	= 20,
81*4882a593Smuzhiyun 	TAG_TRAP_CODE		= 21, /* The trap type */
82*4882a593Smuzhiyun 	TAG_TRAP_HMAP		= 22, /* HMAP violation Address and Info */
83*4882a593Smuzhiyun 	TAG_TRAP_PCIE_ERR_ATTN	= 23, /* PCIE error attn log */
84*4882a593Smuzhiyun 	TAG_TRAP_AXI_ERROR	= 24, /* AXI Error */
85*4882a593Smuzhiyun 	TAG_TRAP_AXI_HOST_INFO  = 25, /* AXI Host log */
86*4882a593Smuzhiyun 	TAG_TRAP_AXI_SR_ERROR	= 26, /* AXI SR error log */
87*4882a593Smuzhiyun 	TAG_TRAP_LAST  /* This must be the last entry */
88*4882a593Smuzhiyun } hnd_ext_tag_trap_t;
89*4882a593Smuzhiyun 
90*4882a593Smuzhiyun typedef struct hnd_ext_trap_bp_err
91*4882a593Smuzhiyun {
92*4882a593Smuzhiyun 	uint32 error;
93*4882a593Smuzhiyun 	uint32 coreid;
94*4882a593Smuzhiyun 	uint32 baseaddr;
95*4882a593Smuzhiyun 	uint32 ioctrl;
96*4882a593Smuzhiyun 	uint32 iostatus;
97*4882a593Smuzhiyun 	uint32 resetctrl;
98*4882a593Smuzhiyun 	uint32 resetstatus;
99*4882a593Smuzhiyun 	uint32 resetreadid;
100*4882a593Smuzhiyun 	uint32 resetwriteid;
101*4882a593Smuzhiyun 	uint32 errlogctrl;
102*4882a593Smuzhiyun 	uint32 errlogdone;
103*4882a593Smuzhiyun 	uint32 errlogstatus;
104*4882a593Smuzhiyun 	uint32 errlogaddrlo;
105*4882a593Smuzhiyun 	uint32 errlogaddrhi;
106*4882a593Smuzhiyun 	uint32 errlogid;
107*4882a593Smuzhiyun 	uint32 errloguser;
108*4882a593Smuzhiyun 	uint32 errlogflags;
109*4882a593Smuzhiyun 	uint32 itipoobaout;
110*4882a593Smuzhiyun 	uint32 itipoobbout;
111*4882a593Smuzhiyun 	uint32 itipoobcout;
112*4882a593Smuzhiyun 	uint32 itipoobdout;
113*4882a593Smuzhiyun } hnd_ext_trap_bp_err_t;
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun #define HND_EXT_TRAP_AXISR_INFO_VER_1	1
116*4882a593Smuzhiyun typedef struct hnd_ext_trap_axi_sr_err_v1
117*4882a593Smuzhiyun {
118*4882a593Smuzhiyun 	uint8 version;
119*4882a593Smuzhiyun 	uint8 pad[3];
120*4882a593Smuzhiyun 	uint32 error;
121*4882a593Smuzhiyun 	uint32 coreid;
122*4882a593Smuzhiyun 	uint32 baseaddr;
123*4882a593Smuzhiyun 	uint32 ioctrl;
124*4882a593Smuzhiyun 	uint32 iostatus;
125*4882a593Smuzhiyun 	uint32 resetctrl;
126*4882a593Smuzhiyun 	uint32 resetstatus;
127*4882a593Smuzhiyun 	uint32 resetreadid;
128*4882a593Smuzhiyun 	uint32 resetwriteid;
129*4882a593Smuzhiyun 	uint32 errlogctrl;
130*4882a593Smuzhiyun 	uint32 errlogdone;
131*4882a593Smuzhiyun 	uint32 errlogstatus;
132*4882a593Smuzhiyun 	uint32 errlogaddrlo;
133*4882a593Smuzhiyun 	uint32 errlogaddrhi;
134*4882a593Smuzhiyun 	uint32 errlogid;
135*4882a593Smuzhiyun 	uint32 errloguser;
136*4882a593Smuzhiyun 	uint32 errlogflags;
137*4882a593Smuzhiyun 	uint32 itipoobaout;
138*4882a593Smuzhiyun 	uint32 itipoobbout;
139*4882a593Smuzhiyun 	uint32 itipoobcout;
140*4882a593Smuzhiyun 	uint32 itipoobdout;
141*4882a593Smuzhiyun 
142*4882a593Smuzhiyun 	/* axi_sr_issue_debug */
143*4882a593Smuzhiyun 	uint32 sr_pwr_control;
144*4882a593Smuzhiyun 	uint32 sr_corereset_wrapper_main;
145*4882a593Smuzhiyun 	uint32 sr_corereset_wrapper_aux;
146*4882a593Smuzhiyun 	uint32 sr_main_gci_status_0;
147*4882a593Smuzhiyun 	uint32 sr_aux_gci_status_0;
148*4882a593Smuzhiyun 	uint32 sr_dig_gci_status_0;
149*4882a593Smuzhiyun } hnd_ext_trap_axi_sr_err_v1_t;
150*4882a593Smuzhiyun 
151*4882a593Smuzhiyun #define HND_EXT_TRAP_PSMWD_INFO_VER	1
152*4882a593Smuzhiyun typedef struct hnd_ext_trap_psmwd_v1 {
153*4882a593Smuzhiyun 	uint16 xtag;
154*4882a593Smuzhiyun 	uint16 version; /* version of the information following this */
155*4882a593Smuzhiyun 	uint32 i32_maccontrol;
156*4882a593Smuzhiyun 	uint32 i32_maccommand;
157*4882a593Smuzhiyun 	uint32 i32_macintstatus;
158*4882a593Smuzhiyun 	uint32 i32_phydebug;
159*4882a593Smuzhiyun 	uint32 i32_clk_ctl_st;
160*4882a593Smuzhiyun 	uint32 i32_psmdebug[PSMDBG_REG_READ_CNT_FOR_PSMWDTRAP_V1];
161*4882a593Smuzhiyun 	uint16 i16_0x1a8; /* gated clock en */
162*4882a593Smuzhiyun 	uint16 i16_0x406; /* Rcv Fifo Ctrl */
163*4882a593Smuzhiyun 	uint16 i16_0x408; /* Rx ctrl 1 */
164*4882a593Smuzhiyun 	uint16 i16_0x41a; /* Rxe Status 1 */
165*4882a593Smuzhiyun 	uint16 i16_0x41c; /* Rxe Status 2 */
166*4882a593Smuzhiyun 	uint16 i16_0x424; /* rcv wrd count 0 */
167*4882a593Smuzhiyun 	uint16 i16_0x426; /* rcv wrd count 1 */
168*4882a593Smuzhiyun 	uint16 i16_0x456; /* RCV_LFIFO_STS */
169*4882a593Smuzhiyun 	uint16 i16_0x480; /* PSM_SLP_TMR */
170*4882a593Smuzhiyun 	uint16 i16_0x490; /* PSM BRC */
171*4882a593Smuzhiyun 	uint16 i16_0x500; /* TXE CTRL */
172*4882a593Smuzhiyun 	uint16 i16_0x50e; /* TXE Status */
173*4882a593Smuzhiyun 	uint16 i16_0x55e; /* TXE_xmtdmabusy */
174*4882a593Smuzhiyun 	uint16 i16_0x566; /* TXE_XMTfifosuspflush */
175*4882a593Smuzhiyun 	uint16 i16_0x690; /* IFS Stat */
176*4882a593Smuzhiyun 	uint16 i16_0x692; /* IFS_MEDBUSY_CTR */
177*4882a593Smuzhiyun 	uint16 i16_0x694; /* IFS_TX_DUR */
178*4882a593Smuzhiyun 	uint16 i16_0x6a0; /* SLow_CTL */
179*4882a593Smuzhiyun 	uint16 i16_0x838; /* TXE_AQM fifo Ready */
180*4882a593Smuzhiyun 	uint16 i16_0x8c0; /* Dagg ctrl */
181*4882a593Smuzhiyun 	uint16 shm_prewds_cnt;
182*4882a593Smuzhiyun 	uint16 shm_txtplufl_cnt;
183*4882a593Smuzhiyun 	uint16 shm_txphyerr_cnt;
184*4882a593Smuzhiyun 	uint16 pad;
185*4882a593Smuzhiyun } hnd_ext_trap_psmwd_v1_t;
186*4882a593Smuzhiyun 
187*4882a593Smuzhiyun typedef struct hnd_ext_trap_psmwd {
188*4882a593Smuzhiyun 	uint16 xtag;
189*4882a593Smuzhiyun 	uint16 version; /* version of the information following this */
190*4882a593Smuzhiyun 	uint32 i32_maccontrol;
191*4882a593Smuzhiyun 	uint32 i32_maccommand;
192*4882a593Smuzhiyun 	uint32 i32_macintstatus;
193*4882a593Smuzhiyun 	uint32 i32_phydebug;
194*4882a593Smuzhiyun 	uint32 i32_clk_ctl_st;
195*4882a593Smuzhiyun 	uint32 i32_psmdebug[PSMDBG_REG_READ_CNT_FOR_PSMWDTRAP_V2];
196*4882a593Smuzhiyun 	uint16 i16_0x4b8; /* psm_brwk_0 */
197*4882a593Smuzhiyun 	uint16 i16_0x4ba; /* psm_brwk_1 */
198*4882a593Smuzhiyun 	uint16 i16_0x4bc; /* psm_brwk_2 */
199*4882a593Smuzhiyun 	uint16 i16_0x4be; /* psm_brwk_2 */
200*4882a593Smuzhiyun 	uint16 i16_0x1a8; /* gated clock en */
201*4882a593Smuzhiyun 	uint16 i16_0x406; /* Rcv Fifo Ctrl */
202*4882a593Smuzhiyun 	uint16 i16_0x408; /* Rx ctrl 1 */
203*4882a593Smuzhiyun 	uint16 i16_0x41a; /* Rxe Status 1 */
204*4882a593Smuzhiyun 	uint16 i16_0x41c; /* Rxe Status 2 */
205*4882a593Smuzhiyun 	uint16 i16_0x424; /* rcv wrd count 0 */
206*4882a593Smuzhiyun 	uint16 i16_0x426; /* rcv wrd count 1 */
207*4882a593Smuzhiyun 	uint16 i16_0x456; /* RCV_LFIFO_STS */
208*4882a593Smuzhiyun 	uint16 i16_0x480; /* PSM_SLP_TMR */
209*4882a593Smuzhiyun 	uint16 i16_0x500; /* TXE CTRL */
210*4882a593Smuzhiyun 	uint16 i16_0x50e; /* TXE Status */
211*4882a593Smuzhiyun 	uint16 i16_0x55e; /* TXE_xmtdmabusy */
212*4882a593Smuzhiyun 	uint16 i16_0x566; /* TXE_XMTfifosuspflush */
213*4882a593Smuzhiyun 	uint16 i16_0x690; /* IFS Stat */
214*4882a593Smuzhiyun 	uint16 i16_0x692; /* IFS_MEDBUSY_CTR */
215*4882a593Smuzhiyun 	uint16 i16_0x694; /* IFS_TX_DUR */
216*4882a593Smuzhiyun 	uint16 i16_0x6a0; /* SLow_CTL */
217*4882a593Smuzhiyun 	uint16 i16_0x490; /* psm_brc */
218*4882a593Smuzhiyun 	uint16 i16_0x4da; /* psm_brc_1 */
219*4882a593Smuzhiyun 	uint16 i16_0x838; /* TXE_AQM fifo Ready */
220*4882a593Smuzhiyun 	uint16 i16_0x8c0; /* Dagg ctrl */
221*4882a593Smuzhiyun 	uint16 shm_prewds_cnt;
222*4882a593Smuzhiyun 	uint16 shm_txtplufl_cnt;
223*4882a593Smuzhiyun 	uint16 shm_txphyerr_cnt;
224*4882a593Smuzhiyun } hnd_ext_trap_psmwd_t;
225*4882a593Smuzhiyun 
226*4882a593Smuzhiyun #define HEAP_HISTOGRAM_DUMP_LEN	6
227*4882a593Smuzhiyun #define HEAP_MAX_SZ_BLKS_LEN	2
228*4882a593Smuzhiyun 
229*4882a593Smuzhiyun /* Ignore chunks for which there are fewer than this many instances, irrespective of size */
230*4882a593Smuzhiyun #define HEAP_HISTOGRAM_INSTANCE_MIN		4
231*4882a593Smuzhiyun 
232*4882a593Smuzhiyun /*
233*4882a593Smuzhiyun  * Use the last two length values for chunks larger than this, or when we run out of
234*4882a593Smuzhiyun  * histogram entries (because we have too many different sized chunks) to store "other"
235*4882a593Smuzhiyun  */
236*4882a593Smuzhiyun #define HEAP_HISTOGRAM_SPECIAL	0xfffeu
237*4882a593Smuzhiyun 
238*4882a593Smuzhiyun #define HEAP_HISTOGRAM_GRTR256K	0xffffu
239*4882a593Smuzhiyun 
240*4882a593Smuzhiyun typedef struct hnd_ext_trap_heap_err {
241*4882a593Smuzhiyun 	uint32 arena_total;
242*4882a593Smuzhiyun 	uint32 heap_free;
243*4882a593Smuzhiyun 	uint32 heap_inuse;
244*4882a593Smuzhiyun 	uint32 mf_count;
245*4882a593Smuzhiyun 	uint32 stack_lwm;
246*4882a593Smuzhiyun 	uint16 heap_histogm[HEAP_HISTOGRAM_DUMP_LEN * 2]; /* size/number */
247*4882a593Smuzhiyun 	uint16 max_sz_free_blk[HEAP_MAX_SZ_BLKS_LEN];
248*4882a593Smuzhiyun } hnd_ext_trap_heap_err_t;
249*4882a593Smuzhiyun 
250*4882a593Smuzhiyun #define MEM_TRAP_NUM_WLC_TX_QUEUES		6
251*4882a593Smuzhiyun #define HND_EXT_TRAP_WLC_MEM_ERR_VER_V2		2
252*4882a593Smuzhiyun 
253*4882a593Smuzhiyun typedef struct hnd_ext_trap_wlc_mem_err {
254*4882a593Smuzhiyun 	uint8 instance;
255*4882a593Smuzhiyun 	uint8 associated;
256*4882a593Smuzhiyun 	uint8 soft_ap_client_cnt;
257*4882a593Smuzhiyun 	uint8 peer_cnt;
258*4882a593Smuzhiyun 	uint16 txqueue_len[MEM_TRAP_NUM_WLC_TX_QUEUES];
259*4882a593Smuzhiyun } hnd_ext_trap_wlc_mem_err_t;
260*4882a593Smuzhiyun 
261*4882a593Smuzhiyun typedef struct hnd_ext_trap_wlc_mem_err_v2 {
262*4882a593Smuzhiyun 	uint16 version;
263*4882a593Smuzhiyun 	uint16 pad;
264*4882a593Smuzhiyun 	uint8 instance;
265*4882a593Smuzhiyun 	uint8 stas_associated;
266*4882a593Smuzhiyun 	uint8 aps_associated;
267*4882a593Smuzhiyun 	uint8 soft_ap_client_cnt;
268*4882a593Smuzhiyun 	uint16 txqueue_len[MEM_TRAP_NUM_WLC_TX_QUEUES];
269*4882a593Smuzhiyun } hnd_ext_trap_wlc_mem_err_v2_t;
270*4882a593Smuzhiyun 
271*4882a593Smuzhiyun #define HND_EXT_TRAP_WLC_MEM_ERR_VER_V3		3
272*4882a593Smuzhiyun 
273*4882a593Smuzhiyun typedef struct hnd_ext_trap_wlc_mem_err_v3 {
274*4882a593Smuzhiyun 	uint8 version;
275*4882a593Smuzhiyun 	uint8 instance;
276*4882a593Smuzhiyun 	uint8 stas_associated;
277*4882a593Smuzhiyun 	uint8 aps_associated;
278*4882a593Smuzhiyun 	uint8 soft_ap_client_cnt;
279*4882a593Smuzhiyun 	uint8 peer_cnt;
280*4882a593Smuzhiyun 	uint16 txqueue_len[MEM_TRAP_NUM_WLC_TX_QUEUES];
281*4882a593Smuzhiyun } hnd_ext_trap_wlc_mem_err_v3_t;
282*4882a593Smuzhiyun 
283*4882a593Smuzhiyun typedef struct hnd_ext_trap_pcie_mem_err {
284*4882a593Smuzhiyun 	uint16 d2h_queue_len;
285*4882a593Smuzhiyun 	uint16 d2h_req_queue_len;
286*4882a593Smuzhiyun } hnd_ext_trap_pcie_mem_err_t;
287*4882a593Smuzhiyun 
288*4882a593Smuzhiyun #define MAX_DMAFIFO_ENTRIES_V1			1
289*4882a593Smuzhiyun #define MAX_DMAFIFO_DESC_ENTRIES_V1		2
290*4882a593Smuzhiyun #define HND_EXT_TRAP_AXIERROR_SIGNATURE		0xbabebabe
291*4882a593Smuzhiyun #define HND_EXT_TRAP_AXIERROR_VERSION_1		1
292*4882a593Smuzhiyun 
293*4882a593Smuzhiyun /* Structure to collect debug info of descriptor entry for dma channel on encountering AXI Error */
294*4882a593Smuzhiyun /* Below three structures are dependant, any change will bump version of all the three */
295*4882a593Smuzhiyun 
296*4882a593Smuzhiyun typedef struct hnd_ext_trap_desc_entry_v1 {
297*4882a593Smuzhiyun 	uint32  ctrl1;   /* descriptor entry at din < misc control bits > */
298*4882a593Smuzhiyun 	uint32  ctrl2;   /* descriptor entry at din <buffer count and address extension> */
299*4882a593Smuzhiyun 	uint32  addrlo;  /* descriptor entry at din <address of data buffer, bits 31:0> */
300*4882a593Smuzhiyun 	uint32  addrhi;  /* descriptor entry at din <address of data buffer, bits 63:32> */
301*4882a593Smuzhiyun } dma_dentry_v1_t;
302*4882a593Smuzhiyun 
303*4882a593Smuzhiyun /* Structure to collect debug info about a dma channel on encountering AXI Error */
304*4882a593Smuzhiyun typedef struct hnd_ext_trap_dma_fifo_v1 {
305*4882a593Smuzhiyun 	uint8	valid;		/* no of valid desc entries filled, non zero = fifo entry valid */
306*4882a593Smuzhiyun 	uint8	direction;	/* TX=1, RX=2, currently only using TX */
307*4882a593Smuzhiyun 	uint16	index;		/* Index of the DMA channel in system */
308*4882a593Smuzhiyun 	uint32	dpa;		/* Expected Address of Descriptor table from software state */
309*4882a593Smuzhiyun 	uint32	desc_lo;	/* Low Address of Descriptor table programmed in DMA register */
310*4882a593Smuzhiyun 	uint32	desc_hi;	/* High Address of Descriptor table programmed in DMA register */
311*4882a593Smuzhiyun 	uint16	din;		/* rxin / txin */
312*4882a593Smuzhiyun 	uint16	dout;		/* rxout / txout */
313*4882a593Smuzhiyun 	dma_dentry_v1_t dentry[MAX_DMAFIFO_DESC_ENTRIES_V1]; /* Descriptor Entires */
314*4882a593Smuzhiyun } dma_fifo_v1_t;
315*4882a593Smuzhiyun 
316*4882a593Smuzhiyun typedef struct hnd_ext_trap_axi_error_v1 {
317*4882a593Smuzhiyun 	uint8 version;			/* version = 1 */
318*4882a593Smuzhiyun 	uint8 dma_fifo_valid_count;	/* Number of valid dma_fifo entries */
319*4882a593Smuzhiyun 	uint16 length;			/* length of whole structure */
320*4882a593Smuzhiyun 	uint32 signature;		/* indicate that its filled with AXI Error data */
321*4882a593Smuzhiyun 	uint32 axi_errorlog_status;	/* errlog_status from slave wrapper */
322*4882a593Smuzhiyun 	uint32 axi_errorlog_core;	/* errlog_core from slave wrapper */
323*4882a593Smuzhiyun 	uint32 axi_errorlog_lo;		/* errlog_lo from slave wrapper */
324*4882a593Smuzhiyun 	uint32 axi_errorlog_hi;		/* errlog_hi from slave wrapper */
325*4882a593Smuzhiyun 	uint32 axi_errorlog_id;		/* errlog_id from slave wrapper */
326*4882a593Smuzhiyun 	dma_fifo_v1_t dma_fifo[MAX_DMAFIFO_ENTRIES_V1];
327*4882a593Smuzhiyun } hnd_ext_trap_axi_error_v1_t;
328*4882a593Smuzhiyun 
329*4882a593Smuzhiyun #define HND_EXT_TRAP_MACSUSP_INFO_VER	1
330*4882a593Smuzhiyun typedef struct hnd_ext_trap_macsusp {
331*4882a593Smuzhiyun 	uint16 xtag;
332*4882a593Smuzhiyun 	uint8 version; /* version of the information following this */
333*4882a593Smuzhiyun 	uint8 trap_reason;
334*4882a593Smuzhiyun 	uint32 i32_maccontrol;
335*4882a593Smuzhiyun 	uint32 i32_maccommand;
336*4882a593Smuzhiyun 	uint32 i32_macintstatus;
337*4882a593Smuzhiyun 	uint32 i32_phydebug[4];
338*4882a593Smuzhiyun 	uint32 i32_psmdebug[8];
339*4882a593Smuzhiyun 	uint16 i16_0x41a; /* Rxe Status 1 */
340*4882a593Smuzhiyun 	uint16 i16_0x41c; /* Rxe Status 2 */
341*4882a593Smuzhiyun 	uint16 i16_0x490; /* PSM BRC */
342*4882a593Smuzhiyun 	uint16 i16_0x50e; /* TXE Status */
343*4882a593Smuzhiyun 	uint16 i16_0x55e; /* TXE_xmtdmabusy */
344*4882a593Smuzhiyun 	uint16 i16_0x566; /* TXE_XMTfifosuspflush */
345*4882a593Smuzhiyun 	uint16 i16_0x690; /* IFS Stat */
346*4882a593Smuzhiyun 	uint16 i16_0x692; /* IFS_MEDBUSY_CTR */
347*4882a593Smuzhiyun 	uint16 i16_0x694; /* IFS_TX_DUR */
348*4882a593Smuzhiyun 	uint16 i16_0x7c0; /* WEP CTL */
349*4882a593Smuzhiyun 	uint16 i16_0x838; /* TXE_AQM fifo Ready */
350*4882a593Smuzhiyun 	uint16 i16_0x880; /* MHP_status */
351*4882a593Smuzhiyun 	uint16 shm_prewds_cnt;
352*4882a593Smuzhiyun 	uint16 shm_ucode_dbgst;
353*4882a593Smuzhiyun } hnd_ext_trap_macsusp_t;
354*4882a593Smuzhiyun 
355*4882a593Smuzhiyun #define HND_EXT_TRAP_MACENAB_INFO_VER	1
356*4882a593Smuzhiyun typedef struct hnd_ext_trap_macenab {
357*4882a593Smuzhiyun 	uint16 xtag;
358*4882a593Smuzhiyun 	uint8 version; /* version of the information following this */
359*4882a593Smuzhiyun 	uint8 trap_reason;
360*4882a593Smuzhiyun 	uint32 i32_maccontrol;
361*4882a593Smuzhiyun 	uint32 i32_maccommand;
362*4882a593Smuzhiyun 	uint32 i32_macintstatus;
363*4882a593Smuzhiyun 	uint32 i32_psmdebug[8];
364*4882a593Smuzhiyun 	uint32 i32_clk_ctl_st;
365*4882a593Smuzhiyun 	uint32 i32_powerctl;
366*4882a593Smuzhiyun 	uint16 i16_0x1a8; /* gated clock en */
367*4882a593Smuzhiyun 	uint16 i16_0x480; /* PSM_SLP_TMR */
368*4882a593Smuzhiyun 	uint16 i16_0x490; /* PSM BRC */
369*4882a593Smuzhiyun 	uint16 i16_0x600; /* TSF CTL */
370*4882a593Smuzhiyun 	uint16 i16_0x690; /* IFS Stat */
371*4882a593Smuzhiyun 	uint16 i16_0x692; /* IFS_MEDBUSY_CTR */
372*4882a593Smuzhiyun 	uint16 i16_0x6a0; /* SLow_CTL */
373*4882a593Smuzhiyun 	uint16 i16_0x6a6; /* SLow_FRAC */
374*4882a593Smuzhiyun 	uint16 i16_0x6a8; /* fast power up delay */
375*4882a593Smuzhiyun 	uint16 i16_0x6aa; /* SLow_PER */
376*4882a593Smuzhiyun 	uint16 shm_ucode_dbgst;
377*4882a593Smuzhiyun 	uint16 PAD;
378*4882a593Smuzhiyun } hnd_ext_trap_macenab_t;
379*4882a593Smuzhiyun 
380*4882a593Smuzhiyun #define HND_EXT_TRAP_PHY_INFO_VER_1 (1)
381*4882a593Smuzhiyun typedef struct hnd_ext_trap_phydbg {
382*4882a593Smuzhiyun 	uint16 err;
383*4882a593Smuzhiyun 	uint16 RxFeStatus;
384*4882a593Smuzhiyun 	uint16 TxFIFOStatus0;
385*4882a593Smuzhiyun 	uint16 TxFIFOStatus1;
386*4882a593Smuzhiyun 	uint16 RfseqMode;
387*4882a593Smuzhiyun 	uint16 RfseqStatus0;
388*4882a593Smuzhiyun 	uint16 RfseqStatus1;
389*4882a593Smuzhiyun 	uint16 RfseqStatus_Ocl;
390*4882a593Smuzhiyun 	uint16 RfseqStatus_Ocl1;
391*4882a593Smuzhiyun 	uint16 OCLControl1;
392*4882a593Smuzhiyun 	uint16 TxError;
393*4882a593Smuzhiyun 	uint16 bphyTxError;
394*4882a593Smuzhiyun 	uint16 TxCCKError;
395*4882a593Smuzhiyun 	uint16 TxCtrlWrd0;
396*4882a593Smuzhiyun 	uint16 TxCtrlWrd1;
397*4882a593Smuzhiyun 	uint16 TxCtrlWrd2;
398*4882a593Smuzhiyun 	uint16 TxLsig0;
399*4882a593Smuzhiyun 	uint16 TxLsig1;
400*4882a593Smuzhiyun 	uint16 TxVhtSigA10;
401*4882a593Smuzhiyun 	uint16 TxVhtSigA11;
402*4882a593Smuzhiyun 	uint16 TxVhtSigA20;
403*4882a593Smuzhiyun 	uint16 TxVhtSigA21;
404*4882a593Smuzhiyun 	uint16 txPktLength;
405*4882a593Smuzhiyun 	uint16 txPsdulengthCtr;
406*4882a593Smuzhiyun 	uint16 gpioClkControl;
407*4882a593Smuzhiyun 	uint16 gpioSel;
408*4882a593Smuzhiyun 	uint16 pktprocdebug;
409*4882a593Smuzhiyun 	uint16 PAD;
410*4882a593Smuzhiyun 	uint32 gpioOut[3];
411*4882a593Smuzhiyun } hnd_ext_trap_phydbg_t;
412*4882a593Smuzhiyun 
413*4882a593Smuzhiyun /* unique IDs for separate cores in SI */
414*4882a593Smuzhiyun #define REGDUMP_MASK_MAC0		BCM_BIT(1)
415*4882a593Smuzhiyun #define REGDUMP_MASK_ARM		BCM_BIT(2)
416*4882a593Smuzhiyun #define REGDUMP_MASK_PCIE		BCM_BIT(3)
417*4882a593Smuzhiyun #define REGDUMP_MASK_MAC1		BCM_BIT(4)
418*4882a593Smuzhiyun #define REGDUMP_MASK_PMU		BCM_BIT(5)
419*4882a593Smuzhiyun 
420*4882a593Smuzhiyun typedef struct {
421*4882a593Smuzhiyun 	uint16 reg_offset;
422*4882a593Smuzhiyun 	uint16 core_mask;
423*4882a593Smuzhiyun } reg_dump_config_t;
424*4882a593Smuzhiyun 
425*4882a593Smuzhiyun #define HND_EXT_TRAP_PHY_INFO_VER              2
426*4882a593Smuzhiyun typedef struct hnd_ext_trap_phydbg_v2 {
427*4882a593Smuzhiyun 	uint8 version;
428*4882a593Smuzhiyun 	uint8 len;
429*4882a593Smuzhiyun 	uint16 err;
430*4882a593Smuzhiyun 	uint16 RxFeStatus;
431*4882a593Smuzhiyun 	uint16 TxFIFOStatus0;
432*4882a593Smuzhiyun 	uint16 TxFIFOStatus1;
433*4882a593Smuzhiyun 	uint16 RfseqMode;
434*4882a593Smuzhiyun 	uint16 RfseqStatus0;
435*4882a593Smuzhiyun 	uint16 RfseqStatus1;
436*4882a593Smuzhiyun 	uint16 RfseqStatus_Ocl;
437*4882a593Smuzhiyun 	uint16 RfseqStatus_Ocl1;
438*4882a593Smuzhiyun 	uint16 OCLControl1;
439*4882a593Smuzhiyun 	uint16 TxError;
440*4882a593Smuzhiyun 	uint16 bphyTxError;
441*4882a593Smuzhiyun 	uint16 TxCCKError;
442*4882a593Smuzhiyun 	uint16 TxCtrlWrd0;
443*4882a593Smuzhiyun 	uint16 TxCtrlWrd1;
444*4882a593Smuzhiyun 	uint16 TxCtrlWrd2;
445*4882a593Smuzhiyun 	uint16 TxLsig0;
446*4882a593Smuzhiyun 	uint16 TxLsig1;
447*4882a593Smuzhiyun 	uint16 TxVhtSigA10;
448*4882a593Smuzhiyun 	uint16 TxVhtSigA11;
449*4882a593Smuzhiyun 	uint16 TxVhtSigA20;
450*4882a593Smuzhiyun 	uint16 TxVhtSigA21;
451*4882a593Smuzhiyun 	uint16 txPktLength;
452*4882a593Smuzhiyun 	uint16 txPsdulengthCtr;
453*4882a593Smuzhiyun 	uint16 gpioClkControl;
454*4882a593Smuzhiyun 	uint16 gpioSel;
455*4882a593Smuzhiyun 	uint16 pktprocdebug;
456*4882a593Smuzhiyun 	uint32 gpioOut[3];
457*4882a593Smuzhiyun 	uint32 additional_regs[1];
458*4882a593Smuzhiyun } hnd_ext_trap_phydbg_v2_t;
459*4882a593Smuzhiyun 
460*4882a593Smuzhiyun #define HND_EXT_TRAP_PHY_INFO_VER_3		(3)
461*4882a593Smuzhiyun typedef struct hnd_ext_trap_phydbg_v3 {
462*4882a593Smuzhiyun 	uint8 version;
463*4882a593Smuzhiyun 	uint8 len;
464*4882a593Smuzhiyun 	uint16 err;
465*4882a593Smuzhiyun 	uint16 RxFeStatus;
466*4882a593Smuzhiyun 	uint16 TxFIFOStatus0;
467*4882a593Smuzhiyun 	uint16 TxFIFOStatus1;
468*4882a593Smuzhiyun 	uint16 RfseqMode;
469*4882a593Smuzhiyun 	uint16 RfseqStatus0;
470*4882a593Smuzhiyun 	uint16 RfseqStatus1;
471*4882a593Smuzhiyun 	uint16 RfseqStatus_Ocl;
472*4882a593Smuzhiyun 	uint16 RfseqStatus_Ocl1;
473*4882a593Smuzhiyun 	uint16 OCLControl1;
474*4882a593Smuzhiyun 	uint16 TxError;
475*4882a593Smuzhiyun 	uint16 bphyTxError;
476*4882a593Smuzhiyun 	uint16 TxCCKError;
477*4882a593Smuzhiyun 	uint16 TxCtrlWrd0;
478*4882a593Smuzhiyun 	uint16 TxCtrlWrd1;
479*4882a593Smuzhiyun 	uint16 TxCtrlWrd2;
480*4882a593Smuzhiyun 	uint16 TxLsig0;
481*4882a593Smuzhiyun 	uint16 TxLsig1;
482*4882a593Smuzhiyun 	uint16 TxVhtSigA10;
483*4882a593Smuzhiyun 	uint16 TxVhtSigA11;
484*4882a593Smuzhiyun 	uint16 TxVhtSigA20;
485*4882a593Smuzhiyun 	uint16 TxVhtSigA21;
486*4882a593Smuzhiyun 	uint16 txPktLength;
487*4882a593Smuzhiyun 	uint16 txPsdulengthCtr;
488*4882a593Smuzhiyun 	uint16 gpioClkControl;
489*4882a593Smuzhiyun 	uint16 gpioSel;
490*4882a593Smuzhiyun 	uint16 pktprocdebug;
491*4882a593Smuzhiyun 	uint32 gpioOut[3];
492*4882a593Smuzhiyun 	uint16 HESigURateFlagStatus;
493*4882a593Smuzhiyun 	uint16 HESigUsRateFlagStatus;
494*4882a593Smuzhiyun 	uint32 additional_regs[1];
495*4882a593Smuzhiyun } hnd_ext_trap_phydbg_v3_t;
496*4882a593Smuzhiyun 
497*4882a593Smuzhiyun /* Phy TxErr Dump Structure */
498*4882a593Smuzhiyun #define HND_EXT_TRAP_PHYTXERR_INFO_VER		1
499*4882a593Smuzhiyun #define HND_EXT_TRAP_PHYTXERR_INFO_VER_V2	2
500*4882a593Smuzhiyun typedef struct hnd_ext_trap_macphytxerr {
501*4882a593Smuzhiyun 	uint8 version; /* version of the information following this */
502*4882a593Smuzhiyun 	uint8 trap_reason;
503*4882a593Smuzhiyun 	uint16 i16_0x63E; /* tsf_tmr_rx_ts */
504*4882a593Smuzhiyun 	uint16 i16_0x640; /* tsf_tmr_tx_ts */
505*4882a593Smuzhiyun 	uint16 i16_0x642; /* tsf_tmr_rx_end_ts  */
506*4882a593Smuzhiyun 	uint16 i16_0x846; /* TDC_FrmLen0 */
507*4882a593Smuzhiyun 	uint16 i16_0x848; /* TDC_FrmLen1 */
508*4882a593Smuzhiyun 	uint16 i16_0x84a; /* TDC_Txtime */
509*4882a593Smuzhiyun 	uint16 i16_0xa5a; /* TXE_BytCntInTxFrmLo  */
510*4882a593Smuzhiyun 	uint16 i16_0xa5c; /* TXE_BytCntInTxFrmHi */
511*4882a593Smuzhiyun 	uint16 i16_0x856; /* TDC_VhtPsduLen0 */
512*4882a593Smuzhiyun 	uint16 i16_0x858; /* TDC_VhtPsduLen1 */
513*4882a593Smuzhiyun 	uint16 i16_0x490; /* psm_brc  */
514*4882a593Smuzhiyun 	uint16 i16_0x4d8; /* psm_brc_1 */
515*4882a593Smuzhiyun 	uint16 shm_txerr_reason;
516*4882a593Smuzhiyun 	uint16 shm_pctl0;
517*4882a593Smuzhiyun 	uint16 shm_pctl1;
518*4882a593Smuzhiyun 	uint16 shm_pctl2;
519*4882a593Smuzhiyun 	uint16 shm_lsig0;
520*4882a593Smuzhiyun 	uint16 shm_lsig1;
521*4882a593Smuzhiyun 	uint16 shm_plcp0;
522*4882a593Smuzhiyun 	uint16 shm_plcp1;
523*4882a593Smuzhiyun 	uint16 shm_plcp2;
524*4882a593Smuzhiyun 	uint16 shm_vht_sigb0;
525*4882a593Smuzhiyun 	uint16 shm_vht_sigb1;
526*4882a593Smuzhiyun 	uint16 shm_tx_tst;
527*4882a593Smuzhiyun 	uint16 shm_txerr_tm;
528*4882a593Smuzhiyun 	uint16 shm_curchannel;
529*4882a593Smuzhiyun 	uint16 shm_crx_rxtsf_pos;
530*4882a593Smuzhiyun 	uint16 shm_lasttx_tsf;
531*4882a593Smuzhiyun 	uint16 shm_s_rxtsftmrval;
532*4882a593Smuzhiyun 	uint16 i16_0x29;	/* Phy indirect address */
533*4882a593Smuzhiyun 	uint16 i16_0x2a;	/* Phy indirect address */
534*4882a593Smuzhiyun } hnd_ext_trap_macphytxerr_t;
535*4882a593Smuzhiyun 
536*4882a593Smuzhiyun typedef struct hnd_ext_trap_macphytxerr_v2 {
537*4882a593Smuzhiyun 	uint8 version; /* version of the information following this */
538*4882a593Smuzhiyun 	uint8 trap_reason;
539*4882a593Smuzhiyun 	uint16 i16_0x63E; /* tsf_tmr_rx_ts */
540*4882a593Smuzhiyun 	uint16 i16_0x640; /* tsf_tmr_tx_ts */
541*4882a593Smuzhiyun 	uint16 i16_0x642; /* tsf_tmr_rx_end_ts  */
542*4882a593Smuzhiyun 	uint16 i16_0x846; /* TDC_FrmLen0 */
543*4882a593Smuzhiyun 	uint16 i16_0x848; /* TDC_FrmLen1 */
544*4882a593Smuzhiyun 	uint16 i16_0x84a; /* TDC_Txtime */
545*4882a593Smuzhiyun 	uint16 i16_0xa5a; /* TXE_BytCntInTxFrmLo  */
546*4882a593Smuzhiyun 	uint16 i16_0xa5c; /* TXE_BytCntInTxFrmHi */
547*4882a593Smuzhiyun 	uint16 i16_0x856; /* TDC_VhtPsduLen0 */
548*4882a593Smuzhiyun 	uint16 i16_0x858; /* TDC_VhtPsduLen1 */
549*4882a593Smuzhiyun 	uint16 i16_0x490; /* psm_brc  */
550*4882a593Smuzhiyun 	uint16 i16_0x4d8; /* psm_brc_1 */
551*4882a593Smuzhiyun 	uint16 shm_txerr_reason;
552*4882a593Smuzhiyun 	uint16 shm_pctl0;
553*4882a593Smuzhiyun 	uint16 shm_pctl1;
554*4882a593Smuzhiyun 	uint16 shm_pctl2;
555*4882a593Smuzhiyun 	uint16 shm_lsig0;
556*4882a593Smuzhiyun 	uint16 shm_lsig1;
557*4882a593Smuzhiyun 	uint16 shm_plcp0;
558*4882a593Smuzhiyun 	uint16 shm_plcp1;
559*4882a593Smuzhiyun 	uint16 shm_plcp2;
560*4882a593Smuzhiyun 	uint16 shm_vht_sigb0;
561*4882a593Smuzhiyun 	uint16 shm_vht_sigb1;
562*4882a593Smuzhiyun 	uint16 shm_tx_tst;
563*4882a593Smuzhiyun 	uint16 shm_txerr_tm;
564*4882a593Smuzhiyun 	uint16 shm_curchannel;
565*4882a593Smuzhiyun 	uint16 shm_crx_rxtsf_pos;
566*4882a593Smuzhiyun 	uint16 shm_lasttx_tsf;
567*4882a593Smuzhiyun 	uint16 shm_s_rxtsftmrval;
568*4882a593Smuzhiyun 	uint16 i16_0x29;        /* Phy indirect address */
569*4882a593Smuzhiyun 	uint16 i16_0x2a;        /* Phy indirect address */
570*4882a593Smuzhiyun 	uint8 phyerr_bmac_cnt; /* number of times bmac raised phy tx err */
571*4882a593Smuzhiyun 	uint8 phyerr_bmac_rsn; /* bmac reason for phy tx error */
572*4882a593Smuzhiyun 	uint16 pad;
573*4882a593Smuzhiyun 	uint32 recv_fifo_status[3][2]; /* Rcv Status0 & Rcv Status1 for 3 Rx fifos */
574*4882a593Smuzhiyun } hnd_ext_trap_macphytxerr_v2_t;
575*4882a593Smuzhiyun 
576*4882a593Smuzhiyun #define HND_EXT_TRAP_PCIE_ERR_ATTN_VER_1	(1u)
577*4882a593Smuzhiyun #define MAX_AER_HDR_LOG_REGS			(4u)
578*4882a593Smuzhiyun typedef struct hnd_ext_trap_pcie_err_attn_v1 {
579*4882a593Smuzhiyun 	uint8 version;
580*4882a593Smuzhiyun 	uint8 pad[3];
581*4882a593Smuzhiyun 	uint32 err_hdr_logreg1;
582*4882a593Smuzhiyun 	uint32 err_hdr_logreg2;
583*4882a593Smuzhiyun 	uint32 err_hdr_logreg3;
584*4882a593Smuzhiyun 	uint32 err_hdr_logreg4;
585*4882a593Smuzhiyun 	uint32 err_code_logreg;
586*4882a593Smuzhiyun 	uint32 err_type;
587*4882a593Smuzhiyun 	uint32 err_code_state;
588*4882a593Smuzhiyun 	uint32 last_err_attn_ts;
589*4882a593Smuzhiyun 	uint32 cfg_tlp_hdr[MAX_AER_HDR_LOG_REGS];
590*4882a593Smuzhiyun } hnd_ext_trap_pcie_err_attn_v1_t;
591*4882a593Smuzhiyun 
592*4882a593Smuzhiyun #define MAX_EVENTLOG_BUFFERS	48
593*4882a593Smuzhiyun typedef struct eventlog_trapdata_info {
594*4882a593Smuzhiyun 	uint32 num_elements;
595*4882a593Smuzhiyun 	uint32 seq_num;
596*4882a593Smuzhiyun 	uint32 log_arr_addr;
597*4882a593Smuzhiyun } eventlog_trapdata_info_t;
598*4882a593Smuzhiyun 
599*4882a593Smuzhiyun typedef struct eventlog_trap_buf_info {
600*4882a593Smuzhiyun 	uint32 len;
601*4882a593Smuzhiyun 	uint32 buf_addr;
602*4882a593Smuzhiyun } eventlog_trap_buf_info_t;
603*4882a593Smuzhiyun 
604*4882a593Smuzhiyun #if defined(ETD) && !defined(WLETD)
605*4882a593Smuzhiyun #define ETD_SW_FLAG_MEM		0x00000001
606*4882a593Smuzhiyun 
607*4882a593Smuzhiyun int etd_init(osl_t *osh);
608*4882a593Smuzhiyun int etd_register_trap_ext_callback(void *cb, void *arg);
609*4882a593Smuzhiyun int (etd_register_trap_ext_callback_late)(void *cb, void *arg);
610*4882a593Smuzhiyun uint32 *etd_get_trap_ext_data(void);
611*4882a593Smuzhiyun uint32 etd_get_trap_ext_swflags(void);
612*4882a593Smuzhiyun void etd_set_trap_ext_swflag(uint32 flag);
613*4882a593Smuzhiyun void etd_notify_trap_ext_callback(trap_t *tr);
614*4882a593Smuzhiyun reg_dump_config_t *etd_get_reg_dump_config_tbl(void);
615*4882a593Smuzhiyun uint etd_get_reg_dump_config_len(void);
616*4882a593Smuzhiyun 
617*4882a593Smuzhiyun extern bool _etd_enab;
618*4882a593Smuzhiyun 
619*4882a593Smuzhiyun 	#define ETD_ENAB(pub)		(_etd_enab)
620*4882a593Smuzhiyun 
621*4882a593Smuzhiyun #else
622*4882a593Smuzhiyun #define ETD_ENAB(pub)		(0)
623*4882a593Smuzhiyun #endif /* WLETD */
624*4882a593Smuzhiyun 
625*4882a593Smuzhiyun #endif /* !LANGUAGE_ASSEMBLY */
626*4882a593Smuzhiyun 
627*4882a593Smuzhiyun #endif /* _ETD_H_ */
628