1/* 2 * Copyright (c) 2013-2014 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 38extern void ql_dump_buf8(qla_host_t *ha, const char *str, void *dbuf, 39 uint32_t len); 40extern void ql_dump_buf16(qla_host_t *ha, const char *str, void *dbuf, 41 uint32_t len16); 42extern 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 56#ifdef QL_DBG 57 58#define QL_DPRINT1(ha, x) if (ha->dbg_level & 0x0001) device_printf x 59#define QL_DPRINT2(ha, x) if (ha->dbg_level & 0x0002) device_printf x 60#define QL_DPRINT4(ha, x) if (ha->dbg_level & 0x0004) device_printf x 61#define QL_DPRINT8(ha, x) if (ha->dbg_level & 0x0008) device_printf x 62#define QL_DPRINT10(ha, x) if (ha->dbg_level & 0x0010) device_printf x 63#define QL_DPRINT20(ha, x) if (ha->dbg_level & 0x0020) device_printf x 64#define QL_DPRINT40(ha, x) if (ha->dbg_level & 0x0040) device_printf x 65#define QL_DPRINT80(ha, x) if (ha->dbg_level & 0x0080) device_printf x 66 67#define QL_DUMP_BUFFER8(h, s, b, n) if (h->dbg_level & 0x08000000)\ 68 qla_dump_buf8(h, s, b, n) 69#define QL_DUMP_BUFFER16(h, s, b, n) if (h->dbg_level & 0x08000000)\ 70 qla_dump_buf16(h, s, b, n) 71#define QL_DUMP_BUFFER32(h, s, b, n) if (h->dbg_level & 0x08000000)\ 72 qla_dump_buf32(h, s, b, n) 73 74#define QL_ASSERT(ha, x, y) if (!x && !ha->err_inject) panic y 75#define QL_ERR_INJECT(ha, val) (ha->err_inject == val) 76 77#else 78 79#define QL_DPRINT1(ha, x) 80#define QL_DPRINT2(ha, x) 81#define QL_DPRINT4(ha, x) 82#define QL_DPRINT8(ha, x) 83#define QL_DPRINT10(ha, x) 84#define QL_DPRINT20(ha, x) 85#define QL_DPRINT40(ha, x) 86#define QL_DPRINT80(ha, x) 87 88#define QL_DUMP_BUFFER8(h, s, b, n) 89#define QL_DUMP_BUFFER16(h, s, b, n) 90#define QL_DUMP_BUFFER32(h, s, b, n) 91 92#define QL_ASSERT(ha, x, y) 93#define QL_ERR_INJECT(ha, val) 0 94 95#endif 96 97 98#endif /* #ifndef _QL_DBG_H_ */ 99