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 #define CUDBG_STATUS_PARTIAL_DATA -41
28
29 #define CUDBG_MAJOR_VERSION 1
30 #define CUDBG_MINOR_VERSION 14
31
32 enum cudbg_dbg_entity_type {
33 CUDBG_REG_DUMP = 1,
34 CUDBG_DEV_LOG = 2,
35 CUDBG_CIM_LA = 3,
36 CUDBG_CIM_MA_LA = 4,
37 CUDBG_CIM_QCFG = 5,
38 CUDBG_CIM_IBQ_TP0 = 6,
39 CUDBG_CIM_IBQ_TP1 = 7,
40 CUDBG_CIM_IBQ_ULP = 8,
41 CUDBG_CIM_IBQ_SGE0 = 9,
42 CUDBG_CIM_IBQ_SGE1 = 10,
43 CUDBG_CIM_IBQ_NCSI = 11,
44 CUDBG_CIM_OBQ_ULP0 = 12,
45 CUDBG_CIM_OBQ_ULP1 = 13,
46 CUDBG_CIM_OBQ_ULP2 = 14,
47 CUDBG_CIM_OBQ_ULP3 = 15,
48 CUDBG_CIM_OBQ_SGE = 16,
49 CUDBG_CIM_OBQ_NCSI = 17,
50 CUDBG_EDC0 = 18,
51 CUDBG_EDC1 = 19,
52 CUDBG_MC0 = 20,
53 CUDBG_MC1 = 21,
54 CUDBG_RSS = 22,
55 CUDBG_RSS_VF_CONF = 25,
56 CUDBG_PATH_MTU = 27,
57 CUDBG_PM_STATS = 30,
58 CUDBG_HW_SCHED = 31,
59 CUDBG_TP_INDIRECT = 36,
60 CUDBG_SGE_INDIRECT = 37,
61 CUDBG_ULPRX_LA = 41,
62 CUDBG_TP_LA = 43,
63 CUDBG_MEMINFO = 44,
64 CUDBG_CIM_PIF_LA = 45,
65 CUDBG_CLK = 46,
66 CUDBG_CIM_OBQ_RXQ0 = 47,
67 CUDBG_CIM_OBQ_RXQ1 = 48,
68 CUDBG_PCIE_INDIRECT = 50,
69 CUDBG_PM_INDIRECT = 51,
70 CUDBG_TID_INFO = 54,
71 CUDBG_PCIE_CONFIG = 55,
72 CUDBG_DUMP_CONTEXT = 56,
73 CUDBG_MPS_TCAM = 57,
74 CUDBG_VPD_DATA = 58,
75 CUDBG_LE_TCAM = 59,
76 CUDBG_CCTRL = 60,
77 CUDBG_MA_INDIRECT = 61,
78 CUDBG_ULPTX_LA = 62,
79 CUDBG_UP_CIM_INDIRECT = 64,
80 CUDBG_PBT_TABLE = 65,
81 CUDBG_MBOX_LOG = 66,
82 CUDBG_HMA_INDIRECT = 67,
83 CUDBG_HMA = 68,
84 CUDBG_MAX_ENTITY = 70,
85 };
86
87 struct cudbg_init {
88 struct adapter *adap; /* Pointer to adapter structure */
89 void *outbuf; /* Output buffer */
90 u32 outbuf_size; /* Output buffer size */
91 u8 compress_type; /* Type of compression to use */
92 void *compress_buff; /* Compression buffer */
93 u32 compress_buff_size; /* Compression buffer size */
94 void *workspace; /* Workspace for zlib */
95 };
96
cudbg_mbytes_to_bytes(unsigned int size)97 static inline unsigned int cudbg_mbytes_to_bytes(unsigned int size)
98 {
99 return size * 1024 * 1024;
100 }
101 #endif /* __CUDBG_IF_H__ */
102