1492 lines
		
	
	
		
			42 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			1492 lines
		
	
	
		
			42 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */
 | |
| /* QLogic qed NIC Driver
 | |
|  * Copyright (c) 2019-2021 Marvell International Ltd.
 | |
|  */
 | |
| #ifndef _QED_DBG_HSI_H
 | |
| #define _QED_DBG_HSI_H
 | |
| 
 | |
| #include <linux/types.h>
 | |
| #include <linux/io.h>
 | |
| #include <linux/bitops.h>
 | |
| #include <linux/delay.h>
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/list.h>
 | |
| #include <linux/slab.h>
 | |
| 
 | |
| /****************************************/
 | |
| /* Debug Tools HSI constants and macros */
 | |
| /****************************************/
 | |
| 
 | |
| enum block_id {
 | |
| 	BLOCK_GRC,
 | |
| 	BLOCK_MISCS,
 | |
| 	BLOCK_MISC,
 | |
| 	BLOCK_DBU,
 | |
| 	BLOCK_PGLUE_B,
 | |
| 	BLOCK_CNIG,
 | |
| 	BLOCK_CPMU,
 | |
| 	BLOCK_NCSI,
 | |
| 	BLOCK_OPTE,
 | |
| 	BLOCK_BMB,
 | |
| 	BLOCK_PCIE,
 | |
| 	BLOCK_MCP,
 | |
| 	BLOCK_MCP2,
 | |
| 	BLOCK_PSWHST,
 | |
| 	BLOCK_PSWHST2,
 | |
| 	BLOCK_PSWRD,
 | |
| 	BLOCK_PSWRD2,
 | |
| 	BLOCK_PSWWR,
 | |
| 	BLOCK_PSWWR2,
 | |
| 	BLOCK_PSWRQ,
 | |
| 	BLOCK_PSWRQ2,
 | |
| 	BLOCK_PGLCS,
 | |
| 	BLOCK_DMAE,
 | |
| 	BLOCK_PTU,
 | |
| 	BLOCK_TCM,
 | |
| 	BLOCK_MCM,
 | |
| 	BLOCK_UCM,
 | |
| 	BLOCK_XCM,
 | |
| 	BLOCK_YCM,
 | |
| 	BLOCK_PCM,
 | |
| 	BLOCK_QM,
 | |
| 	BLOCK_TM,
 | |
| 	BLOCK_DORQ,
 | |
| 	BLOCK_BRB,
 | |
| 	BLOCK_SRC,
 | |
| 	BLOCK_PRS,
 | |
| 	BLOCK_TSDM,
 | |
| 	BLOCK_MSDM,
 | |
| 	BLOCK_USDM,
 | |
| 	BLOCK_XSDM,
 | |
| 	BLOCK_YSDM,
 | |
| 	BLOCK_PSDM,
 | |
| 	BLOCK_TSEM,
 | |
| 	BLOCK_MSEM,
 | |
| 	BLOCK_USEM,
 | |
| 	BLOCK_XSEM,
 | |
| 	BLOCK_YSEM,
 | |
| 	BLOCK_PSEM,
 | |
| 	BLOCK_RSS,
 | |
| 	BLOCK_TMLD,
 | |
| 	BLOCK_MULD,
 | |
| 	BLOCK_YULD,
 | |
| 	BLOCK_XYLD,
 | |
| 	BLOCK_PRM,
 | |
| 	BLOCK_PBF_PB1,
 | |
| 	BLOCK_PBF_PB2,
 | |
| 	BLOCK_RPB,
 | |
| 	BLOCK_BTB,
 | |
| 	BLOCK_PBF,
 | |
| 	BLOCK_RDIF,
 | |
| 	BLOCK_TDIF,
 | |
| 	BLOCK_CDU,
 | |
| 	BLOCK_CCFC,
 | |
| 	BLOCK_TCFC,
 | |
| 	BLOCK_IGU,
 | |
| 	BLOCK_CAU,
 | |
| 	BLOCK_UMAC,
 | |
| 	BLOCK_XMAC,
 | |
| 	BLOCK_MSTAT,
 | |
| 	BLOCK_DBG,
 | |
| 	BLOCK_NIG,
 | |
| 	BLOCK_WOL,
 | |
| 	BLOCK_BMBN,
 | |
| 	BLOCK_IPC,
 | |
| 	BLOCK_NWM,
 | |
| 	BLOCK_NWS,
 | |
| 	BLOCK_MS,
 | |
| 	BLOCK_PHY_PCIE,
 | |
| 	BLOCK_LED,
 | |
| 	BLOCK_AVS_WRAP,
 | |
| 	BLOCK_PXPREQBUS,
 | |
| 	BLOCK_BAR0_MAP,
 | |
| 	BLOCK_MCP_FIO,
 | |
| 	BLOCK_LAST_INIT,
 | |
| 	BLOCK_PRS_FC,
 | |
| 	BLOCK_PBF_FC,
 | |
| 	BLOCK_NIG_LB_FC,
 | |
| 	BLOCK_NIG_LB_FC_PLLH,
 | |
| 	BLOCK_NIG_TX_FC_PLLH,
 | |
| 	BLOCK_NIG_TX_FC,
 | |
| 	BLOCK_NIG_RX_FC_PLLH,
 | |
| 	BLOCK_NIG_RX_FC,
 | |
| 	MAX_BLOCK_ID
 | |
| };
 | |
| 
 | |
| /* binary debug buffer types */
 | |
| enum bin_dbg_buffer_type {
 | |
| 	BIN_BUF_DBG_MODE_TREE,
 | |
| 	BIN_BUF_DBG_DUMP_REG,
 | |
| 	BIN_BUF_DBG_DUMP_MEM,
 | |
| 	BIN_BUF_DBG_IDLE_CHK_REGS,
 | |
| 	BIN_BUF_DBG_IDLE_CHK_IMMS,
 | |
| 	BIN_BUF_DBG_IDLE_CHK_RULES,
 | |
| 	BIN_BUF_DBG_IDLE_CHK_PARSING_DATA,
 | |
| 	BIN_BUF_DBG_ATTN_BLOCKS,
 | |
| 	BIN_BUF_DBG_ATTN_REGS,
 | |
| 	BIN_BUF_DBG_ATTN_INDEXES,
 | |
| 	BIN_BUF_DBG_ATTN_NAME_OFFSETS,
 | |
| 	BIN_BUF_DBG_BLOCKS,
 | |
| 	BIN_BUF_DBG_BLOCKS_CHIP_DATA,
 | |
| 	BIN_BUF_DBG_BUS_LINES,
 | |
| 	BIN_BUF_DBG_BLOCKS_USER_DATA,
 | |
| 	BIN_BUF_DBG_BLOCKS_CHIP_USER_DATA,
 | |
| 	BIN_BUF_DBG_BUS_LINE_NAME_OFFSETS,
 | |
| 	BIN_BUF_DBG_RESET_REGS,
 | |
| 	BIN_BUF_DBG_PARSING_STRINGS,
 | |
| 	MAX_BIN_DBG_BUFFER_TYPE
 | |
| };
 | |
| 
 | |
| /* Attention bit mapping */
 | |
| struct dbg_attn_bit_mapping {
 | |
| 	u16 data;
 | |
| #define DBG_ATTN_BIT_MAPPING_VAL_MASK			0x7FFF
 | |
| #define DBG_ATTN_BIT_MAPPING_VAL_SHIFT			0
 | |
| #define DBG_ATTN_BIT_MAPPING_IS_UNUSED_BIT_CNT_MASK	0x1
 | |
| #define DBG_ATTN_BIT_MAPPING_IS_UNUSED_BIT_CNT_SHIFT	15
 | |
| };
 | |
| 
 | |
| /* Attention block per-type data */
 | |
| struct dbg_attn_block_type_data {
 | |
| 	u16 names_offset;
 | |
| 	u16 reserved1;
 | |
| 	u8 num_regs;
 | |
| 	u8 reserved2;
 | |
| 	u16 regs_offset;
 | |
| 
 | |
| };
 | |
| 
 | |
| /* Block attentions */
 | |
| struct dbg_attn_block {
 | |
| 	struct dbg_attn_block_type_data per_type_data[2];
 | |
| };
 | |
| 
 | |
| /* Attention register result */
 | |
| struct dbg_attn_reg_result {
 | |
| 	u32 data;
 | |
| #define DBG_ATTN_REG_RESULT_STS_ADDRESS_MASK	0xFFFFFF
 | |
| #define DBG_ATTN_REG_RESULT_STS_ADDRESS_SHIFT	0
 | |
| #define DBG_ATTN_REG_RESULT_NUM_REG_ATTN_MASK	0xFF
 | |
| #define DBG_ATTN_REG_RESULT_NUM_REG_ATTN_SHIFT	24
 | |
| 	u16 block_attn_offset;
 | |
| 	u16 reserved;
 | |
| 	u32 sts_val;
 | |
| 	u32 mask_val;
 | |
| };
 | |
