1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2014-2019 Broadcom
7 * date: Mon Mar 9 02:37:53 2020
11 #ifndef ULP_TEMPLATE_DB_H_
12 #define ULP_TEMPLATE_DB_H_
14 #define BNXT_ULP_MAX_NUM_DEVICES 4
15 #define BNXT_ULP_LOG2_MAX_NUM_DEV 2
17 enum bnxt_ulp_action_bit {
18 BNXT_ULP_ACTION_BIT_MARK = 0x0000000000000001,
19 BNXT_ULP_ACTION_BIT_DROP = 0x0000000000000002,
20 BNXT_ULP_ACTION_BIT_COUNT = 0x0000000000000004,
21 BNXT_ULP_ACTION_BIT_RSS = 0x0000000000000008,
22 BNXT_ULP_ACTION_BIT_METER = 0x0000000000000010,
23 BNXT_ULP_ACTION_BIT_VNIC = 0x0000000000000020,
24 BNXT_ULP_ACTION_BIT_VPORT = 0x0000000000000040,
25 BNXT_ULP_ACTION_BIT_VXLAN_DECAP = 0x0000000000000080,
26 BNXT_ULP_ACTION_BIT_NVGRE_DECAP = 0x0000000000000100,
27 BNXT_ULP_ACTION_BIT_OF_POP_MPLS = 0x0000000000000200,
28 BNXT_ULP_ACTION_BIT_OF_PUSH_MPLS = 0x0000000000000400,
29 BNXT_ULP_ACTION_BIT_MAC_SWAP = 0x0000000000000800,
30 BNXT_ULP_ACTION_BIT_SET_MAC_SRC = 0x0000000000001000,
31 BNXT_ULP_ACTION_BIT_SET_MAC_DST = 0x0000000000002000,
32 BNXT_ULP_ACTION_BIT_OF_POP_VLAN = 0x0000000000004000,
33 BNXT_ULP_ACTION_BIT_OF_PUSH_VLAN = 0x0000000000008000,
34 BNXT_ULP_ACTION_BIT_OF_SET_VLAN_PCP = 0x0000000000010000,
35 BNXT_ULP_ACTION_BIT_OF_SET_VLAN_VID = 0x0000000000020000,
36 BNXT_ULP_ACTION_BIT_SET_IPV4_SRC = 0x0000000000040000,
37 BNXT_ULP_ACTION_BIT_SET_IPV4_DST = 0x0000000000080000,
38 BNXT_ULP_ACTION_BIT_SET_IPV6_SRC = 0x0000000000100000,
39 BNXT_ULP_ACTION_BIT_SET_IPV6_DST = 0x0000000000200000,
40 BNXT_ULP_ACTION_BIT_DEC_TTL = 0x0000000000400000,
41 BNXT_ULP_ACTION_BIT_SET_TP_SRC = 0x0000000000800000,
42 BNXT_ULP_ACTION_BIT_SET_TP_DST = 0x0000000001000000,
43 BNXT_ULP_ACTION_BIT_VXLAN_ENCAP = 0x0000000002000000,
44 BNXT_ULP_ACTION_BIT_NVGRE_ENCAP = 0x0000000004000000,
45 BNXT_ULP_ACTION_BIT_LAST = 0x0000000008000000
48 enum bnxt_ulp_byte_order {
49 BNXT_ULP_BYTE_ORDER_BE,
50 BNXT_ULP_BYTE_ORDER_LE,
51 BNXT_ULP_BYTE_ORDER_LAST
54 enum bnxt_ulp_device_id {
55 BNXT_ULP_DEVICE_ID_WH_PLUS,
56 BNXT_ULP_DEVICE_ID_THOR,
57 BNXT_ULP_DEVICE_ID_STINGRAY,
58 BNXT_ULP_DEVICE_ID_STINGRAY2,
59 BNXT_ULP_DEVICE_ID_LAST
62 enum bnxt_ulp_fmf_mask {
63 BNXT_ULP_FMF_MASK_IGNORE,
64 BNXT_ULP_FMF_MASK_ANY,
65 BNXT_ULP_FMF_MASK_EXACT,
66 BNXT_ULP_FMF_MASK_WILDCARD,
67 BNXT_ULP_FMF_MASK_LAST
70 enum bnxt_ulp_mark_enable {
71 BNXT_ULP_MARK_ENABLE_NO = 0,
72 BNXT_ULP_MARK_ENABLE_YES = 1,
73 BNXT_ULP_MARK_ENABLE_LAST = 2
76 enum bnxt_ulp_mask_opc {
77 BNXT_ULP_MASK_OPC_SET_TO_CONSTANT = 0,
78 BNXT_ULP_MASK_OPC_SET_TO_HDR_FIELD = 1,
79 BNXT_ULP_MASK_OPC_SET_TO_REGFILE = 2,
80 BNXT_ULP_MASK_OPC_ADD_PAD = 3,
81 BNXT_ULP_MASK_OPC_LAST = 4
84 enum bnxt_ulp_priority {
85 BNXT_ULP_PRIORITY_LEVEL_0 = 0,
86 BNXT_ULP_PRIORITY_LEVEL_1 = 1,
87 BNXT_ULP_PRIORITY_LEVEL_2 = 2,
88 BNXT_ULP_PRIORITY_LEVEL_3 = 3,
89 BNXT_ULP_PRIORITY_LEVEL_4 = 4,
90 BNXT_ULP_PRIORITY_LEVEL_5 = 5,
91 BNXT_ULP_PRIORITY_LEVEL_6 = 6,
92 BNXT_ULP_PRIORITY_LEVEL_7 = 7,
93 BNXT_ULP_PRIORITY_NOT_USED = 8,
94 BNXT_ULP_PRIORITY_LAST = 9
97 enum bnxt_ulp_regfile_index {
98 BNXT_ULP_REGFILE_INDEX_L2_CNTXT_ID_0 = 0,
99 BNXT_ULP_REGFILE_INDEX_L2_CNTXT_ID_1 = 1,
100 BNXT_ULP_REGFILE_INDEX_PROF_FUNC_ID_0 = 2,
101 BNXT_ULP_REGFILE_INDEX_PROF_FUNC_ID_1 = 3,
102 BNXT_ULP_REGFILE_INDEX_EM_PROFILE_ID_0 = 4,
103 BNXT_ULP_REGFILE_INDEX_EM_PROFILE_ID_1 = 5,
104 BNXT_ULP_REGFILE_INDEX_WC_PROFILE_ID_0 = 6,
105 BNXT_ULP_REGFILE_INDEX_WC_PROFILE_ID_1 = 7,
106 BNXT_ULP_REGFILE_INDEX_ACTION_PTR_MAIN = 8,
107 BNXT_ULP_REGFILE_INDEX_ACTION_PTR_0 = 9,
108 BNXT_ULP_REGFILE_INDEX_ENCAP_PTR_0 = 10,
109 BNXT_ULP_REGFILE_INDEX_ENCAP_PTR_1 = 11,
110 BNXT_ULP_REGFILE_INDEX_NOT_USED = 12,
111 BNXT_ULP_REGFILE_INDEX_LAST = 13
114 enum bnxt_ulp_resource_func {
115 BNXT_ULP_RESOURCE_FUNC_TCAM_TABLE = 0,
116 BNXT_ULP_RESOURCE_FUNC_EM_TABLE = 1,
117 BNXT_ULP_RESOURCE_FUNC_INDEX_TABLE = 2,
118 BNXT_ULP_RESOURCE_FUNC_IDENTIFIER = 3,
119 BNXT_ULP_RESOURCE_FUNC_HW_FID = 4,
120 BNXT_ULP_RESOURCE_FUNC_LAST = 5
123 enum bnxt_ulp_result_opc {
124 BNXT_ULP_RESULT_OPC_SET_TO_CONSTANT = 0,
125 BNXT_ULP_RESULT_OPC_SET_TO_ACT_PROP = 1,
126 BNXT_ULP_RESULT_OPC_SET_TO_ACT_PROP_SZ = 2,
127 BNXT_ULP_RESULT_OPC_SET_TO_REGFILE = 3,
128 BNXT_ULP_RESULT_OPC_LAST = 4
131 enum bnxt_ulp_search_before_alloc {
132 BNXT_ULP_SEARCH_BEFORE_ALLOC_NO = 0,
133 BNXT_ULP_SEARCH_BEFORE_ALLOC_YES = 1,
134 BNXT_ULP_SEARCH_BEFORE_ALLOC_LAST = 2
137 enum bnxt_ulp_spec_opc {
138 BNXT_ULP_SPEC_OPC_SET_TO_CONSTANT = 0,
139 BNXT_ULP_SPEC_OPC_SET_TO_HDR_FIELD = 1,
140 BNXT_ULP_SPEC_OPC_SET_TO_REGFILE = 2,
141 BNXT_ULP_SPEC_OPC_ADD_PAD = 3,
142 BNXT_ULP_SPEC_OPC_LAST = 4
146 BNXT_ULP_SYM_BIG_ENDIAN = 0,
147 BNXT_ULP_SYM_DECAP_FUNC_NONE = 0,
148 BNXT_ULP_SYM_DECAP_FUNC_THRU_L2 = 11,
149 BNXT_ULP_SYM_DECAP_FUNC_THRU_L3 = 12,
150 BNXT_ULP_SYM_DECAP_FUNC_THRU_L4 = 13,
151 BNXT_ULP_SYM_DECAP_FUNC_THRU_TL2 = 3,
152 BNXT_ULP_SYM_DECAP_FUNC_THRU_TL3 = 8,
153 BNXT_ULP_SYM_DECAP_FUNC_THRU_TL4 = 9,
154 BNXT_ULP_SYM_DECAP_FUNC_THRU_TUN = 10,
155 BNXT_ULP_SYM_ECV_L3_TYPE_IPV4 = 4,
156 BNXT_ULP_SYM_ECV_L3_TYPE_IPV6 = 5,
157 BNXT_ULP_SYM_ECV_L3_TYPE_MPLS_8847 = 6,
158 BNXT_ULP_SYM_ECV_L3_TYPE_MPLS_8848 = 7,
159 BNXT_ULP_SYM_ECV_L3_TYPE_NONE = 0,
160 BNXT_ULP_SYM_ECV_L4_TYPE_NONE = 0,
161 BNXT_ULP_SYM_ECV_L4_TYPE_UDP = 4,
162 BNXT_ULP_SYM_ECV_L4_TYPE_UDP_CSUM = 5,
163 BNXT_ULP_SYM_ECV_L4_TYPE_UDP_ENTROPY = 6,
164 BNXT_ULP_SYM_ECV_L4_TYPE_UDP_ENTROPY_CSUM = 7,
165 BNXT_ULP_SYM_ECV_TUN_TYPE_GENERIC = 1,
166 BNXT_ULP_SYM_ECV_TUN_TYPE_GRE = 5,
167 BNXT_ULP_SYM_ECV_TUN_TYPE_NGE = 3,
168 BNXT_ULP_SYM_ECV_TUN_TYPE_NONE = 0,
169 BNXT_ULP_SYM_ECV_TUN_TYPE_NVGRE = 4,
170 BNXT_ULP_SYM_ECV_TUN_TYPE_VXLAN = 2,
171 BNXT_ULP_SYM_IP_PROTO_UDP = 17,
172 BNXT_ULP_SYM_L2_HDR_TYPE_DIX = 0,
173 BNXT_ULP_SYM_L2_HDR_TYPE_LLC = 2,
174 BNXT_ULP_SYM_L2_HDR_TYPE_LLC_SNAP = 1,
175 BNXT_ULP_SYM_L3_HDR_TYPE_ARP = 2,
176 BNXT_ULP_SYM_L3_HDR_TYPE_EAPOL = 4,
177 BNXT_ULP_SYM_L3_HDR_TYPE_FCOE = 6,
178 BNXT_ULP_SYM_L3_HDR_TYPE_IPV4 = 0,
179 BNXT_ULP_SYM_L3_HDR_TYPE_IPV6 = 1,
180 BNXT_ULP_SYM_L3_HDR_TYPE_PTP = 3,
181 BNXT_ULP_SYM_L3_HDR_TYPE_ROCE = 5,
182 BNXT_ULP_SYM_L3_HDR_TYPE_UPAR1 = 7,
183 BNXT_ULP_SYM_L3_HDR_TYPE_UPAR2 = 8,
184 BNXT_ULP_SYM_L4_HDR_TYPE_BTH_V1 = 5,
185 BNXT_ULP_SYM_L4_HDR_TYPE_ICMP = 2,
186 BNXT_ULP_SYM_L4_HDR_TYPE_TCP = 0,
187 BNXT_ULP_SYM_L4_HDR_TYPE_UDP = 1,
188 BNXT_ULP_SYM_L4_HDR_TYPE_UPAR1 = 3,
189 BNXT_ULP_SYM_L4_HDR_TYPE_UPAR2 = 4,
190 BNXT_ULP_SYM_LITTLE_ENDIAN = 1,
192 BNXT_ULP_SYM_PKT_TYPE_L2 = 0,
193 BNXT_ULP_SYM_TL2_HDR_TYPE_DIX = 0,
194 BNXT_ULP_SYM_TL3_HDR_TYPE_IPV4 = 0,
195 BNXT_ULP_SYM_TL3_HDR_TYPE_IPV6 = 1,
196 BNXT_ULP_SYM_TL4_HDR_TYPE_TCP = 0,
197 BNXT_ULP_SYM_TL4_HDR_TYPE_UDP = 1,
198 BNXT_ULP_SYM_TUN_HDR_TYPE_GENEVE = 1,
199 BNXT_ULP_SYM_TUN_HDR_TYPE_GRE = 3,
200 BNXT_ULP_SYM_TUN_HDR_TYPE_IPV4 = 4,
201 BNXT_ULP_SYM_TUN_HDR_TYPE_IPV6 = 5,
202 BNXT_ULP_SYM_TUN_HDR_TYPE_MPLS = 7,
203 BNXT_ULP_SYM_TUN_HDR_TYPE_NONE = 15,
204 BNXT_ULP_SYM_TUN_HDR_TYPE_NVGRE = 2,
205 BNXT_ULP_SYM_TUN_HDR_TYPE_PPPOE = 6,
206 BNXT_ULP_SYM_TUN_HDR_TYPE_UPAR1 = 8,
207 BNXT_ULP_SYM_TUN_HDR_TYPE_UPAR2 = 9,
208 BNXT_ULP_SYM_TUN_HDR_TYPE_VXLAN = 0,
212 enum bnxt_ulp_act_prop_sz {
213 BNXT_ULP_ACT_PROP_SZ_ENCAP_TUN_SZ = 4,
214 BNXT_ULP_ACT_PROP_SZ_ENCAP_IP_SZ = 4,
215 BNXT_ULP_ACT_PROP_SZ_ENCAP_VTAG_SZ = 4,
216 BNXT_ULP_ACT_PROP_SZ_ENCAP_VTAG_TYPE = 4,
217 BNXT_ULP_ACT_PROP_SZ_ENCAP_VTAG_NUM = 4,
218 BNXT_ULP_ACT_PROP_SZ_ENCAP_L3_TYPE = 4,
219 BNXT_ULP_ACT_PROP_SZ_MPLS_POP_NUM = 4,
220 BNXT_ULP_ACT_PROP_SZ_MPLS_PUSH_NUM = 4,
221 BNXT_ULP_ACT_PROP_SZ_VNIC = 4,
222 BNXT_ULP_ACT_PROP_SZ_VPORT = 4,
223 BNXT_ULP_ACT_PROP_SZ_MARK = 4,
224 BNXT_ULP_ACT_PROP_SZ_COUNT = 4,
225 BNXT_ULP_ACT_PROP_SZ_METER = 4,
226 BNXT_ULP_ACT_PROP_SZ_SET_MAC_SRC = 8,
227 BNXT_ULP_ACT_PROP_SZ_SET_MAC_DST = 8,
228 BNXT_ULP_ACT_PROP_SZ_OF_PUSH_VLAN = 4,
229 BNXT_ULP_ACT_PROP_SZ_OF_SET_VLAN_PCP = 4,
230 BNXT_ULP_ACT_PROP_SZ_OF_SET_VLAN_VID = 4,
231 BNXT_ULP_ACT_PROP_SZ_SET_IPV4_SRC = 4,
232 BNXT_ULP_ACT_PROP_SZ_SET_IPV4_DST = 4,
233 BNXT_ULP_ACT_PROP_SZ_SET_IPV6_SRC = 16,
234 BNXT_ULP_ACT_PROP_SZ_SET_IPV6_DST = 16,
235 BNXT_ULP_ACT_PROP_SZ_SET_TP_SRC = 4,
236 BNXT_ULP_ACT_PROP_SZ_SET_TP_DST = 4,
237 BNXT_ULP_ACT_PROP_SZ_OF_PUSH_MPLS_0 = 4,
238 BNXT_ULP_ACT_PROP_SZ_OF_PUSH_MPLS_1 = 4,
239 BNXT_ULP_ACT_PROP_SZ_OF_PUSH_MPLS_2 = 4,
240 BNXT_ULP_ACT_PROP_SZ_OF_PUSH_MPLS_3 = 4,
241 BNXT_ULP_ACT_PROP_SZ_OF_PUSH_MPLS_4 = 4,
242 BNXT_ULP_ACT_PROP_SZ_OF_PUSH_MPLS_5 = 4,
243 BNXT_ULP_ACT_PROP_SZ_OF_PUSH_MPLS_6 = 4,
244 BNXT_ULP_ACT_PROP_SZ_OF_PUSH_MPLS_7 = 4,
245 BNXT_ULP_ACT_PROP_SZ_ENCAP_L2_DMAC = 6,
246 BNXT_ULP_ACT_PROP_SZ_ENCAP_L2_SMAC = 6,
247 BNXT_ULP_ACT_PROP_SZ_ENCAP_VTAG = 8,
248 BNXT_ULP_ACT_PROP_SZ_ENCAP_IP = 32,
249 BNXT_ULP_ACT_PROP_SZ_ENCAP_IP_SRC = 16,
250 BNXT_ULP_ACT_PROP_SZ_ENCAP_UDP = 4,
251 BNXT_ULP_ACT_PROP_SZ_ENCAP_TUN = 32,
252 BNXT_ULP_ACT_PROP_SZ_LAST = 4
255 enum bnxt_ulp_act_prop_idx {
256 BNXT_ULP_ACT_PROP_IDX_ENCAP_TUN_SZ = 0,
257 BNXT_ULP_ACT_PROP_IDX_ENCAP_IP_SZ = 4,
258 BNXT_ULP_ACT_PROP_IDX_ENCAP_VTAG_SZ = 8,
259 BNXT_ULP_ACT_PROP_IDX_ENCAP_VTAG_TYPE = 12,
260 BNXT_ULP_ACT_PROP_IDX_ENCAP_VTAG_NUM = 16,
261 BNXT_ULP_ACT_PROP_IDX_ENCAP_L3_TYPE = 20,
262 BNXT_ULP_ACT_PROP_IDX_MPLS_POP_NUM = 24,
263 BNXT_ULP_ACT_PROP_IDX_MPLS_PUSH_NUM = 28,
264 BNXT_ULP_ACT_PROP_IDX_VNIC = 32,
265 BNXT_ULP_ACT_PROP_IDX_VPORT = 36,
266 BNXT_ULP_ACT_PROP_IDX_MARK = 40,
267 BNXT_ULP_ACT_PROP_IDX_COUNT = 44,
268 BNXT_ULP_ACT_PROP_IDX_METER = 48,
269 BNXT_ULP_ACT_PROP_IDX_SET_MAC_SRC = 52,
270 BNXT_ULP_ACT_PROP_IDX_SET_MAC_DST = 60,
271 BNXT_ULP_ACT_PROP_IDX_OF_PUSH_VLAN = 68,
272 BNXT_ULP_ACT_PROP_IDX_OF_SET_VLAN_PCP = 72,
273 BNXT_ULP_ACT_PROP_IDX_OF_SET_VLAN_VID = 76,
274 BNXT_ULP_ACT_PROP_IDX_SET_IPV4_SRC = 80,
275 BNXT_ULP_ACT_PROP_IDX_SET_IPV4_DST = 84,
276 BNXT_ULP_ACT_PROP_IDX_SET_IPV6_SRC = 88,
277 BNXT_ULP_ACT_PROP_IDX_SET_IPV6_DST = 104,
278 BNXT_ULP_ACT_PROP_IDX_SET_TP_SRC = 120,
279 BNXT_ULP_ACT_PROP_IDX_SET_TP_DST = 124,
280 BNXT_ULP_ACT_PROP_IDX_OF_PUSH_MPLS_0 = 128,
281 BNXT_ULP_ACT_PROP_IDX_OF_PUSH_MPLS_1 = 132,
282 BNXT_ULP_ACT_PROP_IDX_OF_PUSH_MPLS_2 = 136,
283 BNXT_ULP_ACT_PROP_IDX_OF_PUSH_MPLS_3 = 140,
284 BNXT_ULP_ACT_PROP_IDX_OF_PUSH_MPLS_4 = 144,
285 BNXT_ULP_ACT_PROP_IDX_OF_PUSH_MPLS_5 = 148,
286 BNXT_ULP_ACT_PROP_IDX_OF_PUSH_MPLS_6 = 152,
287 BNXT_ULP_ACT_PROP_IDX_OF_PUSH_MPLS_7 = 156,
288 BNXT_ULP_ACT_PROP_IDX_ENCAP_L2_DMAC = 160,
289 BNXT_ULP_ACT_PROP_IDX_ENCAP_L2_SMAC = 166,
290 BNXT_ULP_ACT_PROP_IDX_ENCAP_VTAG = 172,
291 BNXT_ULP_ACT_PROP_IDX_ENCAP_IP = 180,
292 BNXT_ULP_ACT_PROP_IDX_ENCAP_IP_SRC = 212,
293 BNXT_ULP_ACT_PROP_IDX_ENCAP_UDP = 228,
294 BNXT_ULP_ACT_PROP_IDX_ENCAP_TUN = 232,
295 BNXT_ULP_ACT_PROP_IDX_LAST = 264
298 #endif /* _ULP_TEMPLATE_DB_H_ */