GNU Linux-libre 6.8.7-gnu
[releases.git] / drivers / net / ethernet / chelsio / cxgb4 / cudbg_if.h
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  *  Copyright (C) 2017 Chelsio Communications.  All rights reserved.
4  */
5
6 #ifndef __CUDBG_IF_H__
7 #define __CUDBG_IF_H__
8
9 /* Error codes */
10 #define CUDBG_STATUS_NO_MEM -19
11 #define CUDBG_STATUS_ENTITY_NOT_FOUND -24
12 #define CUDBG_STATUS_NOT_IMPLEMENTED -28
13 #define CUDBG_SYSTEM_ERROR -29
14 #define CUDBG_STATUS_CCLK_NOT_DEFINED -32
15 #define CUDBG_STATUS_PARTIAL_DATA -41
16
17 #define CUDBG_MAJOR_VERSION 1
18 #define CUDBG_MINOR_VERSION 14
19
20 enum cudbg_dbg_entity_type {
21         CUDBG_REG_DUMP = 1,
22         CUDBG_DEV_LOG = 2,
23         CUDBG_CIM_LA = 3,
24         CUDBG_CIM_MA_LA = 4,
25         CUDBG_CIM_QCFG = 5,
26         CUDBG_CIM_IBQ_TP0 = 6,
27         CUDBG_CIM_IBQ_TP1 = 7,
28         CUDBG_CIM_IBQ_ULP = 8,
29         CUDBG_CIM_IBQ_SGE0 = 9,
30         CUDBG_CIM_IBQ_SGE1 = 10,
31         CUDBG_CIM_IBQ_NCSI = 11,
32         CUDBG_CIM_OBQ_ULP0 = 12,
33         CUDBG_CIM_OBQ_ULP1 = 13,
34         CUDBG_CIM_OBQ_ULP2 = 14,
35         CUDBG_CIM_OBQ_ULP3 = 15,
36         CUDBG_CIM_OBQ_SGE = 16,
37         CUDBG_CIM_OBQ_NCSI = 17,
38         CUDBG_EDC0 = 18,
39         CUDBG_EDC1 = 19,
40         CUDBG_MC0 = 20,
41         CUDBG_MC1 = 21,
42         CUDBG_RSS = 22,
43         CUDBG_RSS_VF_CONF = 25,
44         CUDBG_PATH_MTU = 27,
45         CUDBG_PM_STATS = 30,
46         CUDBG_HW_SCHED = 31,
47         CUDBG_TP_INDIRECT = 36,
48         CUDBG_SGE_INDIRECT = 37,
49         CUDBG_ULPRX_LA = 41,
50         CUDBG_TP_LA = 43,
51         CUDBG_MEMINFO = 44,
52         CUDBG_CIM_PIF_LA = 45,
53         CUDBG_CLK = 46,
54         CUDBG_CIM_OBQ_RXQ0 = 47,
55         CUDBG_CIM_OBQ_RXQ1 = 48,
56         CUDBG_PCIE_INDIRECT = 50,
57         CUDBG_PM_INDIRECT = 51,
58         CUDBG_TID_INFO = 54,
59         CUDBG_PCIE_CONFIG = 55,
60         CUDBG_DUMP_CONTEXT = 56,
61         CUDBG_MPS_TCAM = 57,
62         CUDBG_VPD_DATA = 58,
63         CUDBG_LE_TCAM = 59,
64         CUDBG_CCTRL = 60,
65         CUDBG_MA_INDIRECT = 61,
66         CUDBG_ULPTX_LA = 62,
67         CUDBG_UP_CIM_INDIRECT = 64,
68         CUDBG_PBT_TABLE = 65,
69         CUDBG_MBOX_LOG = 66,
70         CUDBG_HMA_INDIRECT = 67,
71         CUDBG_HMA = 68,
72         CUDBG_QDESC = 70,
73         CUDBG_FLASH = 71,
74         CUDBG_MAX_ENTITY = 72,
75 };
76
77 struct cudbg_init {
78         struct adapter *adap; /* Pointer to adapter structure */
79         void *outbuf; /* Output buffer */
80         u32 outbuf_size;  /* Output buffer size */
81         u8 compress_type; /* Type of compression to use */
82         void *compress_buff; /* Compression buffer */
83         u32 compress_buff_size; /* Compression buffer size */
84         void *workspace; /* Workspace for zlib */
85 };
86
87 static inline unsigned int cudbg_mbytes_to_bytes(unsigned int size)
88 {
89         return size * 1024 * 1024;
90 }
91 #endif /* __CUDBG_IF_H__ */