| 
 | |
| /* Attention block result */
 | |
| struct dbg_attn_block_result {
 | |
| 	u8 block_id;
 | |
| 	u8 data;
 | |
| #define DBG_ATTN_BLOCK_RESULT_ATTN_TYPE_MASK	0x3
 | |
| #define DBG_ATTN_BLOCK_RESULT_ATTN_TYPE_SHIFT	0
 | |
| #define DBG_ATTN_BLOCK_RESULT_NUM_REGS_MASK	0x3F
 | |
| #define DBG_ATTN_BLOCK_RESULT_NUM_REGS_SHIFT	2
 | |
| 	u16 names_offset;
 | |
| 	struct dbg_attn_reg_result reg_results[15];
 | |
| };
 | |
| 
 | |
| /* Mode header */
 | |
| struct dbg_mode_hdr {
 | |
| 	u16 data;
 | |
| #define DBG_MODE_HDR_EVAL_MODE_MASK		0x1
 | |
| #define DBG_MODE_HDR_EVAL_MODE_SHIFT		0
 | |
| #define DBG_MODE_HDR_MODES_BUF_OFFSET_MASK	0x7FFF
 | |
| #define DBG_MODE_HDR_MODES_BUF_OFFSET_SHIFT	1
 | |
| };
 | |
| 
 | |
| /* Attention register */
 | |
| struct dbg_attn_reg {
 | |
| 	struct dbg_mode_hdr mode;
 | |
| 	u16 block_attn_offset;
 | |
| 	u32 data;
 | |
| #define DBG_ATTN_REG_STS_ADDRESS_MASK	0xFFFFFF
 | |
| #define DBG_ATTN_REG_STS_ADDRESS_SHIFT	0
 | |
| #define DBG_ATTN_REG_NUM_REG_ATTN_MASK	0xFF
 | |
| #define DBG_ATTN_REG_NUM_REG_ATTN_SHIFT 24
 | |
| 	u32 sts_clr_address;
 | |
| 	u32 mask_address;
 | |
| };
 | |
| 
 | |
| /* Attention types */
 | |
| enum dbg_attn_type {
 | |
| 	ATTN_TYPE_INTERRUPT,
 | |
| 	ATTN_TYPE_PARITY,
 | |
| 	MAX_DBG_ATTN_TYPE
 | |
| };
 | |
| 
 | |
| /* Block debug data */
 | |
| struct dbg_block {
 | |
| 	u8 name[15];
 | |
| 	u8 associated_storm_letter;
 | |
| };
 | |
| 
 | |
| /* Chip-specific block debug data */
 | |
| struct dbg_block_chip {
 | |
| 	u8 flags;
 | |
| #define DBG_BLOCK_CHIP_IS_REMOVED_MASK		 0x1
 | |
| #define DBG_BLOCK_CHIP_IS_REMOVED_SHIFT		 0
 | |
| #define DBG_BLOCK_CHIP_HAS_RESET_REG_MASK	 0x1
 | |
| #define DBG_BLOCK_CHIP_HAS_RESET_REG_SHIFT	 1
 | |
| #define DBG_BLOCK_CHIP_UNRESET_BEFORE_DUMP_MASK  0x1
 | |
| #define DBG_BLOCK_CHIP_UNRESET_BEFORE_DUMP_SHIFT 2
 | |
| #define DBG_BLOCK_CHIP_HAS_DBG_BUS_MASK		 0x1
 | |
| #define DBG_BLOCK_CHIP_HAS_DBG_BUS_SHIFT	 3
 | |
| #define DBG_BLOCK_CHIP_HAS_LATENCY_EVENTS_MASK	 0x1
 | |
| #define DBG_BLOCK_CHIP_HAS_LATENCY_EVENTS_SHIFT  4
 | |
| #define DBG_BLOCK_CHIP_RESERVED0_MASK		 0x7
 | |
| #define DBG_BLOCK_CHIP_RESERVED0_SHIFT		 5
 | |
| 	u8 dbg_client_id;
 | |
| 	u8 reset_reg_id;
 | |
| 	u8 reset_reg_bit_offset;
 | |
| 	struct dbg_mode_hdr dbg_bus_mode;
 | |
| 	u16 reserved1;
 | |
| 	u8 reserved2;
 | |
| 	u8 num_of_dbg_bus_lines;
 | |
| 	u16 dbg_bus_lines_offset;
 | |
| 	u32 dbg_select_reg_addr;
 | |
| 	u32 dbg_dword_enable_reg_addr;
 | |
| 	u32 dbg_shift_reg_addr;
 | |
| 	u32 dbg_force_valid_reg_addr;
 | |
| 	u32 dbg_force_frame_reg_addr;
 | |
| };
 | |
| 
 | |
| /* Chip-specific block user debug data */
 | |
| struct dbg_block_chip_user {
 | |
| 	u8 num_of_dbg_bus_lines;
 | |
| 	u8 has_latency_events;
 | |
| 	u16 names_offset;
 | |
| };
 | |
| 
 | |
| /* Block user debug data */
 | |
| struct dbg_block_user {
 | |
| 	u8 name[16];
 | |
| };
 | |
| 
 | |
| /* Block Debug line data */
 | |
| struct dbg_bus_line {
 | |
| 	u8 data;
 | |
| #define DBG_BUS_LINE_NUM_OF_GROUPS_MASK		0xF
 | |
| #define DBG_BUS_LINE_NUM_OF_GROUPS_SHIFT	0
 | |
| #define DBG_BUS_LINE_IS_256B_MASK		0x1
 | |
| #define DBG_BUS_LINE_IS_256B_SHIFT		4
 | |
| #define DBG_BUS_LINE_RESERVED_MASK		0x7
 | |
| #define DBG_BUS_LINE_RESERVED_SHIFT		5
 | |
| 	u8 group_sizes;
 | |
| };
 | |
| 
 | |
| /* Condition header for registers dump */
 | |
| struct dbg_dump_cond_hdr {
 | |
| 	struct dbg_mode_hdr mode; /* Mode header */
 | |
| 	u8 block_id; /* block ID */
 | |
| 	u8 data_size; /* size in dwords of the data following this header */
 | |
| };
 | |
| 
 | |
| /* Memory data for registers dump */
 | |
| struct dbg_dump_mem {
 | |
| 	u32 dword0;
 | |
| #define DBG_DUMP_MEM_ADDRESS_MASK	0xFFFFFF
 | |
| #define DBG_DUMP_MEM_ADDRESS_SHIFT	0
 | |
| #define DBG_DUMP_MEM_MEM_GROUP_ID_MASK	0xFF
 | |
| #define DBG_DUMP_MEM_MEM_GROUP_ID_SHIFT	24
 | |
| 	u32 dword1;
 | |
| #define DBG_DUMP_MEM_LENGTH_MASK	0xFFFFFF
 | |
| #define DBG_DUMP_MEM_LENGTH_SHIFT	0
 | |
| #define DBG_DUMP_MEM_WIDE_BUS_MASK	0x1
 | |
| #define DBG_DUMP_MEM_WIDE_BUS_SHIFT	24
 | |
| #define DBG_DUMP_MEM_RESERVED_MASK	0x7F
 | |
| #define DBG_DUMP_MEM_RESERVED_SHIFT	25
 | |
| };
 | |
| 
 | |
| /* Register data for registers dump */
 | |
| struct dbg_dump_reg {
 | |
| 	u32 data;
 | |
| #define DBG_DUMP_REG_ADDRESS_MASK	0x7FFFFF
 | |
| #define DBG_DUMP_REG_ADDRESS_SHIFT	0
 | |
| #define DBG_DUMP_REG_WIDE_BUS_MASK	0x1
 | |
| #define DBG_DUMP_REG_WIDE_BUS_SHIFT	23
 | |
| #define DBG_DUMP_REG_LENGTH_MASK	0xFF
 | |
| #define DBG_DUMP_REG_LENGTH_SHIFT	24
 | |
| };
 | |
| 
 | |
| /* Split header for registers dump */
 | |
| struct dbg_dump_split_hdr {
 | |
| 	u32 hdr;
 | |
| #define DBG_DUMP_SPLIT_HDR_DATA_SIZE_MASK	0xFFFFFF
 | |
| #define DBG_DUMP_SPLIT_HDR_DATA_SIZE_SHIFT	0
 | |
| #define DBG_DUMP_SPLIT_HDR_SPLIT_TYPE_ID_MASK	0xFF
 | |
| #define DBG_DUMP_SPLIT_HDR_SPLIT_TYPE_ID_SHIFT	24
 | |
| };
 | |
