ql_dbg.h revision 330897
1/*-
2 * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
3 *
4 * Copyright (c) 2013-2016 Qlogic Corporation
5 * All rights reserved.
6 *
7 *  Redistribution and use in source and binary forms, with or without
8 *  modification, are permitted provided that the following conditions
9 *  are met:
10 *
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.
16 *
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.
28 *
29 * $FreeBSD: stable/11/sys/dev/qlxgbe/ql_dbg.h 330897 2018-03-14 03:19:51Z eadler $
30 */
31
32/*
33 * File : ql_dbg.h
34 * Author : David C Somayajulu, Qlogic Corporation, Aliso Viejo, CA 92656.
35 */
36
37#ifndef _QL_DBG_H_
38#define _QL_DBG_H_
39
40extern void ql_dump_buf8(qla_host_t *ha, const char *str, void *dbuf,
41		uint32_t len);
42extern void ql_dump_buf16(qla_host_t *ha, const char *str, void *dbuf,
43		uint32_t len16);
44extern void ql_dump_buf32(qla_host_t *ha, const char *str, void *dbuf,
45		uint32_t len32);
46
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
63#ifdef QL_DBG
64
65#define QL_DPRINT1(ha, x)	if (ha->dbg_level & 0x0001) device_printf x
66#define QL_DPRINT2(ha, x)	if (ha->dbg_level & 0x0002) device_printf x
67#define QL_DPRINT4(ha, x)	if (ha->dbg_level & 0x0004) device_printf x
68#define QL_DPRINT8(ha, x)	if (ha->dbg_level & 0x0008) device_printf x
69#define QL_DPRINT10(ha, x)	if (ha->dbg_level & 0x0010) device_printf x
70#define QL_DPRINT20(ha, x)	if (ha->dbg_level & 0x0020) device_printf x
71#define QL_DPRINT40(ha, x)	if (ha->dbg_level & 0x0040) device_printf x
72#define QL_DPRINT80(ha, x)	if (ha->dbg_level & 0x0080) device_printf x
73
74#define QL_DUMP_BUFFER8(h, s, b, n) if (h->dbg_level & 0x08000000)\
75					qla_dump_buf8(h, s, b, n)
76#define QL_DUMP_BUFFER16(h, s, b, n) if (h->dbg_level & 0x08000000)\
77					qla_dump_buf16(h, s, b, n)
78#define QL_DUMP_BUFFER32(h, s, b, n) if (h->dbg_level & 0x08000000)\
79					qla_dump_buf32(h, s, b, n)
80
81#define QL_ASSERT(ha, x, y)		if (!x && !ha->err_inject) panic y
82#define QL_ERR_INJECT(ha, val)		(ha->err_inject == val)
83
84#else
85
86#define QL_DPRINT1(ha, x)
87#define QL_DPRINT2(ha, x)
88#define QL_DPRINT4(ha, x)
89#define QL_DPRINT8(ha, x)
90#define QL_DPRINT10(ha, x)
91#define QL_DPRINT20(ha, x)
92#define QL_DPRINT40(ha, x)
93#define QL_DPRINT80(ha, x)
94
95#define QL_DUMP_BUFFER8(h, s, b, n)
96#define QL_DUMP_BUFFER16(h, s, b, n)
97#define QL_DUMP_BUFFER32(h, s, b, n)
98
99#define QL_ASSERT(ha, x, y)
100#define QL_ERR_INJECT(ha, val)		0
101
102#endif
103
104
105#endif /* #ifndef _QL_DBG_H_ */
106