linux/drivers/net/ethernet/broadcom/bnx2x/bnx2x_fw_defs.h

/* bnx2x_fw_defs.h: Qlogic Everest network driver.
 *
 * Copyright (c) 2007-2013 Broadcom Corporation
 * Copyright (c) 2014 QLogic Corporation
 * All rights reserved
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation.
 */

#ifndef BNX2X_FW_DEFS_H
#define BNX2X_FW_DEFS_H

#define CSTORM_ASSERT_LIST_INDEX_OFFSET
#define CSTORM_ASSERT_LIST_OFFSET(assertListEntry)
#define CSTORM_EVENT_RING_DATA_OFFSET(pfId)
#define CSTORM_EVENT_RING_PROD_OFFSET(pfId)
#define CSTORM_FINAL_CLEANUP_COMPLETE_OFFSET(funcId)
#define CSTORM_FUNC_EN_OFFSET(funcId)
#define CSTORM_HC_SYNC_LINE_INDEX_E1X_OFFSET(hcIndex, sbId)
#define CSTORM_HC_SYNC_LINE_INDEX_E2_OFFSET(hcIndex, sbId)
#define CSTORM_IGU_MODE_OFFSET
#define CSTORM_ISCSI_CQ_SIZE_OFFSET(pfId)
#define CSTORM_ISCSI_CQ_SQN_SIZE_OFFSET(pfId)
#define CSTORM_ISCSI_EQ_CONS_OFFSET(pfId, iscsiEqId)
#define CSTORM_ISCSI_EQ_NEXT_EQE_ADDR_OFFSET(pfId, iscsiEqId)
#define CSTORM_ISCSI_EQ_NEXT_PAGE_ADDR_OFFSET(pfId, iscsiEqId)
#define CSTORM_ISCSI_EQ_NEXT_PAGE_ADDR_VALID_OFFSET(pfId, iscsiEqId)
#define CSTORM_ISCSI_EQ_PROD_OFFSET(pfId, iscsiEqId)
#define CSTORM_ISCSI_EQ_SB_INDEX_OFFSET(pfId, iscsiEqId)
#define CSTORM_ISCSI_EQ_SB_NUM_OFFSET(pfId, iscsiEqId)
#define CSTORM_ISCSI_HQ_SIZE_OFFSET(pfId)
#define CSTORM_ISCSI_NUM_OF_TASKS_OFFSET(pfId)
#define CSTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(pfId)
#define CSTORM_ISCSI_PAGE_SIZE_OFFSET(pfId)
#define CSTORM_RECORD_SLOW_PATH_OFFSET(funcId)
#define CSTORM_SP_STATUS_BLOCK_DATA_OFFSET(pfId)
#define CSTORM_SP_STATUS_BLOCK_DATA_STATE_OFFSET(pfId)
#define CSTORM_SP_STATUS_BLOCK_OFFSET(pfId)
#define CSTORM_SP_STATUS_BLOCK_SIZE
#define CSTORM_SP_SYNC_BLOCK_OFFSET(pfId)
#define CSTORM_SP_SYNC_BLOCK_SIZE
#define CSTORM_STATUS_BLOCK_DATA_FLAGS_OFFSET(sbId, hcIndex)
#define CSTORM_STATUS_BLOCK_DATA_OFFSET(sbId)
#define CSTORM_STATUS_BLOCK_DATA_STATE_OFFSET(sbId)
#define CSTORM_STATUS_BLOCK_DATA_TIMEOUT_OFFSET(sbId, hcIndex)
#define CSTORM_STATUS_BLOCK_OFFSET(sbId)
#define CSTORM_STATUS_BLOCK_SIZE
#define CSTORM_SYNC_BLOCK_OFFSET(sbId)
#define CSTORM_SYNC_BLOCK_SIZE
#define CSTORM_VF_PF_CHANNEL_STATE_OFFSET(vfId)
#define CSTORM_VF_PF_CHANNEL_VALID_OFFSET(vfId)
#define CSTORM_VF_TO_PF_OFFSET(funcId)
#define TSTORM_APPROXIMATE_MATCH_MULTICAST_FILTERING_OFFSET(pfId)
#define TSTORM_ASSERT_LIST_INDEX_OFFSET
#define TSTORM_ASSERT_LIST_OFFSET(assertListEntry)
#define TSTORM_FUNCTION_COMMON_CONFIG_OFFSET(pfId)
#define TSTORM_FUNC_EN_OFFSET(funcId)
#define TSTORM_ISCSI_ERROR_BITMAP_OFFSET(pfId)
#define TSTORM_ISCSI_L2_ISCSI_OOO_CID_TABLE_OFFSET(pfId)
#define TSTORM_ISCSI_L2_ISCSI_OOO_CLIENT_ID_TABLE_OFFSET(pfId)
#define TSTORM_ISCSI_L2_ISCSI_OOO_PROD_OFFSET(pfId)
#define TSTORM_ISCSI_NUM_OF_TASKS_OFFSET(pfId)
#define TSTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(pfId)
#define TSTORM_ISCSI_PAGE_SIZE_OFFSET(pfId)
#define TSTORM_ISCSI_RQ_SIZE_OFFSET(pfId)
#define TSTORM_ISCSI_TCP_LOCAL_ADV_WND_OFFSET(pfId)
#define TSTORM_ISCSI_TCP_VARS_FLAGS_OFFSET(pfId)
#define TSTORM_ISCSI_TCP_VARS_LSB_LOCAL_MAC_ADDR_OFFSET(pfId)
#define TSTORM_ISCSI_TCP_VARS_MID_LOCAL_MAC_ADDR_OFFSET(pfId)
#define TSTORM_ISCSI_TCP_VARS_MSB_LOCAL_MAC_ADDR_OFFSET(pfId)
#define TSTORM_MAC_FILTER_CONFIG_OFFSET(pfId)
#define TSTORM_RECORD_SLOW_PATH_OFFSET(funcId)
#define TSTORM_TCP_MAX_CWND_OFFSET(pfId)
#define TSTORM_VF_TO_PF_OFFSET(funcId)
#define USTORM_AGG_DATA_OFFSET
#define USTORM_AGG_DATA_SIZE
#define USTORM_ASSERT_LIST_INDEX_OFFSET
#define USTORM_ASSERT_LIST_OFFSET(assertListEntry)
#define USTORM_ETH_PAUSE_ENABLED_OFFSET(portId)
#define USTORM_FCOE_EQ_PROD_OFFSET(pfId)
#define USTORM_FUNC_EN_OFFSET(funcId)
#define USTORM_ISCSI_CQ_SIZE_OFFSET(pfId)
#define USTORM_ISCSI_CQ_SQN_SIZE_OFFSET(pfId)
#define USTORM_ISCSI_ERROR_BITMAP_OFFSET(pfId)
#define USTORM_ISCSI_GLOBAL_BUF_PHYS_ADDR_OFFSET(pfId)
#define USTORM_ISCSI_NUM_OF_TASKS_OFFSET(pfId)
#define USTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(pfId)
#define USTORM_ISCSI_PAGE_SIZE_OFFSET(pfId)
#define USTORM_ISCSI_R2TQ_SIZE_OFFSET(pfId)
#define USTORM_ISCSI_RQ_BUFFER_SIZE_OFFSET(pfId)
#define USTORM_ISCSI_RQ_SIZE_OFFSET(pfId)
#define USTORM_MEM_WORKAROUND_ADDRESS_OFFSET(pfId)
#define USTORM_RECORD_SLOW_PATH_OFFSET(funcId)
#define USTORM_RX_PRODS_E1X_OFFSET(portId, clientId)
#define USTORM_RX_PRODS_E2_OFFSET(qzoneId)
#define USTORM_TPA_BTR_OFFSET
#define USTORM_TPA_BTR_SIZE
#define USTORM_VF_TO_PF_OFFSET(funcId)
#define XSTORM_AGG_INT_FINAL_CLEANUP_COMP_TYPE
#define XSTORM_AGG_INT_FINAL_CLEANUP_INDEX
#define XSTORM_ASSERT_LIST_INDEX_OFFSET
#define XSTORM_ASSERT_LIST_OFFSET(assertListEntry)
#define XSTORM_CMNG_PER_PORT_VARS_OFFSET(portId)
#define XSTORM_FAIRNESS_PER_VN_VARS_OFFSET(pfId)
#define XSTORM_FUNC_EN_OFFSET(funcId)
#define XSTORM_ISCSI_HQ_SIZE_OFFSET(pfId)
#define XSTORM_ISCSI_LOCAL_MAC_ADDR0_OFFSET(pfId)
#define XSTORM_ISCSI_LOCAL_MAC_ADDR1_OFFSET(pfId)
#define XSTORM_ISCSI_LOCAL_MAC_ADDR2_OFFSET(pfId)
#define XSTORM_ISCSI_LOCAL_MAC_ADDR3_OFFSET(pfId)
#define XSTORM_ISCSI_LOCAL_MAC_ADDR4_OFFSET(pfId)
#define XSTORM_ISCSI_LOCAL_MAC_ADDR5_OFFSET(pfId)
#define XSTORM_ISCSI_LOCAL_VLAN_OFFSET(pfId)
#define XSTORM_ISCSI_NUM_OF_TASKS_OFFSET(pfId)
#define XSTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(pfId)
#define XSTORM_ISCSI_PAGE_SIZE_OFFSET(pfId)
#define XSTORM_ISCSI_R2TQ_SIZE_OFFSET(pfId)
#define XSTORM_ISCSI_SQ_SIZE_OFFSET(pfId)
#define XSTORM_ISCSI_TCP_VARS_ADV_WND_SCL_OFFSET(pfId)
#define XSTORM_ISCSI_TCP_VARS_FLAGS_OFFSET(pfId)
#define XSTORM_ISCSI_TCP_VARS_TOS_OFFSET(pfId)
#define XSTORM_ISCSI_TCP_VARS_TTL_OFFSET(pfId)
#define XSTORM_RATE_SHAPING_PER_VN_VARS_OFFSET(pfId)
#define XSTORM_RECORD_SLOW_PATH_OFFSET(funcId)
#define XSTORM_SPQ_DATA_OFFSET(funcId)
#define XSTORM_SPQ_DATA_SIZE
#define XSTORM_SPQ_PAGE_BASE_OFFSET(funcId)
#define XSTORM_SPQ_PROD_OFFSET(funcId)
#define XSTORM_TCP_GLOBAL_DEL_ACK_COUNTER_ENABLED_OFFSET(portId)
#define XSTORM_TCP_GLOBAL_DEL_ACK_COUNTER_MAX_COUNT_OFFSET(portId)
#define XSTORM_TCP_TX_SWS_TIMER_VAL_OFFSET(pfId)
#define XSTORM_VF_TO_PF_OFFSET(funcId)
#define XSTORM_ETH_FUNCTION_INFO_FP_HSI_VALID_E2_OFFSET(fid)
#define COMMON_ASM_INVALID_ASSERT_OPCODE