| 
 | |
| /* Condition header for idle check */
 | |
| struct dbg_idle_chk_cond_hdr {
 | |
| 	struct dbg_mode_hdr mode; /* Mode header */
 | |
| 	u16 data_size; /* size in dwords of the data following this header */
 | |
| };
 | |
| 
 | |
| /* Idle Check condition register */
 | |
| struct dbg_idle_chk_cond_reg {
 | |
| 	u32 data;
 | |
| #define DBG_IDLE_CHK_COND_REG_ADDRESS_MASK	0x7FFFFF
 | |
| #define DBG_IDLE_CHK_COND_REG_ADDRESS_SHIFT	0
 | |
| #define DBG_IDLE_CHK_COND_REG_WIDE_BUS_MASK	0x1
 | |
| #define DBG_IDLE_CHK_COND_REG_WIDE_BUS_SHIFT	23
 | |
| #define DBG_IDLE_CHK_COND_REG_BLOCK_ID_MASK	0xFF
 | |
| #define DBG_IDLE_CHK_COND_REG_BLOCK_ID_SHIFT	24
 | |
| 	u16 num_entries;
 | |
| 	u8 entry_size;
 | |
| 	u8 start_entry;
 | |
| };
 | |
| 
 | |
| /* Idle Check info register */
 | |
| struct dbg_idle_chk_info_reg {
 | |
| 	u32 data;
 | |
| #define DBG_IDLE_CHK_INFO_REG_ADDRESS_MASK	0x7FFFFF
 | |
| #define DBG_IDLE_CHK_INFO_REG_ADDRESS_SHIFT	0
 | |
| #define DBG_IDLE_CHK_INFO_REG_WIDE_BUS_MASK	0x1
 | |
| #define DBG_IDLE_CHK_INFO_REG_WIDE_BUS_SHIFT	23
 | |
| #define DBG_IDLE_CHK_INFO_REG_BLOCK_ID_MASK	0xFF
 | |
| #define DBG_IDLE_CHK_INFO_REG_BLOCK_ID_SHIFT	24
 | |
| 	u16 size; /* register size in dwords */
 | |
| 	struct dbg_mode_hdr mode; /* Mode header */
 | |
| };
 | |
| 
 | |
| /* Idle Check register */
 | |
| union dbg_idle_chk_reg {
 | |
| 	struct dbg_idle_chk_cond_reg cond_reg; /* condition register */
 | |
| 	struct dbg_idle_chk_info_reg info_reg; /* info register */
 | |
| };
 | |
| 
 | |
| /* Idle Check result header */
 | |
| struct dbg_idle_chk_result_hdr {
 | |
| 	u16 rule_id; /* Failing rule index */
 | |
| 	u16 mem_entry_id; /* Failing memory entry index */
 | |
| 	u8 num_dumped_cond_regs; /* number of dumped condition registers */
 | |
| 	u8 num_dumped_info_regs; /* number of dumped condition registers */
 | |
| 	u8 severity; /* from dbg_idle_chk_severity_types enum */
 | |
| 	u8 reserved;
 | |
| };
 | |
| 
 | |
| /* Idle Check result register header */
 | |
| struct dbg_idle_chk_result_reg_hdr {
 | |
| 	u8 data;
 | |
| #define DBG_IDLE_CHK_RESULT_REG_HDR_IS_MEM_MASK  0x1
 | |
| #define DBG_IDLE_CHK_RESULT_REG_HDR_IS_MEM_SHIFT 0
 | |
| #define DBG_IDLE_CHK_RESULT_REG_HDR_REG_ID_MASK  0x7F
 | |
| #define DBG_IDLE_CHK_RESULT_REG_HDR_REG_ID_SHIFT 1
 | |
| 	u8 start_entry; /* index of the first checked entry */
 | |
| 	u16 size; /* register size in dwords */
 | |
| };
 | |
| 
 | |
| /* Idle Check rule */
 | |
| struct dbg_idle_chk_rule {
 | |
| 	u16 rule_id; /* Idle Check rule ID */
 | |
| 	u8 severity; /* value from dbg_idle_chk_severity_types enum */
 | |
| 	u8 cond_id; /* Condition ID */
 | |
| 	u8 num_cond_regs; /* number of condition registers */
 | |
| 	u8 num_info_regs; /* number of info registers */
 | |
| 	u8 num_imms; /* number of immediates in the condition */
 | |
| 	u8 reserved1;
 | |
| 	u16 reg_offset; /* offset of this rules registers in the idle check
 | |
| 			 * register array (in dbg_idle_chk_reg units).
 | |
| 			 */
 | |
| 	u16 imm_offset; /* offset of this rules immediate values in the
 | |
| 			 * immediate values array (in dwords).
 | |
| 			 */
 | |
| };
 | |
| 
 | |
| /* Idle Check rule parsing data */
 | |
| struct dbg_idle_chk_rule_parsing_data {
 | |
| 	u32 data;
 | |
| #define DBG_IDLE_CHK_RULE_PARSING_DATA_HAS_FW_MSG_MASK	0x1
 | |
| #define DBG_IDLE_CHK_RULE_PARSING_DATA_HAS_FW_MSG_SHIFT	0
 | |
| #define DBG_IDLE_CHK_RULE_PARSING_DATA_STR_OFFSET_MASK	0x7FFFFFFF
 | |
| #define DBG_IDLE_CHK_RULE_PARSING_DATA_STR_OFFSET_SHIFT	1
 | |
| };
 | |
| 
 | |
| /* Idle check severity types */
 | |
| enum dbg_idle_chk_severity_types {
 | |
| 	/* idle check failure should cause an error */
 | |
| 	IDLE_CHK_SEVERITY_ERROR,
 | |
| 	/* idle check failure should cause an error only if theres no traffic */
 | |
| 	IDLE_CHK_SEVERITY_ERROR_NO_TRAFFIC,
 | |
| 	/* idle check failure should cause a warning */
 | |
| 	IDLE_CHK_SEVERITY_WARNING,
 | |
| 	MAX_DBG_IDLE_CHK_SEVERITY_TYPES
 | |
| };
 | |
| 
 | |
| /* Reset register */
 | |
| struct dbg_reset_reg {
 | |
| 	u32 data;
 | |
| #define DBG_RESET_REG_ADDR_MASK        0xFFFFFF
 | |
| #define DBG_RESET_REG_ADDR_SHIFT       0
 | |
| #define DBG_RESET_REG_IS_REMOVED_MASK  0x1
 | |
| #define DBG_RESET_REG_IS_REMOVED_SHIFT 24
 | |
| #define DBG_RESET_REG_RESERVED_MASK    0x7F
 | |
| #define DBG_RESET_REG_RESERVED_SHIFT   25
 | |
| };
 | |
| 
 | |
| /* Debug Bus block data */
 | |
| struct dbg_bus_block_data {
 | |
| 	u8 enable_mask;
 | |
| 	u8 right_shift;
 | |
| 	u8 force_valid_mask;
 | |
| 	u8 force_frame_mask;
 | |
| 	u8 dword_mask;
 | |
| 	u8 line_num;
 | |
| 	u8 hw_id;
 | |
| 	u8 flags;
 | |
| #define DBG_BUS_BLOCK_DATA_IS_256B_LINE_MASK  0x1
 | |
| #define DBG_BUS_BLOCK_DATA_IS_256B_LINE_SHIFT 0
 | |
| #define DBG_BUS_BLOCK_DATA_RESERVED_MASK      0x7F
 | |
| #define DBG_BUS_BLOCK_DATA_RESERVED_SHIFT     1
 | |
| };
 | |
| 
 | |
| enum dbg_bus_clients {
 | |
| 	DBG_BUS_CLIENT_RBCN,
 | |
| 	DBG_BUS_CLIENT_RBCP,
 | |
| 	DBG_BUS_CLIENT_RBCR,
 | |
| 	DBG_BUS_CLIENT_RBCT,
 | |
| 	DBG_BUS_CLIENT_RBCU,
 | |
| 	DBG_BUS_CLIENT_RBCF,
 | |
| 	DBG_BUS_CLIENT_RBCX,
 | |
| 	DBG_BUS_CLIENT_RBCS,
 | |
| 	DBG_BUS_CLIENT_RBCH,
 | |
| 	DBG_BUS_CLIENT_RBCZ,
 | |
| 	DBG_BUS_CLIENT_OTHER_ENGINE,
 | |
| 	DBG_BUS_CLIENT_TIMESTAMP,
 | |
| 	DBG_BUS_CLIENT_CPU,
 | |
| 	DBG_BUS_CLIENT_RBCY,
 | |
| 	DBG_BUS_CLIENT_RBCQ,
 | |
| 	DBG_BUS_CLIENT_RBCM,
 | |
| 	DBG_BUS_CLIENT_RBCB,
 | |
| 	DBG_BUS_CLIENT_RBCW,
 | |
| 	DBG_BUS_CLIENT_RBCV,
 | |
| 	MAX_DBG_BUS_CLIENTS
 | |
| };
 | |
