#ifndef __T4_HW_H
#define __T4_HW_H
#include "osdep.h"
enum {
NCHAN = 4,
T6_NCHAN = 2,
MAX_NCHAN = 4,
MAX_MTU = 9600,
EEPROMSIZE = 17408,
EEPROMVSIZE = 32768,
EEPROMPFSIZE = 1024,
RSS_NENTRIES = 2048,
T6_RSS_NENTRIES = 4096,
T7_RSS_NENTRIES = 16384,
TCB_SIZE = 128,
NMTUS = 16,
NCCTRL_WIN = 32,
NTX_SCHED = 8,
PM_NSTATS = 5,
T6_PM_NSTATS = 7,
MAX_PM_NSTATS = 7,
T7_PM_RX_CACHE_NSTATS = 27,
MBOX_LEN = 64,
NTRACE = 4,
TRACE_LEN = 112,
FILTER_OPT_LEN = 36,
T5_FILTER_OPT_LEN = 40,
T7_FILTER_OPT_LEN = 63,
NWOL_PAT = 8,
WOL_PAT_LEN = 128,
UDBS_SEG_SIZE = 128,
UDBS_SEG_SHIFT = 7,
UDBS_DB_OFFSET = 8,
UDBS_WR_OFFSET = 64,
MAX_UP_CORES = 8,
};
enum {
CIM_NUM_IBQ = 6,
CIM_NUM_IBQ_T7 = 16,
CIM_NUM_OBQ = 6,
CIM_NUM_OBQ_T5 = 8,
CIM_NUM_OBQ_T7 = 16,
CIMLA_SIZE = 256 * 8,
CIMLA_SIZE_T6 = 256 * 10,
CIM_PIFLA_SIZE = 64,
CIM_MALA_SIZE = 64,
CIM_IBQ_SIZE = 128,
CIM_OBQ_SIZE = 128,
TPLA_SIZE = 128,
ULPRX_LA_SIZE = 512,
};
enum {
SF_PAGE_SIZE = 256,
SF_SEC_SIZE = 64 * 1024,
};
enum ctxt_type { CTXT_EGRESS, CTXT_INGRESS, CTXT_FLM, CTXT_CNM };
enum { RSP_TYPE_FLBUF, RSP_TYPE_CPL, RSP_TYPE_INTR };
enum { MBOX_OWNER_NONE, MBOX_OWNER_FW, MBOX_OWNER_DRV };
enum {
SGE_MAX_WR_LEN = 512,
SGE_CTXT_SIZE = 24,
SGE_CTXT_SIZE_T7 = 28,
SGE_NTIMERS = 6,
SGE_NCOUNTERS = 4,
SGE_NDBQTIMERS = 8,
SGE_MAX_IQ_SIZE = 65520,
SGE_FLBUF_SIZES = 16,
};
struct sge_qstat {
volatile __be32 qid;
volatile __be16 cidx;
volatile __be16 pidx;
};
#define S_QSTAT_PIDX 0
#define M_QSTAT_PIDX 0xffff
#define G_QSTAT_PIDX(x) (((x) >> S_QSTAT_PIDX) & M_QSTAT_PIDX)
#define S_QSTAT_CIDX 16
#define M_QSTAT_CIDX 0xffff
#define G_QSTAT_CIDX(x) (((x) >> S_QSTAT_CIDX) & M_QSTAT_CIDX)
struct rsp_ctrl {
__be32 hdrbuflen_pidx;
__be32 pldbuflen_qid;
union {
u8 type_gen;
__be64 last_flit;
} u;
};
#define S_RSPD_NEWBUF 31
#define V_RSPD_NEWBUF(x) ((x) << S_RSPD_NEWBUF)
#define F_RSPD_NEWBUF V_RSPD_NEWBUF(1U)
#define S_RSPD_LEN 0
#define M_RSPD_LEN 0x7fffffff
#define V_RSPD_LEN(x) ((x) << S_RSPD_LEN)
#define G_RSPD_LEN(x) (((x) >> S_RSPD_LEN) & M_RSPD_LEN)
#define S_RSPD_QID S_RSPD_LEN
#define M_RSPD_QID M_RSPD_LEN
#define V_RSPD_QID(x) V_RSPD_LEN(x)
#define G_RSPD_QID(x) G_RSPD_LEN(x)
#define S_RSPD_GEN 7
#define V_RSPD_GEN(x) ((x) << S_RSPD_GEN)
#define F_RSPD_GEN V_RSPD_GEN(1U)
#define S_RSPD_QOVFL 6
#define V_RSPD_QOVFL(x) ((x) << S_RSPD_QOVFL)
#define F_RSPD_QOVFL V_RSPD_QOVFL(1U)
#define S_RSPD_TYPE 4
#define M_RSPD_TYPE 0x3
#define V_RSPD_TYPE(x) ((x) << S_RSPD_TYPE)
#define G_RSPD_TYPE(x) (((x) >> S_RSPD_TYPE) & M_RSPD_TYPE)
#define S_QINTR_CNT_EN 0
#define V_QINTR_CNT_EN(x) ((x) << S_QINTR_CNT_EN)
#define F_QINTR_CNT_EN V_QINTR_CNT_EN(1U)
#define S_QINTR_TIMER_IDX 1
#define M_QINTR_TIMER_IDX 0x7
#define V_QINTR_TIMER_IDX(x) ((x) << S_QINTR_TIMER_IDX)
#define G_QINTR_TIMER_IDX(x) (((x) >> S_QINTR_TIMER_IDX) & M_QINTR_TIMER_IDX)
#define S_ARM_QTYPE 11
#define M_ARM_QTYPE 1
#define V_ARM_QTYPE(x) ((x) << S_ARM_QTYPE)
#define S_ARM_PIDX 0
#define M_ARM_PIDX 0x7ffU
#define V_ARM_PIDX(x) ((x) << S_ARM_PIDX)
#define S_ARM_CIDXINC 0
#define M_ARM_CIDXINC 0x7ffU
#define V_ARM_CIDXINC(x) ((x) << S_ARM_CIDXINC)
#define PPOD_PAGES 4U
struct pagepod {
__be64 vld_tid_pgsz_tag_color;
__be64 len_offset;
__be64 rsvd;
__be64 addr[PPOD_PAGES + 1];
};
#define S_PPOD_COLOR 0
#define M_PPOD_COLOR 0x3F
#define V_PPOD_COLOR(x) ((x) << S_PPOD_COLOR)
#define S_PPOD_TAG 6
#define M_PPOD_TAG 0xFFFFFF
#define V_PPOD_TAG(x) ((x) << S_PPOD_TAG)
#define G_PPOD_TAG(x) (((x) >> S_PPOD_TAG) & M_PPOD_TAG)
#define S_PPOD_PGSZ 30
#define M_PPOD_PGSZ 0x3
#define V_PPOD_PGSZ(x) ((x) << S_PPOD_PGSZ)
#define G_PPOD_PGSZ(x) (((x) >> S_PPOD_PGSZ) & M_PPOD_PGSZ)
#define S_PPOD_TID 32
#define M_PPOD_TID 0xFFFFFF
#define V_PPOD_TID(x) ((__u64)(x) << S_PPOD_TID)
#define S_PPOD_VALID 56
#define V_PPOD_VALID(x) ((__u64)(x) << S_PPOD_VALID)
#define F_PPOD_VALID V_PPOD_VALID(1ULL)
#define S_PPOD_LEN 32
#define M_PPOD_LEN 0xFFFFFFFF
#define V_PPOD_LEN(x) ((__u64)(x) << S_PPOD_LEN)
#define S_PPOD_OFST 0
#define M_PPOD_OFST 0xFFFFFFFF
#define V_PPOD_OFST(x) ((x) << S_PPOD_OFST)
#define FLASH_START(start) ((start) * SF_SEC_SIZE)
#define FLASH_MAX_SIZE(nsecs) ((nsecs) * SF_SEC_SIZE)
#define FLASH_MIN_SIZE FLASH_START(32)
enum t4_flash_loc {
FLASH_LOC_EXP_ROM = 0,
FLASH_LOC_IBFT,
FLASH_LOC_BOOTCFG,
FLASH_LOC_FW,
FLASH_LOC_FWBOOTSTRAP,
FLASH_LOC_ISCSI_CRASH,
FLASH_LOC_FCOE_CRASH,
FLASH_LOC_CFG,
FLASH_LOC_CUDBG,
FLASH_LOC_CHIP_DUMP,
FLASH_LOC_DPU_BOOT,
FLASH_LOC_DPU_AREA,
FLASH_LOC_VPD,
FLASH_LOC_VPD_BACKUP,
FLASH_LOC_FW_BACKUP,
FLASH_LOC_FWBOOTSTRAP_BACKUP,
FLASH_LOC_CFG_BACK,
FLASH_LOC_BOOT_AREA,
FLASH_LOC_MIN_SIZE,
FLASH_LOC_END
};
struct t4_flash_loc_entry {
u16 start_sec;
u16 nsecs;
};
#define S_SGE_TIMESTAMP 0
#define M_SGE_TIMESTAMP 0xfffffffffffffffULL
#define V_SGE_TIMESTAMP(x) ((__u64)(x) << S_SGE_TIMESTAMP)
#define G_SGE_TIMESTAMP(x) (((__u64)(x) >> S_SGE_TIMESTAMP) & M_SGE_TIMESTAMP)
#define I2C_DEV_ADDR_A0 0xa0
#define I2C_DEV_ADDR_A2 0xa2
#define I2C_PAGE_SIZE 0x100
#define SFP_DIAG_TYPE_ADDR 0x5c
#define SFP_DIAG_TYPE_LEN 0x1
#define SFF_8472_COMP_ADDR 0x5e
#define SFF_8472_COMP_LEN 0x1
#define SFF_REV_ADDR 0x1
#define SFF_REV_LEN 0x1
#endif