/* eth hsi version */
#define ETH_FP_HSI_VERSION

/* Ethernet Ring parameters */
#define X_ETH_LOCAL_RING_SIZE
#define FIRST_BD_IN_PKT
#define PARSE_BD_INDEX
#define NUM_OF_ETH_BDS_IN_PAGE
#define U_ETH_NUM_OF_SGES_TO_FETCH
#define U_ETH_MAX_SGES_FOR_PACKET

/* Rx ring params */
#define U_ETH_LOCAL_BD_RING_SIZE
#define U_ETH_LOCAL_SGE_RING_SIZE
#define U_ETH_SGL_SIZE
	/* The fw will padd the buffer with this value, so the IP header \
	will be align to 4 Byte */
#define IP_HEADER_ALIGNMENT_PADDING

#define U_ETH_SGES_PER_PAGE_INVERSE_MASK

#define TU_ETH_CQES_PER_PAGE
#define U_ETH_BDS_PER_PAGE
#define U_ETH_SGES_PER_PAGE

#define U_ETH_BDS_PER_PAGE_MASK
#define U_ETH_CQE_PER_PAGE_MASK
#define U_ETH_SGES_PER_PAGE_MASK

#define U_ETH_UNDEFINED_Q

#define T_ETH_INDIRECTION_TABLE_SIZE
#define T_ETH_RSS_KEY
#define ETH_NUM_OF_RSS_ENGINES_E2