| 
 | |
| /* Debug Bus constraint operation types */
 | |
| enum dbg_bus_constraint_ops {
 | |
| 	DBG_BUS_CONSTRAINT_OP_EQ,
 | |
| 	DBG_BUS_CONSTRAINT_OP_NE,
 | |
| 	DBG_BUS_CONSTRAINT_OP_LT,
 | |
| 	DBG_BUS_CONSTRAINT_OP_LTC,
 | |
| 	DBG_BUS_CONSTRAINT_OP_LE,
 | |
| 	DBG_BUS_CONSTRAINT_OP_LEC,
 | |
| 	DBG_BUS_CONSTRAINT_OP_GT,
 | |
| 	DBG_BUS_CONSTRAINT_OP_GTC,
 | |
| 	DBG_BUS_CONSTRAINT_OP_GE,
 | |
| 	DBG_BUS_CONSTRAINT_OP_GEC,
 | |
| 	MAX_DBG_BUS_CONSTRAINT_OPS
 | |
| };
 | |
| 
 | |
| /* Debug Bus trigger state data */
 | |
| struct dbg_bus_trigger_state_data {
 | |
| 	u8 msg_len;
 | |
| 	u8 constraint_dword_mask;
 | |
| 	u8 storm_id;
 | |
| 	u8 reserved;
 | |
| };
 | |
| 
 | |
| /* Debug Bus memory address */
 | |
| struct dbg_bus_mem_addr {
 | |
| 	u32 lo;
 | |
| 	u32 hi;
 | |
| };
 | |
| 
 | |
| /* Debug Bus PCI buffer data */
 | |
| struct dbg_bus_pci_buf_data {
 | |
| 	struct dbg_bus_mem_addr phys_addr; /* PCI buffer physical address */
 | |
| 	struct dbg_bus_mem_addr virt_addr; /* PCI buffer virtual address */
 | |
| 	u32 size; /* PCI buffer size in bytes */
 | |
| };
 | |
| 
 | |
| /* Debug Bus Storm EID range filter params */
 | |
| struct dbg_bus_storm_eid_range_params {
 | |
| 	u8 min; /* Minimal event ID to filter on */
 | |
| 	u8 max; /* Maximal event ID to filter on */
 | |
| };
 | |
| 
 | |
| /* Debug Bus Storm EID mask filter params */
 | |
| struct dbg_bus_storm_eid_mask_params {
 | |
| 	u8 val; /* Event ID value */
 | |
| 	u8 mask; /* Event ID mask. 1s in the mask = dont care bits. */
 | |
| };
 | |
| 
 | |
| /* Debug Bus Storm EID filter params */
 | |
| union dbg_bus_storm_eid_params {
 | |
| 	struct dbg_bus_storm_eid_range_params range;
 | |
| 	struct dbg_bus_storm_eid_mask_params mask;
 | |
| };
 | |
| 
 | |
| /* Debug Bus Storm data */
 | |
| struct dbg_bus_storm_data {
 | |
| 	u8 enabled;
 | |
| 	u8 mode;
 | |
| 	u8 hw_id;
 | |
| 	u8 eid_filter_en;
 | |
| 	u8 eid_range_not_mask;
 | |
| 	u8 cid_filter_en;
 | |
| 	union dbg_bus_storm_eid_params eid_filter_params;
 | |
| 	u32 cid;
 | |
| };
 | |
| 
 | |
| /* Debug Bus data */
 | |
| struct dbg_bus_data {
 | |
| 	u32 app_version;
 | |
| 	u8 state;
 | |
| 	u8 mode_256b_en;
 | |
| 	u8 num_enabled_blocks;
 | |
| 	u8 num_enabled_storms;
 | |
| 	u8 target;
 | |
| 	u8 one_shot_en;
 | |
| 	u8 grc_input_en;
 | |
| 	u8 timestamp_input_en;
 | |
| 	u8 filter_en;
 | |
| 	u8 adding_filter;
 | |
| 	u8 filter_pre_trigger;
 | |
| 	u8 filter_post_trigger;
 | |
| 	u8 trigger_en;
 | |
| 	u8 filter_constraint_dword_mask;
 | |
| 	u8 next_trigger_state;
 | |
| 	u8 next_constraint_id;
 | |
| 	struct dbg_bus_trigger_state_data trigger_states[3];
 | |
| 	u8 filter_msg_len;
 | |
| 	u8 rcv_from_other_engine;
 | |
| 	u8 blocks_dword_mask;
 | |
| 	u8 blocks_dword_overlap;
 | |
| 	u32 hw_id_mask;
 | |
| 	struct dbg_bus_pci_buf_data pci_buf;
 | |
| 	struct dbg_bus_block_data blocks[132];
 | |
| 	struct dbg_bus_storm_data storms[6];
 | |
| };
 | |
| 
 | |
| /* Debug bus states */
 | |
| enum dbg_bus_states {
 | |
| 	DBG_BUS_STATE_IDLE,
 | |
| 	DBG_BUS_STATE_READY,
 | |
| 	DBG_BUS_STATE_RECORDING,
 | |
| 	DBG_BUS_STATE_STOPPED,
 | |
| 	MAX_DBG_BUS_STATES
 | |
| };
 | |
| 
 | |
| /* Debug Bus Storm modes */
 | |
| enum dbg_bus_storm_modes {
 | |
| 	DBG_BUS_STORM_MODE_PRINTF,
 | |
| 	DBG_BUS_STORM_MODE_PRAM_ADDR,
 | |
| 	DBG_BUS_STORM_MODE_DRA_RW,
 | |
| 	DBG_BUS_STORM_MODE_DRA_W,
 | |
| 	DBG_BUS_STORM_MODE_LD_ST_ADDR,
 | |
| 	DBG_BUS_STORM_MODE_DRA_FSM,
 | |
| 	DBG_BUS_STORM_MODE_FAST_DBGMUX,
 | |
| 	DBG_BUS_STORM_MODE_RH,
 | |
| 	DBG_BUS_STORM_MODE_RH_WITH_STORE,
 | |
| 	DBG_BUS_STORM_MODE_FOC,
 | |
| 	DBG_BUS_STORM_MODE_EXT_STORE,
 | |
| 	MAX_DBG_BUS_STORM_MODES
 | |
| };
 | |
| 
 | |
| /* Debug bus target IDs */
 | |
| enum dbg_bus_targets {
 | |
| 	DBG_BUS_TARGET_ID_INT_BUF,
 | |
| 	DBG_BUS_TARGET_ID_NIG,
 | |
| 	DBG_BUS_TARGET_ID_PCI,
 | |
| 	MAX_DBG_BUS_TARGETS
 | |
| };
 | |
| 
 | |
| /* GRC Dump data */
 | |
| struct dbg_grc_data {
 | |
| 	u8 params_initialized;
 | |
| 	u8 reserved1;
 | |
| 	u16 reserved2;
 | |
| 	u32 param_val[48];
 | |
| };
 | |
| 
 | |
| /* Debug GRC params */
 | |
