xref: /f-stack/dpdk/drivers/net/cxgbe/base/t4_hw.h (revision d30ea906)
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2014-2018 Chelsio Communications.
3  * All rights reserved.
4  */
5 
6 #ifndef __T4_HW_H
7 #define __T4_HW_H
8 
9 enum {
10 	NCHAN           = 4,     /* # of HW channels */
11 	EEPROMSIZE      = 17408, /* Serial EEPROM physical size */
12 	EEPROMVSIZE     = 32768, /* Serial EEPROM virtual address space size */
13 	EEPROMPFSIZE    = 1024,  /* EEPROM writable area size for PFn, n>0 */
14 	NMTUS           = 16,    /* size of MTU table */
15 	NCCTRL_WIN      = 32,    /* # of congestion control windows */
16 	MBOX_LEN        = 64,    /* mailbox size in bytes */
17 	UDBS_SEG_SIZE   = 128,   /* segment size for BAR2 user doorbells */
18 };
19 
20 enum {
21 	CIMLA_SIZE     = 2048,  /* # of 32-bit words in CIM LA */
22 };
23 
24 enum {
25 	SF_SEC_SIZE = 64 * 1024,      /* serial flash sector size */
26 };
27 
28 enum {
29 	SGE_NTIMERS = 6,          /* # of interrupt holdoff timer values */
30 	SGE_NCOUNTERS = 4,        /* # of interrupt packet counter values */
31 };
32 
33 /* PCI-e memory window access */
34 enum pcie_memwin {
35 	MEMWIN_NIC      = 0,
36 };
37 
38 enum {
39 	SGE_MAX_WR_LEN = 512,     /* max WR size in bytes */
40 	SGE_EQ_IDXSIZE = 64,      /* egress queue pidx/cidx unit size */
41 	/* max no. of desc allowed in WR */
42 	SGE_MAX_WR_NDESC = SGE_MAX_WR_LEN / SGE_EQ_IDXSIZE,
43 };
44 
45 enum {
46 	TCB_SIZE        = 128,   /* TCB size */
47 };
48 
49 struct sge_qstat {                /* data written to SGE queue status entries */
50 	__be32 qid;
51 	__be16 cidx;
52 	__be16 pidx;
53 };
54 
55 /*
56  * Structure for last 128 bits of response descriptors
57  */
58 struct rsp_ctrl {
59 	__be32 hdrbuflen_pidx;
60 	__be32 pldbuflen_qid;
61 	union {
62 		u8 type_gen;
63 		__be64 last_flit;
64 	} u;
65 };
66 
67 #define S_RSPD_NEWBUF    31
68 #define V_RSPD_NEWBUF(x) ((x) << S_RSPD_NEWBUF)
69 #define F_RSPD_NEWBUF    V_RSPD_NEWBUF(1U)
70 
71 #define S_RSPD_LEN    0
72 #define M_RSPD_LEN    0x7fffffff
73 #define V_RSPD_LEN(x) ((x) << S_RSPD_LEN)
74 #define G_RSPD_LEN(x) (((x) >> S_RSPD_LEN) & M_RSPD_LEN)
75 
76 #define S_RSPD_GEN    7
77 #define V_RSPD_GEN(x) ((x) << S_RSPD_GEN)
78 #define F_RSPD_GEN    V_RSPD_GEN(1U)
79 
80 #define S_RSPD_TYPE    4
81 #define M_RSPD_TYPE    0x3
82 #define V_RSPD_TYPE(x) ((x) << S_RSPD_TYPE)
83 #define G_RSPD_TYPE(x) (((x) >> S_RSPD_TYPE) & M_RSPD_TYPE)
84 
85 /* Rx queue interrupt deferral field: timer index */
86 #define S_QINTR_CNT_EN    0
87 #define V_QINTR_CNT_EN(x) ((x) << S_QINTR_CNT_EN)
88 #define F_QINTR_CNT_EN    V_QINTR_CNT_EN(1U)
89 
90 #define S_QINTR_TIMER_IDX    1
91 #define M_QINTR_TIMER_IDX    0x7
92 #define V_QINTR_TIMER_IDX(x) ((x) << S_QINTR_TIMER_IDX)
93 #define G_QINTR_TIMER_IDX(x) (((x) >> S_QINTR_TIMER_IDX) & M_QINTR_TIMER_IDX)
94 
95 /*
96  * Flash layout.
97  */
98 #define FLASH_START(start)      ((start) * SF_SEC_SIZE)
99 #define FLASH_MAX_SIZE(nsecs)   ((nsecs) * SF_SEC_SIZE)
100 
101 enum {
102 	/*
103 	 * Various Expansion-ROM boot images, etc.
104 	 */
105 	FLASH_EXP_ROM_START_SEC = 0,
106 	FLASH_EXP_ROM_NSECS = 6,
107 	FLASH_EXP_ROM_START = FLASH_START(FLASH_EXP_ROM_START_SEC),
108 	FLASH_EXP_ROM_MAX_SIZE = FLASH_MAX_SIZE(FLASH_EXP_ROM_NSECS),
109 
110 	/*
111 	 * Location of firmware image in FLASH.
112 	 */
113 	FLASH_FW_START_SEC = 8,
114 	FLASH_FW_NSECS = 16,
115 	FLASH_FW_START = FLASH_START(FLASH_FW_START_SEC),
116 	FLASH_FW_MAX_SIZE = FLASH_MAX_SIZE(FLASH_FW_NSECS),
117 
118 	/*
119 	 * Location of bootstrap firmware image in FLASH.
120 	 */
121 	FLASH_FWBOOTSTRAP_START_SEC = 27,
122 	FLASH_FWBOOTSTRAP_NSECS = 1,
123 	FLASH_FWBOOTSTRAP_START = FLASH_START(FLASH_FWBOOTSTRAP_START_SEC),
124 	FLASH_FWBOOTSTRAP_MAX_SIZE = FLASH_MAX_SIZE(FLASH_FWBOOTSTRAP_NSECS),
125 
126 	/*
127 	 * Location of Firmware Configuration File in FLASH.
128 	 */
129 	FLASH_CFG_START_SEC = 31,
130 	FLASH_CFG_NSECS = 1,
131 	FLASH_CFG_START = FLASH_START(FLASH_CFG_START_SEC),
132 	FLASH_CFG_MAX_SIZE = FLASH_MAX_SIZE(FLASH_CFG_NSECS),
133 
134 	/*
135 	 * We don't support FLASH devices which can't support the full
136 	 * standard set of sections which we need for normal operations.
137 	 */
138 	FLASH_MIN_SIZE = FLASH_CFG_START + FLASH_CFG_MAX_SIZE,
139 };
140 
141 #undef FLASH_START
142 #undef FLASH_MAX_SIZE
143 
144 #endif /* __T4_HW_H */
145