xref: /OK3568_Linux_fs/kernel/drivers/scsi/qla2xxx/qla_dbg.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * QLogic Fibre Channel HBA Driver
4*4882a593Smuzhiyun  * Copyright (c)  2003-2014 QLogic Corporation
5*4882a593Smuzhiyun  */
6*4882a593Smuzhiyun 
7*4882a593Smuzhiyun #include "qla_def.h"
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun /*
10*4882a593Smuzhiyun  * Firmware Dump structure definition
11*4882a593Smuzhiyun  */
12*4882a593Smuzhiyun 
13*4882a593Smuzhiyun struct qla2300_fw_dump {
14*4882a593Smuzhiyun 	__be16 hccr;
15*4882a593Smuzhiyun 	__be16 pbiu_reg[8];
16*4882a593Smuzhiyun 	__be16 risc_host_reg[8];
17*4882a593Smuzhiyun 	__be16 mailbox_reg[32];
18*4882a593Smuzhiyun 	__be16 resp_dma_reg[32];
19*4882a593Smuzhiyun 	__be16 dma_reg[48];
20*4882a593Smuzhiyun 	__be16 risc_hdw_reg[16];
21*4882a593Smuzhiyun 	__be16 risc_gp0_reg[16];
22*4882a593Smuzhiyun 	__be16 risc_gp1_reg[16];
23*4882a593Smuzhiyun 	__be16 risc_gp2_reg[16];
24*4882a593Smuzhiyun 	__be16 risc_gp3_reg[16];
25*4882a593Smuzhiyun 	__be16 risc_gp4_reg[16];
26*4882a593Smuzhiyun 	__be16 risc_gp5_reg[16];
27*4882a593Smuzhiyun 	__be16 risc_gp6_reg[16];
28*4882a593Smuzhiyun 	__be16 risc_gp7_reg[16];
29*4882a593Smuzhiyun 	__be16 frame_buf_hdw_reg[64];
30*4882a593Smuzhiyun 	__be16 fpm_b0_reg[64];
31*4882a593Smuzhiyun 	__be16 fpm_b1_reg[64];
32*4882a593Smuzhiyun 	__be16 risc_ram[0xf800];
33*4882a593Smuzhiyun 	__be16 stack_ram[0x1000];
34*4882a593Smuzhiyun 	__be16 data_ram[1];
35*4882a593Smuzhiyun };
36*4882a593Smuzhiyun 
37*4882a593Smuzhiyun struct qla2100_fw_dump {
38*4882a593Smuzhiyun 	__be16 hccr;
39*4882a593Smuzhiyun 	__be16 pbiu_reg[8];
40*4882a593Smuzhiyun 	__be16 mailbox_reg[32];
41*4882a593Smuzhiyun 	__be16 dma_reg[48];
42*4882a593Smuzhiyun 	__be16 risc_hdw_reg[16];
43*4882a593Smuzhiyun 	__be16 risc_gp0_reg[16];
44*4882a593Smuzhiyun 	__be16 risc_gp1_reg[16];
45*4882a593Smuzhiyun 	__be16 risc_gp2_reg[16];
46*4882a593Smuzhiyun 	__be16 risc_gp3_reg[16];
47*4882a593Smuzhiyun 	__be16 risc_gp4_reg[16];
48*4882a593Smuzhiyun 	__be16 risc_gp5_reg[16];
49*4882a593Smuzhiyun 	__be16 risc_gp6_reg[16];
50*4882a593Smuzhiyun 	__be16 risc_gp7_reg[16];
51*4882a593Smuzhiyun 	__be16 frame_buf_hdw_reg[16];
52*4882a593Smuzhiyun 	__be16 fpm_b0_reg[64];
53*4882a593Smuzhiyun 	__be16 fpm_b1_reg[64];
54*4882a593Smuzhiyun 	__be16 risc_ram[0xf000];
55*4882a593Smuzhiyun 	u8	queue_dump[];
56*4882a593Smuzhiyun };
57*4882a593Smuzhiyun 
58*4882a593Smuzhiyun struct qla24xx_fw_dump {
59*4882a593Smuzhiyun 	__be32	host_status;
60*4882a593Smuzhiyun 	__be32	host_reg[32];
61*4882a593Smuzhiyun 	__be32	shadow_reg[7];
62*4882a593Smuzhiyun 	__be16	mailbox_reg[32];
63*4882a593Smuzhiyun 	__be32	xseq_gp_reg[128];
64*4882a593Smuzhiyun 	__be32	xseq_0_reg[16];
65*4882a593Smuzhiyun 	__be32	xseq_1_reg[16];
66*4882a593Smuzhiyun 	__be32	rseq_gp_reg[128];
67*4882a593Smuzhiyun 	__be32	rseq_0_reg[16];
68*4882a593Smuzhiyun 	__be32	rseq_1_reg[16];
69*4882a593Smuzhiyun 	__be32	rseq_2_reg[16];
70*4882a593Smuzhiyun 	__be32	cmd_dma_reg[16];
71*4882a593Smuzhiyun 	__be32	req0_dma_reg[15];
72*4882a593Smuzhiyun 	__be32	resp0_dma_reg[15];
73*4882a593Smuzhiyun 	__be32	req1_dma_reg[15];
74*4882a593Smuzhiyun 	__be32	xmt0_dma_reg[32];
75*4882a593Smuzhiyun 	__be32	xmt1_dma_reg[32];
76*4882a593Smuzhiyun 	__be32	xmt2_dma_reg[32];
77*4882a593Smuzhiyun 	__be32	xmt3_dma_reg[32];
78*4882a593Smuzhiyun 	__be32	xmt4_dma_reg[32];
79*4882a593Smuzhiyun 	__be32	xmt_data_dma_reg[16];
80*4882a593Smuzhiyun 	__be32	rcvt0_data_dma_reg[32];
81*4882a593Smuzhiyun 	__be32	rcvt1_data_dma_reg[32];
82*4882a593Smuzhiyun 	__be32	risc_gp_reg[128];
83*4882a593Smuzhiyun 	__be32	lmc_reg[112];
84*4882a593Smuzhiyun 	__be32	fpm_hdw_reg[192];
85*4882a593Smuzhiyun 	__be32	fb_hdw_reg[176];
86*4882a593Smuzhiyun 	__be32	code_ram[0x2000];
87*4882a593Smuzhiyun 	__be32	ext_mem[1];
88*4882a593Smuzhiyun };
89*4882a593Smuzhiyun 
90*4882a593Smuzhiyun struct qla25xx_fw_dump {
91*4882a593Smuzhiyun 	__be32	host_status;
92*4882a593Smuzhiyun 	__be32	host_risc_reg[32];
93*4882a593Smuzhiyun 	__be32	pcie_regs[4];
94*4882a593Smuzhiyun 	__be32	host_reg[32];
95*4882a593Smuzhiyun 	__be32	shadow_reg[11];
96*4882a593Smuzhiyun 	__be32	risc_io_reg;
97*4882a593Smuzhiyun 	__be16	mailbox_reg[32];
98*4882a593Smuzhiyun 	__be32	xseq_gp_reg[128];
99*4882a593Smuzhiyun 	__be32	xseq_0_reg[48];
100*4882a593Smuzhiyun 	__be32	xseq_1_reg[16];
101*4882a593Smuzhiyun 	__be32	rseq_gp_reg[128];
102*4882a593Smuzhiyun 	__be32	rseq_0_reg[32];
103*4882a593Smuzhiyun 	__be32	rseq_1_reg[16];
104*4882a593Smuzhiyun 	__be32	rseq_2_reg[16];
105*4882a593Smuzhiyun 	__be32	aseq_gp_reg[128];
106*4882a593Smuzhiyun 	__be32	aseq_0_reg[32];
107*4882a593Smuzhiyun 	__be32	aseq_1_reg[16];
108*4882a593Smuzhiyun 	__be32	aseq_2_reg[16];
109*4882a593Smuzhiyun 	__be32	cmd_dma_reg[16];
110*4882a593Smuzhiyun 	__be32	req0_dma_reg[15];
111*4882a593Smuzhiyun 	__be32	resp0_dma_reg[15];
112*4882a593Smuzhiyun 	__be32	req1_dma_reg[15];
113*4882a593Smuzhiyun 	__be32	xmt0_dma_reg[32];
114*4882a593Smuzhiyun 	__be32	xmt1_dma_reg[32];
115*4882a593Smuzhiyun 	__be32	xmt2_dma_reg[32];
116*4882a593Smuzhiyun 	__be32	xmt3_dma_reg[32];
117*4882a593Smuzhiyun 	__be32	xmt4_dma_reg[32];
118*4882a593Smuzhiyun 	__be32	xmt_data_dma_reg[16];
119*4882a593Smuzhiyun 	__be32	rcvt0_data_dma_reg[32];
120*4882a593Smuzhiyun 	__be32	rcvt1_data_dma_reg[32];
121*4882a593Smuzhiyun 	__be32	risc_gp_reg[128];
122*4882a593Smuzhiyun 	__be32	lmc_reg[128];
123*4882a593Smuzhiyun 	__be32	fpm_hdw_reg[192];
124*4882a593Smuzhiyun 	__be32	fb_hdw_reg[192];
125*4882a593Smuzhiyun 	__be32	code_ram[0x2000];
126*4882a593Smuzhiyun 	__be32	ext_mem[1];
127*4882a593Smuzhiyun };
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun struct qla81xx_fw_dump {
130*4882a593Smuzhiyun 	__be32	host_status;
131*4882a593Smuzhiyun 	__be32	host_risc_reg[32];
132*4882a593Smuzhiyun 	__be32	pcie_regs[4];
133*4882a593Smuzhiyun 	__be32	host_reg[32];
134*4882a593Smuzhiyun 	__be32	shadow_reg[11];
135*4882a593Smuzhiyun 	__be32	risc_io_reg;
136*4882a593Smuzhiyun 	__be16	mailbox_reg[32];
137*4882a593Smuzhiyun 	__be32	xseq_gp_reg[128];
138*4882a593Smuzhiyun 	__be32	xseq_0_reg[48];
139*4882a593Smuzhiyun 	__be32	xseq_1_reg[16];
140*4882a593Smuzhiyun 	__be32	rseq_gp_reg[128];
141*4882a593Smuzhiyun 	__be32	rseq_0_reg[32];
142*4882a593Smuzhiyun 	__be32	rseq_1_reg[16];
143*4882a593Smuzhiyun 	__be32	rseq_2_reg[16];
144*4882a593Smuzhiyun 	__be32	aseq_gp_reg[128];
145*4882a593Smuzhiyun 	__be32	aseq_0_reg[32];
146*4882a593Smuzhiyun 	__be32	aseq_1_reg[16];
147*4882a593Smuzhiyun 	__be32	aseq_2_reg[16];
148*4882a593Smuzhiyun 	__be32	cmd_dma_reg[16];
149*4882a593Smuzhiyun 	__be32	req0_dma_reg[15];
150*4882a593Smuzhiyun 	__be32	resp0_dma_reg[15];
151*4882a593Smuzhiyun 	__be32	req1_dma_reg[15];
152*4882a593Smuzhiyun 	__be32	xmt0_dma_reg[32];
153*4882a593Smuzhiyun 	__be32	xmt1_dma_reg[32];
154*4882a593Smuzhiyun 	__be32	xmt2_dma_reg[32];
155*4882a593Smuzhiyun 	__be32	xmt3_dma_reg[32];
156*4882a593Smuzhiyun 	__be32	xmt4_dma_reg[32];
157*4882a593Smuzhiyun 	__be32	xmt_data_dma_reg[16];
158*4882a593Smuzhiyun 	__be32	rcvt0_data_dma_reg[32];
159*4882a593Smuzhiyun 	__be32	rcvt1_data_dma_reg[32];
160*4882a593Smuzhiyun 	__be32	risc_gp_reg[128];
161*4882a593Smuzhiyun 	__be32	lmc_reg[128];
162*4882a593Smuzhiyun 	__be32	fpm_hdw_reg[224];
163*4882a593Smuzhiyun 	__be32	fb_hdw_reg[208];
164*4882a593Smuzhiyun 	__be32	code_ram[0x2000];
165*4882a593Smuzhiyun 	__be32	ext_mem[1];
166*4882a593Smuzhiyun };
167*4882a593Smuzhiyun 
168*4882a593Smuzhiyun struct qla83xx_fw_dump {
169*4882a593Smuzhiyun 	__be32	host_status;
170*4882a593Smuzhiyun 	__be32	host_risc_reg[48];
171*4882a593Smuzhiyun 	__be32	pcie_regs[4];
172*4882a593Smuzhiyun 	__be32	host_reg[32];
173*4882a593Smuzhiyun 	__be32	shadow_reg[11];
174*4882a593Smuzhiyun 	__be32	risc_io_reg;
175*4882a593Smuzhiyun 	__be16	mailbox_reg[32];
176*4882a593Smuzhiyun 	__be32	xseq_gp_reg[256];
177*4882a593Smuzhiyun 	__be32	xseq_0_reg[48];
178*4882a593Smuzhiyun 	__be32	xseq_1_reg[16];
179*4882a593Smuzhiyun 	__be32	xseq_2_reg[16];
180*4882a593Smuzhiyun 	__be32	rseq_gp_reg[256];
181*4882a593Smuzhiyun 	__be32	rseq_0_reg[32];
182*4882a593Smuzhiyun 	__be32	rseq_1_reg[16];
183*4882a593Smuzhiyun 	__be32	rseq_2_reg[16];
184*4882a593Smuzhiyun 	__be32	rseq_3_reg[16];
185*4882a593Smuzhiyun 	__be32	aseq_gp_reg[256];
186*4882a593Smuzhiyun 	__be32	aseq_0_reg[32];
187*4882a593Smuzhiyun 	__be32	aseq_1_reg[16];
188*4882a593Smuzhiyun 	__be32	aseq_2_reg[16];
189*4882a593Smuzhiyun 	__be32	aseq_3_reg[16];
190*4882a593Smuzhiyun 	__be32	cmd_dma_reg[64];
191*4882a593Smuzhiyun 	__be32	req0_dma_reg[15];
192*4882a593Smuzhiyun 	__be32	resp0_dma_reg[15];
193*4882a593Smuzhiyun 	__be32	req1_dma_reg[15];
194*4882a593Smuzhiyun 	__be32	xmt0_dma_reg[32];
195*4882a593Smuzhiyun 	__be32	xmt1_dma_reg[32];
196*4882a593Smuzhiyun 	__be32	xmt2_dma_reg[32];
197*4882a593Smuzhiyun 	__be32	xmt3_dma_reg[32];
198*4882a593Smuzhiyun 	__be32	xmt4_dma_reg[32];
199*4882a593Smuzhiyun 	__be32	xmt_data_dma_reg[16];
200*4882a593Smuzhiyun 	__be32	rcvt0_data_dma_reg[32];
201*4882a593Smuzhiyun 	__be32	rcvt1_data_dma_reg[32];
202*4882a593Smuzhiyun 	__be32	risc_gp_reg[128];
203*4882a593Smuzhiyun 	__be32	lmc_reg[128];
204*4882a593Smuzhiyun 	__be32	fpm_hdw_reg[256];
205*4882a593Smuzhiyun 	__be32	rq0_array_reg[256];
206*4882a593Smuzhiyun 	__be32	rq1_array_reg[256];
207*4882a593Smuzhiyun 	__be32	rp0_array_reg[256];
208*4882a593Smuzhiyun 	__be32	rp1_array_reg[256];
209*4882a593Smuzhiyun 	__be32	queue_control_reg[16];
210*4882a593Smuzhiyun 	__be32	fb_hdw_reg[432];
211*4882a593Smuzhiyun 	__be32	at0_array_reg[128];
212*4882a593Smuzhiyun 	__be32	code_ram[0x2400];
213*4882a593Smuzhiyun 	__be32	ext_mem[1];
214*4882a593Smuzhiyun };
215*4882a593Smuzhiyun 
216*4882a593Smuzhiyun #define EFT_NUM_BUFFERS		4
217*4882a593Smuzhiyun #define EFT_BYTES_PER_BUFFER	0x4000
218*4882a593Smuzhiyun #define EFT_SIZE		((EFT_BYTES_PER_BUFFER) * (EFT_NUM_BUFFERS))
219*4882a593Smuzhiyun 
220*4882a593Smuzhiyun #define FCE_NUM_BUFFERS		64
221*4882a593Smuzhiyun #define FCE_BYTES_PER_BUFFER	0x400
222*4882a593Smuzhiyun #define FCE_SIZE		((FCE_BYTES_PER_BUFFER) * (FCE_NUM_BUFFERS))
223*4882a593Smuzhiyun #define fce_calc_size(b)	((FCE_BYTES_PER_BUFFER) * (b))
224*4882a593Smuzhiyun 
225*4882a593Smuzhiyun struct qla2xxx_fce_chain {
226*4882a593Smuzhiyun 	__be32	type;
227*4882a593Smuzhiyun 	__be32	chain_size;
228*4882a593Smuzhiyun 
229*4882a593Smuzhiyun 	__be32	size;
230*4882a593Smuzhiyun 	__be32	addr_l;
231*4882a593Smuzhiyun 	__be32	addr_h;
232*4882a593Smuzhiyun 	__be32	eregs[8];
233*4882a593Smuzhiyun };
234*4882a593Smuzhiyun 
235*4882a593Smuzhiyun /* used by exchange off load and extended login offload */
236*4882a593Smuzhiyun struct qla2xxx_offld_chain {
237*4882a593Smuzhiyun 	__be32	type;
238*4882a593Smuzhiyun 	__be32	chain_size;
239*4882a593Smuzhiyun 
240*4882a593Smuzhiyun 	__be32	size;
241*4882a593Smuzhiyun 	__be32	reserved;
242*4882a593Smuzhiyun 	__be64	addr;
243*4882a593Smuzhiyun };
244*4882a593Smuzhiyun 
245*4882a593Smuzhiyun struct qla2xxx_mq_chain {
246*4882a593Smuzhiyun 	__be32	type;
247*4882a593Smuzhiyun 	__be32	chain_size;
248*4882a593Smuzhiyun 
249*4882a593Smuzhiyun 	__be32	count;
250*4882a593Smuzhiyun 	__be32	qregs[4 * QLA_MQ_SIZE];
251*4882a593Smuzhiyun };
252*4882a593Smuzhiyun 
253*4882a593Smuzhiyun struct qla2xxx_mqueue_header {
254*4882a593Smuzhiyun 	__be32	queue;
255*4882a593Smuzhiyun #define TYPE_REQUEST_QUEUE	0x1
256*4882a593Smuzhiyun #define TYPE_RESPONSE_QUEUE	0x2
257*4882a593Smuzhiyun #define TYPE_ATIO_QUEUE		0x3
258*4882a593Smuzhiyun 	__be32	number;
259*4882a593Smuzhiyun 	__be32	size;
260*4882a593Smuzhiyun };
261*4882a593Smuzhiyun 
262*4882a593Smuzhiyun struct qla2xxx_mqueue_chain {
263*4882a593Smuzhiyun 	__be32	type;
264*4882a593Smuzhiyun 	__be32	chain_size;
265*4882a593Smuzhiyun };
266*4882a593Smuzhiyun 
267*4882a593Smuzhiyun #define DUMP_CHAIN_VARIANT	0x80000000
268*4882a593Smuzhiyun #define DUMP_CHAIN_FCE		0x7FFFFAF0
269*4882a593Smuzhiyun #define DUMP_CHAIN_MQ		0x7FFFFAF1
270*4882a593Smuzhiyun #define DUMP_CHAIN_QUEUE	0x7FFFFAF2
271*4882a593Smuzhiyun #define DUMP_CHAIN_EXLOGIN	0x7FFFFAF3
272*4882a593Smuzhiyun #define DUMP_CHAIN_EXCHG	0x7FFFFAF4
273*4882a593Smuzhiyun #define DUMP_CHAIN_LAST		0x80000000
274*4882a593Smuzhiyun 
275*4882a593Smuzhiyun struct qla2xxx_fw_dump {
276*4882a593Smuzhiyun 	uint8_t signature[4];
277*4882a593Smuzhiyun 	__be32	version;
278*4882a593Smuzhiyun 
279*4882a593Smuzhiyun 	__be32 fw_major_version;
280*4882a593Smuzhiyun 	__be32 fw_minor_version;
281*4882a593Smuzhiyun 	__be32 fw_subminor_version;
282*4882a593Smuzhiyun 	__be32 fw_attributes;
283*4882a593Smuzhiyun 
284*4882a593Smuzhiyun 	__be32 vendor;
285*4882a593Smuzhiyun 	__be32 device;
286*4882a593Smuzhiyun 	__be32 subsystem_vendor;
287*4882a593Smuzhiyun 	__be32 subsystem_device;
288*4882a593Smuzhiyun 
289*4882a593Smuzhiyun 	__be32	fixed_size;
290*4882a593Smuzhiyun 	__be32	mem_size;
291*4882a593Smuzhiyun 	__be32	req_q_size;
292*4882a593Smuzhiyun 	__be32	rsp_q_size;
293*4882a593Smuzhiyun 
294*4882a593Smuzhiyun 	__be32	eft_size;
295*4882a593Smuzhiyun 	__be32	eft_addr_l;
296*4882a593Smuzhiyun 	__be32	eft_addr_h;
297*4882a593Smuzhiyun 
298*4882a593Smuzhiyun 	__be32	header_size;
299*4882a593Smuzhiyun 
300*4882a593Smuzhiyun 	union {
301*4882a593Smuzhiyun 		struct qla2100_fw_dump isp21;
302*4882a593Smuzhiyun 		struct qla2300_fw_dump isp23;
303*4882a593Smuzhiyun 		struct qla24xx_fw_dump isp24;
304*4882a593Smuzhiyun 		struct qla25xx_fw_dump isp25;
305*4882a593Smuzhiyun 		struct qla81xx_fw_dump isp81;
306*4882a593Smuzhiyun 		struct qla83xx_fw_dump isp83;
307*4882a593Smuzhiyun 	} isp;
308*4882a593Smuzhiyun };
309*4882a593Smuzhiyun 
310*4882a593Smuzhiyun #define QL_MSGHDR "qla2xxx"
311*4882a593Smuzhiyun #define QL_DBG_DEFAULT1_MASK    0x1e400000
312*4882a593Smuzhiyun 
313*4882a593Smuzhiyun #define ql_log_fatal		0 /* display fatal errors */
314*4882a593Smuzhiyun #define ql_log_warn		1 /* display critical errors */
315*4882a593Smuzhiyun #define ql_log_info		2 /* display all recovered errors */
316*4882a593Smuzhiyun #define ql_log_all		3 /* This value is only used by ql_errlev.
317*4882a593Smuzhiyun 				   * No messages will use this value.
318*4882a593Smuzhiyun 				   * This should be always highest value
319*4882a593Smuzhiyun 				   * as compared to other log levels.
320*4882a593Smuzhiyun 				   */
321*4882a593Smuzhiyun 
322*4882a593Smuzhiyun extern uint ql_errlev;
323*4882a593Smuzhiyun 
324*4882a593Smuzhiyun void __attribute__((format (printf, 4, 5)))
325*4882a593Smuzhiyun ql_dbg(uint, scsi_qla_host_t *vha, uint, const char *fmt, ...);
326*4882a593Smuzhiyun void __attribute__((format (printf, 4, 5)))
327*4882a593Smuzhiyun ql_dbg_pci(uint, struct pci_dev *pdev, uint, const char *fmt, ...);
328*4882a593Smuzhiyun void __attribute__((format (printf, 4, 5)))
329*4882a593Smuzhiyun ql_dbg_qp(uint32_t, struct qla_qpair *, int32_t, const char *fmt, ...);
330*4882a593Smuzhiyun 
331*4882a593Smuzhiyun 
332*4882a593Smuzhiyun void __attribute__((format (printf, 4, 5)))
333*4882a593Smuzhiyun ql_log(uint, scsi_qla_host_t *vha, uint, const char *fmt, ...);
334*4882a593Smuzhiyun void __attribute__((format (printf, 4, 5)))
335*4882a593Smuzhiyun ql_log_pci(uint, struct pci_dev *pdev, uint, const char *fmt, ...);
336*4882a593Smuzhiyun 
337*4882a593Smuzhiyun void __attribute__((format (printf, 4, 5)))
338*4882a593Smuzhiyun ql_log_qp(uint32_t, struct qla_qpair *, int32_t, const char *fmt, ...);
339*4882a593Smuzhiyun 
340*4882a593Smuzhiyun /* Debug Levels */
341*4882a593Smuzhiyun /* The 0x40000000 is the max value any debug level can have
342*4882a593Smuzhiyun  * as ql2xextended_error_logging is of type signed int
343*4882a593Smuzhiyun  */
344*4882a593Smuzhiyun #define ql_dbg_init	0x40000000 /* Init Debug */
345*4882a593Smuzhiyun #define ql_dbg_mbx	0x20000000 /* MBX Debug */
346*4882a593Smuzhiyun #define ql_dbg_disc	0x10000000 /* Device Discovery Debug */
347*4882a593Smuzhiyun #define ql_dbg_io	0x08000000 /* IO Tracing Debug */
348*4882a593Smuzhiyun #define ql_dbg_dpc	0x04000000 /* DPC Thead Debug */
349*4882a593Smuzhiyun #define ql_dbg_async	0x02000000 /* Async events Debug */
350*4882a593Smuzhiyun #define ql_dbg_timer	0x01000000 /* Timer Debug */
351*4882a593Smuzhiyun #define ql_dbg_user	0x00800000 /* User Space Interations Debug */
352*4882a593Smuzhiyun #define ql_dbg_taskm	0x00400000 /* Task Management Debug */
353*4882a593Smuzhiyun #define ql_dbg_aer	0x00200000 /* AER/EEH Debug */
354*4882a593Smuzhiyun #define ql_dbg_multiq	0x00100000 /* MultiQ Debug */
355*4882a593Smuzhiyun #define ql_dbg_p3p	0x00080000 /* P3P specific Debug */
356*4882a593Smuzhiyun #define ql_dbg_vport	0x00040000 /* Virtual Port Debug */
357*4882a593Smuzhiyun #define ql_dbg_buffer	0x00020000 /* For dumping the buffer/regs */
358*4882a593Smuzhiyun #define ql_dbg_misc	0x00010000 /* For dumping everything that is not
359*4882a593Smuzhiyun 				    * not covered by upper categories
360*4882a593Smuzhiyun 				    */
361*4882a593Smuzhiyun #define ql_dbg_verbose	0x00008000 /* More verbosity for each level
362*4882a593Smuzhiyun 				    * This is to be used with other levels where
363*4882a593Smuzhiyun 				    * more verbosity is required. It might not
364*4882a593Smuzhiyun 				    * be applicable to all the levels.
365*4882a593Smuzhiyun 				    */
366*4882a593Smuzhiyun #define ql_dbg_tgt	0x00004000 /* Target mode */
367*4882a593Smuzhiyun #define ql_dbg_tgt_mgt	0x00002000 /* Target mode management */
368*4882a593Smuzhiyun #define ql_dbg_tgt_tmr	0x00001000 /* Target mode task management */
369*4882a593Smuzhiyun #define ql_dbg_tgt_dif  0x00000800 /* Target mode dif */
370*4882a593Smuzhiyun 
371*4882a593Smuzhiyun extern int qla27xx_dump_mpi_ram(struct qla_hw_data *, uint32_t, uint32_t *,
372*4882a593Smuzhiyun 	uint32_t, void **);
373*4882a593Smuzhiyun extern int qla24xx_dump_ram(struct qla_hw_data *, uint32_t, __be32 *,
374*4882a593Smuzhiyun 	uint32_t, void **);
375*4882a593Smuzhiyun extern void qla24xx_pause_risc(struct device_reg_24xx __iomem *,
376*4882a593Smuzhiyun 	struct qla_hw_data *);
377*4882a593Smuzhiyun extern int qla24xx_soft_reset(struct qla_hw_data *);
378*4882a593Smuzhiyun 
379*4882a593Smuzhiyun static inline int
ql_mask_match(uint level)380*4882a593Smuzhiyun ql_mask_match(uint level)
381*4882a593Smuzhiyun {
382*4882a593Smuzhiyun 	if (ql2xextended_error_logging == 1)
383*4882a593Smuzhiyun 		ql2xextended_error_logging = QL_DBG_DEFAULT1_MASK;
384*4882a593Smuzhiyun 
385*4882a593Smuzhiyun 	return (level & ql2xextended_error_logging) == level;
386*4882a593Smuzhiyun }
387