| enum dbg_grc_params {
 | |
| 	DBG_GRC_PARAM_DUMP_TSTORM,
 | |
| 	DBG_GRC_PARAM_DUMP_MSTORM,
 | |
| 	DBG_GRC_PARAM_DUMP_USTORM,
 | |
| 	DBG_GRC_PARAM_DUMP_XSTORM,
 | |
| 	DBG_GRC_PARAM_DUMP_YSTORM,
 | |
| 	DBG_GRC_PARAM_DUMP_PSTORM,
 | |
| 	DBG_GRC_PARAM_DUMP_REGS,
 | |
| 	DBG_GRC_PARAM_DUMP_RAM,
 | |
| 	DBG_GRC_PARAM_DUMP_PBUF,
 | |
| 	DBG_GRC_PARAM_DUMP_IOR,
 | |
| 	DBG_GRC_PARAM_DUMP_VFC,
 | |
| 	DBG_GRC_PARAM_DUMP_CM_CTX,
 | |
| 	DBG_GRC_PARAM_DUMP_PXP,
 | |
| 	DBG_GRC_PARAM_DUMP_RSS,
 | |
| 	DBG_GRC_PARAM_DUMP_CAU,
 | |
| 	DBG_GRC_PARAM_DUMP_QM,
 | |
| 	DBG_GRC_PARAM_DUMP_MCP,
 | |
| 	DBG_GRC_PARAM_DUMP_DORQ,
 | |
| 	DBG_GRC_PARAM_DUMP_CFC,
 | |
| 	DBG_GRC_PARAM_DUMP_IGU,
 | |
| 	DBG_GRC_PARAM_DUMP_BRB,
 | |
| 	DBG_GRC_PARAM_DUMP_BTB,
 | |
| 	DBG_GRC_PARAM_DUMP_BMB,
 | |
| 	DBG_GRC_PARAM_RESERVD1,
 | |
| 	DBG_GRC_PARAM_DUMP_MULD,
 | |
| 	DBG_GRC_PARAM_DUMP_PRS,
 | |
| 	DBG_GRC_PARAM_DUMP_DMAE,
 | |
| 	DBG_GRC_PARAM_DUMP_TM,
 | |
| 	DBG_GRC_PARAM_DUMP_SDM,
 | |
| 	DBG_GRC_PARAM_DUMP_DIF,
 | |
| 	DBG_GRC_PARAM_DUMP_STATIC,
 | |
| 	DBG_GRC_PARAM_UNSTALL,
 | |
| 	DBG_GRC_PARAM_RESERVED2,
 | |
| 	DBG_GRC_PARAM_MCP_TRACE_META_SIZE,
 | |
| 	DBG_GRC_PARAM_EXCLUDE_ALL,
 | |
| 	DBG_GRC_PARAM_CRASH,
 | |
| 	DBG_GRC_PARAM_PARITY_SAFE,
 | |
| 	DBG_GRC_PARAM_DUMP_CM,
 | |
| 	DBG_GRC_PARAM_DUMP_PHY,
 | |
| 	DBG_GRC_PARAM_NO_MCP,
 | |
| 	DBG_GRC_PARAM_NO_FW_VER,
 | |
| 	DBG_GRC_PARAM_RESERVED3,
 | |
| 	DBG_GRC_PARAM_DUMP_MCP_HW_DUMP,
 | |
| 	DBG_GRC_PARAM_DUMP_ILT_CDUC,
 | |
| 	DBG_GRC_PARAM_DUMP_ILT_CDUT,
 | |
| 	DBG_GRC_PARAM_DUMP_CAU_EXT,
 | |
| 	MAX_DBG_GRC_PARAMS
 | |
| };
 | |
| 
 | |
| /* Debug status codes */
 | |
| enum dbg_status {
 | |
| 	DBG_STATUS_OK,
 | |
| 	DBG_STATUS_APP_VERSION_NOT_SET,
 | |
| 	DBG_STATUS_UNSUPPORTED_APP_VERSION,
 | |
| 	DBG_STATUS_DBG_BLOCK_NOT_RESET,
 | |
| 	DBG_STATUS_INVALID_ARGS,
 | |
| 	DBG_STATUS_OUTPUT_ALREADY_SET,
 | |
| 	DBG_STATUS_INVALID_PCI_BUF_SIZE,
 | |
| 	DBG_STATUS_PCI_BUF_ALLOC_FAILED,
 | |
| 	DBG_STATUS_PCI_BUF_NOT_ALLOCATED,
 | |
| 	DBG_STATUS_INVALID_FILTER_TRIGGER_DWORDS,
 | |
| 	DBG_STATUS_NO_MATCHING_FRAMING_MODE,
 | |
| 	DBG_STATUS_VFC_READ_ERROR,
 | |
| 	DBG_STATUS_STORM_ALREADY_ENABLED,
 | |
| 	DBG_STATUS_STORM_NOT_ENABLED,
 | |
| 	DBG_STATUS_BLOCK_ALREADY_ENABLED,
 | |
| 	DBG_STATUS_BLOCK_NOT_ENABLED,
 | |
| 	DBG_STATUS_NO_INPUT_ENABLED,
 | |
| 	DBG_STATUS_NO_FILTER_TRIGGER_256B,
 | |
| 	DBG_STATUS_FILTER_ALREADY_ENABLED,
 | |
| 	DBG_STATUS_TRIGGER_ALREADY_ENABLED,
 | |
| 	DBG_STATUS_TRIGGER_NOT_ENABLED,
 | |
| 	DBG_STATUS_CANT_ADD_CONSTRAINT,
 | |
| 	DBG_STATUS_TOO_MANY_TRIGGER_STATES,
 | |
| 	DBG_STATUS_TOO_MANY_CONSTRAINTS,
 | |
| 	DBG_STATUS_RECORDING_NOT_STARTED,
 | |
| 	DBG_STATUS_DATA_DIDNT_TRIGGER,
 | |
| 	DBG_STATUS_NO_DATA_RECORDED,
 | |
| 	DBG_STATUS_DUMP_BUF_TOO_SMALL,
 | |
| 	DBG_STATUS_DUMP_NOT_CHUNK_ALIGNED,
 | |
| 	DBG_STATUS_UNKNOWN_CHIP,
 | |
| 	DBG_STATUS_VIRT_MEM_ALLOC_FAILED,
 | |
| 	DBG_STATUS_BLOCK_IN_RESET,
 | |
| 	DBG_STATUS_INVALID_TRACE_SIGNATURE,
 | |
| 	DBG_STATUS_INVALID_NVRAM_BUNDLE,
 | |
| 	DBG_STATUS_NVRAM_GET_IMAGE_FAILED,
 | |
| 	DBG_STATUS_NON_ALIGNED_NVRAM_IMAGE,
 | |
| 	DBG_STATUS_NVRAM_READ_FAILED,
 | |
| 	DBG_STATUS_IDLE_CHK_PARSE_FAILED,
 | |
| 	DBG_STATUS_MCP_TRACE_BAD_DATA,
 | |
| 	DBG_STATUS_MCP_TRACE_NO_META,
 | |
| 	DBG_STATUS_MCP_COULD_NOT_HALT,
 | |
| 	DBG_STATUS_MCP_COULD_NOT_RESUME,
 | |
| 	DBG_STATUS_RESERVED0,
 | |
| 	DBG_STATUS_SEMI_FIFO_NOT_EMPTY,
 | |
| 	DBG_STATUS_IGU_FIFO_BAD_DATA,
 | |
| 	DBG_STATUS_MCP_COULD_NOT_MASK_PRTY,
 | |
| 	DBG_STATUS_FW_ASSERTS_PARSE_FAILED,
 | |
| 	DBG_STATUS_REG_FIFO_BAD_DATA,
 | |
| 	DBG_STATUS_PROTECTION_OVERRIDE_BAD_DATA,
 | |
| 	DBG_STATUS_DBG_ARRAY_NOT_SET,
 | |
| 	DBG_STATUS_RESERVED1,
 | |
| 	DBG_STATUS_NON_MATCHING_LINES,
 | |
| 	DBG_STATUS_INSUFFICIENT_HW_IDS,
 | |
| 	DBG_STATUS_DBG_BUS_IN_USE,
 | |
| 	DBG_STATUS_INVALID_STORM_DBG_MODE,
 | |
| 	DBG_STATUS_OTHER_ENGINE_BB_ONLY,
 | |
| 	DBG_STATUS_FILTER_SINGLE_HW_ID,
 | |
| 	DBG_STATUS_TRIGGER_SINGLE_HW_ID,
 | |
| 	DBG_STATUS_MISSING_TRIGGER_STATE_STORM,
 | |
| 	MAX_DBG_STATUS
 | |
| };
 | |
| 
 | |
| /* Debug Storms IDs */
 | |
| enum dbg_storms {
 | |
| 	DBG_TSTORM_ID,
 | |
| 	DBG_MSTORM_ID,
 | |
| 	DBG_USTORM_ID,
 | |
| 	DBG_XSTORM_ID,
 | |
| 	DBG_YSTORM_ID,
 | |
| 	DBG_PSTORM_ID,
 | |
| 	MAX_DBG_STORMS
 | |
| };
 | |
| 
 | |
| /* Idle Check data */
 | |
| struct idle_chk_data {
 | |
| 	u32 buf_size;
 | |
| 	u8 buf_size_set;
 | |
| 	u8 reserved1;
 | |
| 	u16 reserved2;
 | |
| };
 | |
| 
 | |
| struct pretend_params {
 | |
| 	u8 split_type;
 | |
| 	u8 reserved;
 | |
| 	u16 split_id;
 | |
| };
 | |
| 
 | |
| /* Debug Tools data (per HW function)
 | |
|  */
 | |