#define FILTER_RULES_COUNT
#define MULTICAST_RULES_COUNT
#define CLASSIFY_RULES_COUNT

/*The CRC32 seed, that is used for the hash(reduction) multicast address */
#define ETH_CRC32_HASH_SEED

#define ETH_CRC32_HASH_BIT_SIZE
#define ETH_CRC32_HASH_MASK

/* Maximal L2 clients supported */
#define ETH_MAX_RX_CLIENTS_E1
#define ETH_MAX_RX_CLIENTS_E1H
#define ETH_MAX_RX_CLIENTS_E2

/* Maximal statistics client Ids */
#define MAX_STAT_COUNTER_ID_E1
#define MAX_STAT_COUNTER_ID_E1H
#define MAX_STAT_COUNTER_ID_E2

#define MAX_MAC_CREDIT_E1
#define MAX_MAC_CREDIT_E1H
#define MAX_MAC_CREDIT_E2
#define MAX_VLAN_CREDIT_E1
#define MAX_VLAN_CREDIT_E1H
#define MAX_VLAN_CREDIT_E2

/* Maximal aggregation queues supported */
#define ETH_MAX_AGGREGATION_QUEUES_E1
#define ETH_MAX_AGGREGATION_QUEUES_E1H_E2

#define ETH_NUM_OF_MCAST_BINS
#define ETH_NUM_OF_MCAST_ENGINES_E2

