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