2 * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
4 * Copyright (c) 2013-2016 Qlogic Corporation
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
17 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
21 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 * POSSIBILITY OF SUCH DAMAGE.
34 * Author : David C Somayajulu, Qlogic Corporation, Aliso Viejo, CA 92656.
40 extern void ql_dump_buf8(qla_host_t *ha, const char *str, void *dbuf,
42 extern void ql_dump_buf16(qla_host_t *ha, const char *str, void *dbuf,
44 extern void ql_dump_buf32(qla_host_t *ha, const char *str, void *dbuf,
47 #define INJCT_RX_RXB_INVAL 0x00001
48 #define INJCT_RX_MP_NULL 0x00002
49 #define INJCT_LRO_RXB_INVAL 0x00003
50 #define INJCT_LRO_MP_NULL 0x00004
51 #define INJCT_NUM_HNDLE_INVALID 0x00005
52 #define INJCT_RDWR_INDREG_FAILURE 0x00006
53 #define INJCT_RDWR_OFFCHIPMEM_FAILURE 0x00007
54 #define INJCT_MBX_CMD_FAILURE 0x00008
55 #define INJCT_HEARTBEAT_FAILURE 0x00009
56 #define INJCT_TEMPERATURE_FAILURE 0x0000A
57 #define INJCT_M_GETCL_M_GETJCL_FAILURE 0x0000B
58 #define INJCT_INV_CONT_OPCODE 0x0000C
59 #define INJCT_SGL_RCV_INV_DESC_COUNT 0x0000D
60 #define INJCT_SGL_LRO_INV_DESC_COUNT 0x0000E
61 #define INJCT_PEER_PORT_FAILURE_ERR_RECOVERY 0x0000F
62 #define INJCT_TXBUF_MBUF_NON_NULL 0x00010
66 #define QL_DPRINT1(ha, x) if (ha->dbg_level & 0x0001) device_printf x
67 #define QL_DPRINT2(ha, x) if (ha->dbg_level & 0x0002) device_printf x
68 #define QL_DPRINT4(ha, x) if (ha->dbg_level & 0x0004) device_printf x
69 #define QL_DPRINT8(ha, x) if (ha->dbg_level & 0x0008) device_printf x
70 #define QL_DPRINT10(ha, x) if (ha->dbg_level & 0x0010) device_printf x
71 #define QL_DPRINT20(ha, x) if (ha->dbg_level & 0x0020) device_printf x
72 #define QL_DPRINT40(ha, x) if (ha->dbg_level & 0x0040) device_printf x
73 #define QL_DPRINT80(ha, x) if (ha->dbg_level & 0x0080) device_printf x
75 #define QL_DUMP_BUFFER8(h, s, b, n) if (h->dbg_level & 0x08000000)\
76 qla_dump_buf8(h, s, b, n)
77 #define QL_DUMP_BUFFER16(h, s, b, n) if (h->dbg_level & 0x08000000)\
78 qla_dump_buf16(h, s, b, n)
79 #define QL_DUMP_BUFFER32(h, s, b, n) if (h->dbg_level & 0x08000000)\
80 qla_dump_buf32(h, s, b, n)
82 #define QL_ASSERT(ha, x, y) if (!x && !ha->err_inject) panic y
83 #define QL_ERR_INJECT(ha, val) (ha->err_inject == val)
87 #define QL_DPRINT1(ha, x)
88 #define QL_DPRINT2(ha, x)
89 #define QL_DPRINT4(ha, x)
90 #define QL_DPRINT8(ha, x)
91 #define QL_DPRINT10(ha, x)
92 #define QL_DPRINT20(ha, x)
93 #define QL_DPRINT40(ha, x)
94 #define QL_DPRINT80(ha, x)
96 #define QL_DUMP_BUFFER8(h, s, b, n)
97 #define QL_DUMP_BUFFER16(h, s, b, n)
98 #define QL_DUMP_BUFFER32(h, s, b, n)
100 #define QL_ASSERT(ha, x, y)
101 #define QL_ERR_INJECT(ha, val) 0
106 #endif /* #ifndef _QL_DBG_H_ */