#define ETH_MIN_RX_CQES_WITHOUT_TPA
#define ETH_MIN_RX_CQES_WITH_TPA_E1
#define ETH_MIN_RX_CQES_WITH_TPA_E1H_E2

#define DISABLE_STATISTIC_COUNTER_ID_VALUE


/* This file defines HSI constants common to all microcode flows */

#define PROTOCOL_STATE_BIT_OFFSET

#define ETH_STATE
#define TOE_STATE
#define RDMA_STATE

/* microcode fixed page page size 4K (chains and ring segments) */
#define MC_PAGE_SIZE

/* Number of indices per slow-path SB */
#define HC_SP_SB_MAX_INDICES

/* Number of indices per SB */
#define HC_SB_MAX_INDICES_E1X
#define HC_SB_MAX_INDICES_E2

#define HC_SB_MAX_SB_E1X
#define HC_SB_MAX_SB_E2

#define HC_SP_SB_ID

#define HC_SB_MAX_SM

#define HC_SB_MAX_DYNAMIC_INDICES

/* max number of slow path commands per port */
#define MAX_RAMRODS_PER_PORT

/**** DEFINES FOR TIMERS/CLOCKS RESOLUTIONS ****/

#define TIMERS_TICK_SIZE_CHIP

#define TSEMI_CLK1_RESUL_CHIP

#define XSEMI_CLK1_RESUL_CHIP

#define SDM_TIMER_TICK_RESUL_CHIP
#define TSDM_TIMER_TICK_RESUL_CHIP

/**** END DEFINES FOR TIMERS/CLOCKS RESOLUTIONS ****/

#define XSTORM_IP_ID_ROLL_HALF
#define XSTORM_IP_ID_ROLL_ALL

#define FW_LOG_LIST_SIZE

#define NUM_OF_SAFC_BITS
#define MAX_COS_NUMBER
#define MAX_TRAFFIC_TYPES
#define MAX_PFC_PRIORITIES
#define MAX_VLAN_PRIORITIES
	/* used by array traffic_type_to_priority[] to mark traffic type \
	that is not mapped to priority*/
#define LLFC_TRAFFIC_TYPE_TO_PRIORITY_UNMAPPED

#define C_ERES_PER_PAGE
#define C_ERE_PER_PAGE_MASK

#define STATS_QUERY_CMD_COUNT

#define AFEX_LIST_TABLE_SIZE

#define INVALID_VNIC_ID

#define UNDEF_IRO

/* used for defining the amount of FCoE tasks supported for PF */
#define MAX_FCOE_FUNCS_PER_ENGINE
#define MAX_NUM_FCOE_TASKS_PER_ENGINE

#endif /* BNX2X_FW_DEFS_H */