| struct dbg_tools_data {
 | |
| 	struct dbg_grc_data grc;
 | |
| 	struct dbg_bus_data bus;
 | |
| 	struct idle_chk_data idle_chk;
 | |
| 	u8 mode_enable[40];
 | |
| 	u8 block_in_reset[132];
 | |
| 	u8 chip_id;
 | |
| 	u8 hw_type;
 | |
| 	u8 num_ports;
 | |
| 	u8 num_pfs_per_port;
 | |
| 	u8 num_vfs;
 | |
| 	u8 initialized;
 | |
| 	u8 use_dmae;
 | |
| 	u8 reserved;
 | |
| 	struct pretend_params pretend;
 | |
| 	u32 num_regs_read;
 | |
| };
 | |
| 
 | |
| /* ILT Clients */
 | |
| enum ilt_clients {
 | |
| 	ILT_CLI_CDUC,
 | |
| 	ILT_CLI_CDUT,
 | |
| 	ILT_CLI_QM,
 | |
| 	ILT_CLI_TM,
 | |
| 	ILT_CLI_SRC,
 | |
| 	ILT_CLI_TSDM,
 | |
| 	ILT_CLI_RGFS,
 | |
| 	ILT_CLI_TGFS,
 | |
| 	MAX_ILT_CLIENTS
 | |
| };
 | |
| 
 | |
| /***************************** Public Functions *******************************/
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_set_bin_ptr(): Sets a pointer to the binary data with debug
 | |
|  *                        arrays.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @bin_ptr: A pointer to the binary data with debug arrays.
 | |
|  *
 | |
|  * Return: enum dbg status.
 | |
|  */
 | |
| enum dbg_status qed_dbg_set_bin_ptr(struct qed_hwfn *p_hwfn,
 | |
| 				    const u8 * const bin_ptr);
 | |
| 
 | |
| /**
 | |
|  * qed_read_regs(): Reads registers into a buffer (using GRC).
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @buf: Destination buffer.
 | |
|  * @addr: Source GRC address in dwords.
 | |
|  * @len: Number of registers to read.
 | |
|  *
 | |
|  * Return: Void.
 | |
|  */
 | |
| void qed_read_regs(struct qed_hwfn *p_hwfn,
 | |
| 		   struct qed_ptt *p_ptt, u32 *buf, u32 addr, u32 len);
 | |
| 
 | |
| /**
 | |
|  * qed_read_fw_info(): Reads FW info from the chip.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @fw_info: (Out) a pointer to write the FW info into.
 | |
|  *
 | |
|  * Return: True if the FW info was read successfully from one of the Storms,
 | |
|  * or false if all Storms are in reset.
 | |
|  *
 | |
|  * The FW info contains FW-related information, such as the FW version,
 | |
|  * FW image (main/L2B/kuku), FW timestamp, etc.
 | |
|  * The FW info is read from the internal RAM of the first Storm that is not in
 | |
|  * reset.
 | |
|  */
 | |
| bool qed_read_fw_info(struct qed_hwfn *p_hwfn,
 | |
| 		      struct qed_ptt *p_ptt, struct fw_info *fw_info);
 | |
| /**
 | |
|  * qed_dbg_grc_config(): Sets the value of a GRC parameter.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @grc_param: GRC parameter.
 | |
|  * @val: Value to set.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set.
 | |
|  *         - Grc_param is invalid.
 | |
|  *         - Val is outside the allowed boundaries.
 | |
|  */
 | |
| enum dbg_status qed_dbg_grc_config(struct qed_hwfn *p_hwfn,
 | |
| 				   enum dbg_grc_params grc_param, u32 val);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_grc_set_params_default(): Reverts all GRC parameters to their
 | |
|  *                                   default value.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  *
 | |
|  * Return: Void.
 | |
|  */
 | |
| void qed_dbg_grc_set_params_default(struct qed_hwfn *p_hwfn);
 | |
| /**
 | |
|  * qed_dbg_grc_get_dump_buf_size(): Returns the required buffer size for
 | |
|  *                                  GRC Dump.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @buf_size: (OUT) required buffer size (in dwords) for the GRC Dump
 | |
|  *             data.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_grc_get_dump_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 					      struct qed_ptt *p_ptt,
 | |
| 					      u32 *buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_grc_dump(): Dumps GRC data into the specified buffer.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @dump_buf: Pointer to write the collected GRC data into.
 | |
|  * @buf_size_in_dwords:Size of the specified buffer in dwords.
 | |
|  * @num_dumped_dwords: (OUT) number of dumped dwords.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *        - The version wasn't set.
 | |
|  *        - The specified dump buffer is too small.
 | |
|  *          Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_grc_dump(struct qed_hwfn *p_hwfn,
 | |
| 				 struct qed_ptt *p_ptt,
 | |
| 				 u32 *dump_buf,
 | |
| 				 u32 buf_size_in_dwords,
 | |
| 				 u32 *num_dumped_dwords);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_idle_chk_get_dump_buf_size(): Returns the required buffer size
 | |
|  *                                       for idle check results.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @buf_size: (OUT) required buffer size (in dwords) for the idle check
 | |
|  *             data.
 | |
|  *
 | |
|  * return: Error if one of the following holds:
 | |
|  *        - The version wasn't set.
 | |
|  *          Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_idle_chk_get_dump_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						   struct qed_ptt *p_ptt,
 | |
| 						   u32 *buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_idle_chk_dump: Performs idle check and writes the results
 | |
|  *                        into the specified buffer.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @dump_buf: Pointer to write the idle check data into.
 | |
|  * @buf_size_in_dwords: Size of the specified buffer in dwords.
 | |
|  * @num_dumped_dwords: (OUT) number of dumped dwords.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set.
 | |
|  *         - The specified buffer is too small.
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_idle_chk_dump(struct qed_hwfn *p_hwfn,
 | |
| 				      struct qed_ptt *p_ptt,
 | |
| 				      u32 *dump_buf,
 | |
| 				      u32 buf_size_in_dwords,
 | |
| 				      u32 *num_dumped_dwords);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_mcp_trace_get_dump_buf_size(): Returns the required buffer size
 | |
|  *                                        for mcp trace results.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @buf_size: (OUT) Required buffer size (in dwords) for mcp trace data.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set.
 | |
|  *         - The trace data in MCP scratchpad contain an invalid signature.
 | |
|  *         - The bundle ID in NVRAM is invalid.
 | |
|  *         - The trace meta data cannot be found (in NVRAM or image file).
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_mcp_trace_get_dump_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						    struct qed_ptt *p_ptt,
 | |
| 						    u32 *buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_mcp_trace_dump(): Performs mcp trace and writes the results
 | |
|  *                           into the specified buffer.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @dump_buf: Pointer to write the mcp trace data into.
 | |
|  * @buf_size_in_dwords: Size of the specified buffer in dwords.
 | |
|  * @num_dumped_dwords: (OUT) number of dumped dwords.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *        - The version wasn't set.
 | |
|  *        - The specified buffer is too small.
 | |
|  *        - The trace data in MCP scratchpad contain an invalid signature.
 | |
|  *        - The bundle ID in NVRAM is invalid.
 | |
|  *        - The trace meta data cannot be found (in NVRAM or image file).
 | |
|  *        - The trace meta data cannot be read (from NVRAM or image file).
 | |
|  *          Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_mcp_trace_dump(struct qed_hwfn *p_hwfn,
 | |
| 				       struct qed_ptt *p_ptt,
 | |
| 				       u32 *dump_buf,
 | |
| 				       u32 buf_size_in_dwords,
 | |
| 				       u32 *num_dumped_dwords);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_reg_fifo_get_dump_buf_size(): Returns the required buffer size
 | |
|  *                                       for grc trace fifo results.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @buf_size: (OUT) Required buffer size (in dwords) for reg fifo data.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_reg_fifo_get_dump_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						   struct qed_ptt *p_ptt,
 | |
| 						   u32 *buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_reg_fifo_dump(): Reads the reg fifo and writes the results into
 | |
|  *                          the specified buffer.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @dump_buf: Pointer to write the reg fifo data into.
 | |
|  * @buf_size_in_dwords: Size of the specified buffer in dwords.
 | |
|  * @num_dumped_dwords: (OUT) number of dumped dwords.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *        - The version wasn't set.
 | |
|  *        - The specified buffer is too small.
 | |
|  *        - DMAE transaction failed.
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_reg_fifo_dump(struct qed_hwfn *p_hwfn,
 | |
| 				      struct qed_ptt *p_ptt,
 | |
| 				      u32 *dump_buf,
 | |
| 				      u32 buf_size_in_dwords,
 | |
| 				      u32 *num_dumped_dwords);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_igu_fifo_get_dump_buf_size(): Returns the required buffer size
 | |
|  *                                       for the IGU fifo results.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @buf_size: (OUT) Required buffer size (in dwords) for the IGU fifo
 | |
|  *            data.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set.
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_igu_fifo_get_dump_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						   struct qed_ptt *p_ptt,
 | |
| 						   u32 *buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_igu_fifo_dump(): Reads the IGU fifo and writes the results into
 | |
|  *                          the specified buffer.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @dump_buf: Pointer to write the IGU fifo data into.
 | |
|  * @buf_size_in_dwords: Size of the specified buffer in dwords.
 | |
|  * @num_dumped_dwords: (OUT) number of dumped dwords.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set
 | |
|  *         - The specified buffer is too small
 | |
|  *         - DMAE transaction failed
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_igu_fifo_dump(struct qed_hwfn *p_hwfn,
 | |
| 				      struct qed_ptt *p_ptt,
 | |
| 				      u32 *dump_buf,
 | |
| 				      u32 buf_size_in_dwords,
 | |
| 				      u32 *num_dumped_dwords);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_protection_override_get_dump_buf_size(): Returns the required
 | |
|  *        buffer size for protection override window results.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @buf_size: (OUT) Required buffer size (in dwords) for protection
 | |
|  *             override data.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status
 | |
| qed_dbg_protection_override_get_dump_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 					      struct qed_ptt *p_ptt,
 | |
| 					      u32 *buf_size);
 | |
| /**
 | |
|  * qed_dbg_protection_override_dump(): Reads protection override window
 | |
|  *       entries and writes the results into the specified buffer.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @dump_buf: Pointer to write the protection override data into.
 | |
|  * @buf_size_in_dwords: Size of the specified buffer in dwords.
 | |
|  * @num_dumped_dwords: (OUT) number of dumped dwords.
 | |
|  *
 | |
|  * @return: Error if one of the following holds:
 | |
|  *          - The version wasn't set.
 | |
|  *          - The specified buffer is too small.
 | |
|  *          - DMAE transaction failed.
 | |
|  *             Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_protection_override_dump(struct qed_hwfn *p_hwfn,
 | |
| 						 struct qed_ptt *p_ptt,
 | |
| 						 u32 *dump_buf,
 | |
| 						 u32 buf_size_in_dwords,
 | |
| 						 u32 *num_dumped_dwords);
 | |
| /**
 | |
|  * qed_dbg_fw_asserts_get_dump_buf_size(): Returns the required buffer
 | |
|  *                                         size for FW Asserts results.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @buf_size: (OUT) Required buffer size (in dwords) for FW Asserts data.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set.
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_fw_asserts_get_dump_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						     struct qed_ptt *p_ptt,
 | |
| 						     u32 *buf_size);
 | |
| /**
 | |
|  * qed_dbg_fw_asserts_dump(): Reads the FW Asserts and writes the results
 | |
|  *                            into the specified buffer.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @dump_buf: Pointer to write the FW Asserts data into.
 | |
|  * @buf_size_in_dwords: Size of the specified buffer in dwords.
 | |
|  * @num_dumped_dwords: (OUT) number of dumped dwords.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set.
 | |
|  *         - The specified buffer is too small.
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_fw_asserts_dump(struct qed_hwfn *p_hwfn,
 | |
| 					struct qed_ptt *p_ptt,
 | |
| 					u32 *dump_buf,
 | |
| 					u32 buf_size_in_dwords,
 | |
| 					u32 *num_dumped_dwords);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_read_attn(): Reads the attention registers of the specified
 | |
|  * block and type, and writes the results into the specified buffer.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @p_ptt: Ptt window used for writing the registers.
 | |
|  * @block: Block ID.
 | |
|  * @attn_type: Attention type.
 | |
|  * @clear_status: Indicates if the attention status should be cleared.
 | |
|  * @results:  (OUT) Pointer to write the read results into.
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set
 | |
|  *          Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_read_attn(struct qed_hwfn *p_hwfn,
 | |
| 				  struct qed_ptt *p_ptt,
 | |
| 				  enum block_id block,
 | |
| 				  enum dbg_attn_type attn_type,
 | |
| 				  bool clear_status,
 | |
| 				  struct dbg_attn_block_result *results);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_print_attn(): Prints attention registers values in the
 | |
|  *                       specified results struct.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @results: Pointer to the attention read results
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *        - The version wasn't set
 | |
|  *          Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_print_attn(struct qed_hwfn *p_hwfn,
 | |
| 				   struct dbg_attn_block_result *results);
 | |
| 
 | |
| /******************************* Data Types **********************************/
 | |
