1 /* 2 * Copyright (c) 2013-2016 Qlogic Corporation 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 * 9 * 1. Redistributions of source code must retain the above copyright 10 * notice, this list of conditions and the following disclaimer. 11 * 2. Redistributions in binary form must reproduce the above copyright 12 * notice, this list of conditions and the following disclaimer in the 13 * documentation and/or other materials provided with the distribution. 14 * 15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 25 * POSSIBILITY OF SUCH DAMAGE. 26 * 27 * $FreeBSD$ 28 */ 29 30 /* 31 * File : ql_dbg.h 32 * Author : David C Somayajulu, Qlogic Corporation, Aliso Viejo, CA 92656. 33 */ 34 35 #ifndef _QL_DBG_H_ 36 #define _QL_DBG_H_ 37 38 extern void ql_dump_buf8(qla_host_t *ha, const char *str, void *dbuf, 39 uint32_t len); 40 extern void ql_dump_buf16(qla_host_t *ha, const char *str, void *dbuf, 41 uint32_t len16); 42 extern void ql_dump_buf32(qla_host_t *ha, const char *str, void *dbuf, 43 uint32_t len32); 44 45 #define INJCT_RX_RXB_INVAL 0x00001 46 #define INJCT_RX_MP_NULL 0x00002 47 #define INJCT_LRO_RXB_INVAL 0x00003 48 #define INJCT_LRO_MP_NULL 0x00004 49 #define INJCT_NUM_HNDLE_INVALID 0x00005 50 #define INJCT_RDWR_INDREG_FAILURE 0x00006 51 #define INJCT_RDWR_OFFCHIPMEM_FAILURE 0x00007 52 #define INJCT_MBX_CMD_FAILURE 0x00008 53 #define INJCT_HEARTBEAT_FAILURE 0x00009 54 #define INJCT_TEMPERATURE_FAILURE 0x0000A 55 #define INJCT_M_GETCL_M_GETJCL_FAILURE 0x0000B 56 57 #ifdef QL_DBG 58 59 #define QL_DPRINT1(ha, x) if (ha->dbg_level & 0x0001) device_printf x 60 #define QL_DPRINT2(ha, x) if (ha->dbg_level & 0x0002) device_printf x 61 #define QL_DPRINT4(ha, x) if (ha->dbg_level & 0x0004) device_printf x 62 #define QL_DPRINT8(ha, x) if (ha->dbg_level & 0x0008) device_printf x 63 #define QL_DPRINT10(ha, x) if (ha->dbg_level & 0x0010) device_printf x 64 #define QL_DPRINT20(ha, x) if (ha->dbg_level & 0x0020) device_printf x 65 #define QL_DPRINT40(ha, x) if (ha->dbg_level & 0x0040) device_printf x 66 #define QL_DPRINT80(ha, x) if (ha->dbg_level & 0x0080) device_printf x 67 68 #define QL_DUMP_BUFFER8(h, s, b, n) if (h->dbg_level & 0x08000000)\ 69 qla_dump_buf8(h, s, b, n) 70 #define QL_DUMP_BUFFER16(h, s, b, n) if (h->dbg_level & 0x08000000)\ 71 qla_dump_buf16(h, s, b, n) 72 #define QL_DUMP_BUFFER32(h, s, b, n) if (h->dbg_level & 0x08000000)\ 73 qla_dump_buf32(h, s, b, n) 74 75 #define QL_ASSERT(ha, x, y) if (!x && !ha->err_inject) panic y 76 #define QL_ERR_INJECT(ha, val) (ha->err_inject == val) 77 78 #else 79 80 #define QL_DPRINT1(ha, x) 81 #define QL_DPRINT2(ha, x) 82 #define QL_DPRINT4(ha, x) 83 #define QL_DPRINT8(ha, x) 84 #define QL_DPRINT10(ha, x) 85 #define QL_DPRINT20(ha, x) 86 #define QL_DPRINT40(ha, x) 87 #define QL_DPRINT80(ha, x) 88 89 #define QL_DUMP_BUFFER8(h, s, b, n) 90 #define QL_DUMP_BUFFER16(h, s, b, n) 91 #define QL_DUMP_BUFFER32(h, s, b, n) 92 93 #define QL_ASSERT(ha, x, y) 94 #define QL_ERR_INJECT(ha, val) 0 95 96 #endif 97 98 99 #endif /* #ifndef _QL_DBG_H_ */ 100