1 /* 2 * Copyright (C) 2017 Chelsio Communications. All rights reserved. 3 * 4 * This program is free software; you can redistribute it and/or modify it 5 * under the terms and conditions of the GNU General Public License, 6 * version 2, as published by the Free Software Foundation. 7 * 8 * This program is distributed in the hope it will be useful, but WITHOUT 9 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 10 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 11 * more details. 12 * 13 * The full GNU General Public License is included in this distribution in 14 * the file called "COPYING". 15 * 16 */ 17 18 #ifndef __CUDBG_IF_H__ 19 #define __CUDBG_IF_H__ 20 21 /* Error codes */ 22 #define CUDBG_STATUS_NO_MEM -19 23 #define CUDBG_STATUS_ENTITY_NOT_FOUND -24 24 #define CUDBG_STATUS_NOT_IMPLEMENTED -28 25 #define CUDBG_SYSTEM_ERROR -29 26 #define CUDBG_STATUS_CCLK_NOT_DEFINED -32 27 28 #define CUDBG_MAJOR_VERSION 1 29 #define CUDBG_MINOR_VERSION 14 30 31 enum cudbg_dbg_entity_type { 32 CUDBG_REG_DUMP = 1, 33 CUDBG_DEV_LOG = 2, 34 CUDBG_CIM_LA = 3, 35 CUDBG_CIM_MA_LA = 4, 36 CUDBG_CIM_QCFG = 5, 37 CUDBG_CIM_IBQ_TP0 = 6, 38 CUDBG_CIM_IBQ_TP1 = 7, 39 CUDBG_CIM_IBQ_ULP = 8, 40 CUDBG_CIM_IBQ_SGE0 = 9, 41 CUDBG_CIM_IBQ_SGE1 = 10, 42 CUDBG_CIM_IBQ_NCSI = 11, 43 CUDBG_CIM_OBQ_ULP0 = 12, 44 CUDBG_CIM_OBQ_ULP1 = 13, 45 CUDBG_CIM_OBQ_ULP2 = 14, 46 CUDBG_CIM_OBQ_ULP3 = 15, 47 CUDBG_CIM_OBQ_SGE = 16, 48 CUDBG_CIM_OBQ_NCSI = 17, 49 CUDBG_EDC0 = 18, 50 CUDBG_EDC1 = 19, 51 CUDBG_MC0 = 20, 52 CUDBG_MC1 = 21, 53 CUDBG_RSS = 22, 54 CUDBG_RSS_VF_CONF = 25, 55 CUDBG_PATH_MTU = 27, 56 CUDBG_PM_STATS = 30, 57 CUDBG_HW_SCHED = 31, 58 CUDBG_TP_INDIRECT = 36, 59 CUDBG_SGE_INDIRECT = 37, 60 CUDBG_ULPRX_LA = 41, 61 CUDBG_TP_LA = 43, 62 CUDBG_MEMINFO = 44, 63 CUDBG_CIM_PIF_LA = 45, 64 CUDBG_CLK = 46, 65 CUDBG_CIM_OBQ_RXQ0 = 47, 66 CUDBG_CIM_OBQ_RXQ1 = 48, 67 CUDBG_PCIE_INDIRECT = 50, 68 CUDBG_PM_INDIRECT = 51, 69 CUDBG_TID_INFO = 54, 70 CUDBG_PCIE_CONFIG = 55, 71 CUDBG_DUMP_CONTEXT = 56, 72 CUDBG_MPS_TCAM = 57, 73 CUDBG_VPD_DATA = 58, 74 CUDBG_LE_TCAM = 59, 75 CUDBG_CCTRL = 60, 76 CUDBG_MA_INDIRECT = 61, 77 CUDBG_ULPTX_LA = 62, 78 CUDBG_UP_CIM_INDIRECT = 64, 79 CUDBG_PBT_TABLE = 65, 80 CUDBG_MBOX_LOG = 66, 81 CUDBG_HMA_INDIRECT = 67, 82 CUDBG_HMA = 68, 83 CUDBG_MAX_ENTITY = 70, 84 }; 85 86 struct cudbg_init { 87 struct adapter *adap; /* Pointer to adapter structure */ 88 void *outbuf; /* Output buffer */ 89 u32 outbuf_size; /* Output buffer size */ 90 u8 compress_type; /* Type of compression to use */ 91 void *compress_buff; /* Compression buffer */ 92 u32 compress_buff_size; /* Compression buffer size */ 93 void *workspace; /* Workspace for zlib */ 94 }; 95 96 static inline unsigned int cudbg_mbytes_to_bytes(unsigned int size) 97 { 98 return size * 1024 * 1024; 99 } 100 #endif /* __CUDBG_IF_H__ */ 101