| 
 | |
| struct mcp_trace_format {
 | |
| 	u32 data;
 | |
| #define MCP_TRACE_FORMAT_MODULE_MASK	0x0000ffff
 | |
| #define MCP_TRACE_FORMAT_MODULE_OFFSET	0
 | |
| #define MCP_TRACE_FORMAT_LEVEL_MASK	0x00030000
 | |
| #define MCP_TRACE_FORMAT_LEVEL_OFFSET	16
 | |
| #define MCP_TRACE_FORMAT_P1_SIZE_MASK	0x000c0000
 | |
| #define MCP_TRACE_FORMAT_P1_SIZE_OFFSET 18
 | |
| #define MCP_TRACE_FORMAT_P2_SIZE_MASK	0x00300000
 | |
| #define MCP_TRACE_FORMAT_P2_SIZE_OFFSET 20
 | |
| #define MCP_TRACE_FORMAT_P3_SIZE_MASK	0x00c00000
 | |
| #define MCP_TRACE_FORMAT_P3_SIZE_OFFSET 22
 | |
| #define MCP_TRACE_FORMAT_LEN_MASK	0xff000000
 | |
| #define MCP_TRACE_FORMAT_LEN_OFFSET	24
 | |
| 
 | |
| 	char *format_str;
 | |
| };
 | |
| 
 | |
| /* MCP Trace Meta data structure */
 | |
| struct mcp_trace_meta {
 | |
| 	u32 modules_num;
 | |
| 	char **modules;
 | |
| 	u32 formats_num;
 | |
| 	struct mcp_trace_format *formats;
 | |
| 	bool is_allocated;
 | |
| };
 | |
| 
 | |
| /* Debug Tools user data */
 | |
| struct dbg_tools_user_data {
 | |
| 	struct mcp_trace_meta mcp_trace_meta;
 | |
| 	const u32 *mcp_trace_user_meta_buf;
 | |
| };
 | |
| 
 | |
| /******************************** Constants **********************************/
 | |
| 
 | |
| #define MAX_NAME_LEN	16
 | |
| 
 | |
| /***************************** Public Functions *******************************/
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_user_set_bin_ptr(): Sets a pointer to the binary data with
 | |
|  *                             debug arrays.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @bin_ptr: a pointer to the binary data with debug arrays.
 | |
|  *
 | |
|  * Return: dbg_status.
 | |
|  */
 | |
| enum dbg_status qed_dbg_user_set_bin_ptr(struct qed_hwfn *p_hwfn,
 | |
| 					 const u8 * const bin_ptr);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_alloc_user_data(): Allocates user debug data.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @user_data_ptr: (OUT) a pointer to the allocated memory.
 | |
|  *
 | |
|  * Return: dbg_status.
 | |
|  */
 | |
| enum dbg_status qed_dbg_alloc_user_data(struct qed_hwfn *p_hwfn,
 | |
| 					void **user_data_ptr);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_get_status_str(): Returns a string for the specified status.
 | |
|  *
 | |
|  * @status: A debug status code.
 | |
|  *
 | |
|  * Return: A string for the specified status.
 | |
|  */
 | |
| const char *qed_dbg_get_status_str(enum dbg_status status);
 | |
| 
 | |
| /**
 | |
|  * qed_get_idle_chk_results_buf_size(): Returns the required buffer size
 | |
|  *                                      for idle check results (in bytes).
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: idle check dump buffer.
 | |
|  * @num_dumped_dwords: number of dwords that were dumped.
 | |
|  * @results_buf_size: (OUT) required buffer size (in bytes) for the parsed
 | |
|  *                    results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_get_idle_chk_results_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						  u32 *dump_buf,
 | |
| 						  u32  num_dumped_dwords,
 | |
| 						  u32 *results_buf_size);
 | |
| /**
 | |
|  * qed_print_idle_chk_results(): Prints idle check results
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: idle check dump buffer.
 | |
|  * @num_dumped_dwords: number of dwords that were dumped.
 | |
|  * @results_buf: buffer for printing the idle check results.
 | |
|  * @num_errors: (OUT) number of errors found in idle check.
 | |
|  * @num_warnings: (OUT) number of warnings found in idle check.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_print_idle_chk_results(struct qed_hwfn *p_hwfn,
 | |
| 					   u32 *dump_buf,
 | |
| 					   u32 num_dumped_dwords,
 | |
| 					   char *results_buf,
 | |
| 					   u32 *num_errors,
 | |
| 					   u32 *num_warnings);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_mcp_trace_set_meta_data(): Sets the MCP Trace meta data.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @meta_buf: Meta buffer.
 | |
|  *
 | |
|  * Return: Void.
 | |
|  *
 | |
|  * Needed in case the MCP Trace dump doesn't contain the meta data (e.g. due to
 | |
|  * no NVRAM access).
 | |
|  */
 | |
| void qed_dbg_mcp_trace_set_meta_data(struct qed_hwfn *p_hwfn,
 | |
| 				     const u32 *meta_buf);
 | |
| 
 | |
| /**
 | |
|  * qed_get_mcp_trace_results_buf_size(): Returns the required buffer size
 | |
|  *                                       for MCP Trace results (in bytes).
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: MCP Trace dump buffer.
 | |
|  * @num_dumped_dwords: number of dwords that were dumped.
 | |
|  * @results_buf_size: (OUT) required buffer size (in bytes) for the parsed
 | |
|  *                    results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_get_mcp_trace_results_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						   u32 *dump_buf,
 | |
| 						   u32 num_dumped_dwords,
 | |
| 						   u32 *results_buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_print_mcp_trace_results(): Prints MCP Trace results
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: MCP trace dump buffer, starting from the header.
 | |
|  * @num_dumped_dwords: Member of dwords that were dumped.
 | |
|  * @results_buf: Buffer for printing the mcp trace results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_print_mcp_trace_results(struct qed_hwfn *p_hwfn,
 | |
| 					    u32 *dump_buf,
 | |
| 					    u32 num_dumped_dwords,
 | |
| 					    char *results_buf);
 | |
| 
 | |
| /**
 | |
|  * qed_print_mcp_trace_results_cont(): Prints MCP Trace results, and
 | |
|  * keeps the MCP trace meta data allocated, to support continuous MCP Trace
 | |
|  * parsing. After the continuous parsing ends, mcp_trace_free_meta_data should
 | |
|  * be called to free the meta data.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: MVP trace dump buffer, starting from the header.
 | |
|  * @results_buf: Buffer for printing the mcp trace results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_print_mcp_trace_results_cont(struct qed_hwfn *p_hwfn,
 | |
| 						 u32 *dump_buf,
 | |
| 						 char *results_buf);
 | |
| 
 | |
| /**
 | |
|  * qed_print_mcp_trace_line(): Prints MCP Trace results for a single line
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: MCP trace dump buffer, starting from the header.
 | |
|  * @num_dumped_bytes: Number of bytes that were dumped.
 | |
|  * @results_buf: Buffer for printing the mcp trace results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_print_mcp_trace_line(struct qed_hwfn *p_hwfn,
 | |
| 					 u8 *dump_buf,
 | |
| 					 u32 num_dumped_bytes,
 | |
| 					 char *results_buf);
 | |
| 
 | |
| /**
 | |
|  * qed_mcp_trace_free_meta_data(): Frees the MCP Trace meta data.
 | |
|  * Should be called after continuous MCP Trace parsing.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  *
 | |
|  * Return: Void.
 | |
|  */
 | |
| void qed_mcp_trace_free_meta_data(struct qed_hwfn *p_hwfn);
 | |
| 
 | |
| /**
 | |
|  * qed_get_reg_fifo_results_buf_size(): Returns the required buffer size
 | |
|  *                                      for reg_fifo results (in bytes).
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: Reg fifo dump buffer.
 | |
|  * @num_dumped_dwords: Number of dwords that were dumped.
 | |
|  * @results_buf_size: (OUT) required buffer size (in bytes) for the parsed
 | |
|  *                     results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_get_reg_fifo_results_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						  u32 *dump_buf,
 | |
| 						  u32 num_dumped_dwords,
 | |
| 						  u32 *results_buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_print_reg_fifo_results(): Prints reg fifo results.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: Reg fifo dump buffer, starting from the header.
 | |
|  * @num_dumped_dwords: Number of dwords that were dumped.
 | |
|  * @results_buf: Buffer for printing the reg fifo results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_print_reg_fifo_results(struct qed_hwfn *p_hwfn,
 | |
| 					   u32 *dump_buf,
 | |
| 					   u32 num_dumped_dwords,
 | |
| 					   char *results_buf);
 | |
| 
 | |
| /**
 | |
|  * qed_get_igu_fifo_results_buf_size(): Returns the required buffer size
 | |
|  *                                      for igu_fifo results (in bytes).
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: IGU fifo dump buffer.
 | |
|  * @num_dumped_dwords: number of dwords that were dumped.
 | |
|  * @results_buf_size: (OUT) required buffer size (in bytes) for the parsed
 | |
|  *                    results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_get_igu_fifo_results_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						  u32 *dump_buf,
 | |
| 						  u32 num_dumped_dwords,
 | |
| 						  u32 *results_buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_print_igu_fifo_results(): Prints IGU fifo results
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: IGU fifo dump buffer, starting from the header.
 | |
|  * @num_dumped_dwords: Number of dwords that were dumped.
 | |
|  * @results_buf: Buffer for printing the IGU fifo results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_print_igu_fifo_results(struct qed_hwfn *p_hwfn,
 | |
| 					   u32 *dump_buf,
 | |
| 					   u32 num_dumped_dwords,
 | |
| 					   char *results_buf);
 | |
| 
 | |
| /**
 | |
|  * qed_get_protection_override_results_buf_size(): Returns the required
 | |
|  *         buffer size for protection override results (in bytes).
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: Protection override dump buffer.
 | |
|  * @num_dumped_dwords: Number of dwords that were dumped.
 | |
|  * @results_buf_size: (OUT) required buffer size (in bytes) for the parsed
 | |
|  *                    results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status
 | |
| qed_get_protection_override_results_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 					     u32 *dump_buf,
 | |
| 					     u32 num_dumped_dwords,
 | |
| 					     u32 *results_buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_print_protection_override_results(): Prints protection override
 | |
|  *                                          results.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: Protection override dump buffer, starting from the header.
 | |
|  * @num_dumped_dwords: Number of dwords that were dumped.
 | |
|  * @results_buf: Buffer for printing the reg fifo results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_print_protection_override_results(struct qed_hwfn *p_hwfn,
 | |
| 						      u32 *dump_buf,
 | |
| 						      u32 num_dumped_dwords,
 | |
| 						      char *results_buf);
 | |
| 
 | |
| /**
 | |
|  * qed_get_fw_asserts_results_buf_size(): Returns the required buffer size
 | |
|  *                                        for FW Asserts results (in bytes).
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: FW Asserts dump buffer.
 | |
|  * @num_dumped_dwords: number of dwords that were dumped.
 | |
|  * @results_buf_size: (OUT) required buffer size (in bytes) for the parsed
 | |
|  *                    results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_get_fw_asserts_results_buf_size(struct qed_hwfn *p_hwfn,
 | |
| 						    u32 *dump_buf,
 | |
| 						    u32 num_dumped_dwords,
 | |
| 						    u32 *results_buf_size);
 | |
| 
 | |
| /**
 | |
|  * qed_print_fw_asserts_results(): Prints FW Asserts results.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @dump_buf: FW Asserts dump buffer, starting from the header.
 | |
|  * @num_dumped_dwords: number of dwords that were dumped.
 | |
|  * @results_buf: buffer for printing the FW Asserts results.
 | |
|  *
 | |
|  * Return: Error if the parsing fails, ok otherwise.
 | |
|  */
 | |
| enum dbg_status qed_print_fw_asserts_results(struct qed_hwfn *p_hwfn,
 | |
| 					     u32 *dump_buf,
 | |
| 					     u32 num_dumped_dwords,
 | |
| 					     char *results_buf);
 | |
| 
 | |
| /**
 | |
|  * qed_dbg_parse_attn(): Parses and prints attention registers values in
 | |
|  *                      the specified results struct.
 | |
|  *
 | |
|  * @p_hwfn: HW device data.
 | |
|  * @results: Pointer to the attention read results
 | |
|  *
 | |
|  * Return: Error if one of the following holds:
 | |
|  *         - The version wasn't set.
 | |
|  *           Otherwise, returns ok.
 | |
|  */
 | |
| enum dbg_status qed_dbg_parse_attn(struct qed_hwfn *p_hwfn,
 | |
| 				   struct dbg_attn_block_result *results);
 | |
| #endif
 |