1 /*******************************************************************************
3 * Intel Ethernet Controller XL710 Family Linux Driver
4 * Copyright(c) 2013 - 2014 Intel Corporation.
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms and conditions of the GNU General Public License,
8 * version 2, as published by the Free Software Foundation.
10 * This program is distributed in the hope it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
15 * You should have received a copy of the GNU General Public License along
16 * with this program. If not, see <http://www.gnu.org/licenses/>.
18 * The full GNU General Public License is included in this distribution in
19 * the file called "COPYING".
21 * Contact Information:
22 * e1000-devel Mailing List <e1000-devel@lists.sourceforge.net>
23 * Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
25 ******************************************************************************/
27 #include "i40e_osdep.h"
28 #include "i40e_register.h"
29 #include "i40e_type.h"
31 #include "i40e_lan_hmc.h"
32 #include "i40e_prototype.h"
34 /* lan specific interface functions */
37 * i40e_align_l2obj_base - aligns base object pointer to 512 bytes
38 * @offset: base address offset needing alignment
40 * Aligns the layer 2 function private memory so it's 512-byte aligned.
42 static u64
i40e_align_l2obj_base(u64 offset
)
44 u64 aligned_offset
= offset
;
46 if ((offset
% I40E_HMC_L2OBJ_BASE_ALIGNMENT
) > 0)
47 aligned_offset
+= (I40E_HMC_L2OBJ_BASE_ALIGNMENT
-
48 (offset
% I40E_HMC_L2OBJ_BASE_ALIGNMENT
));
50 return aligned_offset
;
54 * i40e_calculate_l2fpm_size - calculates layer 2 FPM memory size
55 * @txq_num: number of Tx queues needing backing context
56 * @rxq_num: number of Rx queues needing backing context
57 * @fcoe_cntx_num: amount of FCoE statefull contexts needing backing context
58 * @fcoe_filt_num: number of FCoE filters needing backing context
60 * Calculates the maximum amount of memory for the function required, based
61 * on the number of resources it must provide context for.
63 static u64
i40e_calculate_l2fpm_size(u32 txq_num
, u32 rxq_num
,
64 u32 fcoe_cntx_num
, u32 fcoe_filt_num
)
68 fpm_size
= txq_num
* I40E_HMC_OBJ_SIZE_TXQ
;
69 fpm_size
= i40e_align_l2obj_base(fpm_size
);
71 fpm_size
+= (rxq_num
* I40E_HMC_OBJ_SIZE_RXQ
);
72 fpm_size
= i40e_align_l2obj_base(fpm_size
);
74 fpm_size
+= (fcoe_cntx_num
* I40E_HMC_OBJ_SIZE_FCOE_CNTX
);
75 fpm_size
= i40e_align_l2obj_base(fpm_size
);
77 fpm_size
+= (fcoe_filt_num
* I40E_HMC_OBJ_SIZE_FCOE_FILT
);
78 fpm_size
= i40e_align_l2obj_base(fpm_size
);
84 * i40e_init_lan_hmc - initialize i40e_hmc_info struct
85 * @hw: pointer to the HW structure
86 * @txq_num: number of Tx queues needing backing context
87 * @rxq_num: number of Rx queues needing backing context
88 * @fcoe_cntx_num: amount of FCoE statefull contexts needing backing context
89 * @fcoe_filt_num: number of FCoE filters needing backing context
91 * This function will be called once per physical function initialization.
92 * It will fill out the i40e_hmc_obj_info structure for LAN objects based on
93 * the driver's provided input, as well as information from the HMC itself
97 * - HMC Resource Profile has been selected before calling this function.
99 i40e_status
i40e_init_lan_hmc(struct i40e_hw
*hw
, u32 txq_num
,
100 u32 rxq_num
, u32 fcoe_cntx_num
,
103 struct i40e_hmc_obj_info
*obj
, *full_obj
;
104 i40e_status ret_code
= 0;
108 hw
->hmc
.signature
= I40E_HMC_INFO_SIGNATURE
;
109 hw
->hmc
.hmc_fn_id
= hw
->pf_id
;
111 /* allocate memory for hmc_obj */
112 ret_code
= i40e_allocate_virt_mem(hw
, &hw
->hmc
.hmc_obj_virt_mem
,
113 sizeof(struct i40e_hmc_obj_info
) * I40E_HMC_LAN_MAX
);
115 goto init_lan_hmc_out
;
116 hw
->hmc
.hmc_obj
= (struct i40e_hmc_obj_info
*)
117 hw
->hmc
.hmc_obj_virt_mem
.va
;
119 /* The full object will be used to create the LAN HMC SD */
120 full_obj
= &hw
->hmc
.hmc_obj
[I40E_HMC_LAN_FULL
];
121 full_obj
->max_cnt
= 0;
126 /* Tx queue context information */
127 obj
= &hw
->hmc
.hmc_obj
[I40E_HMC_LAN_TX
];
128 obj
->max_cnt
= rd32(hw
, I40E_GLHMC_LANQMAX
);
131 size_exp
= rd32(hw
, I40E_GLHMC_LANTXOBJSZ
);
132 obj
->size
= BIT_ULL(size_exp
);
134 /* validate values requested by driver don't exceed HMC capacity */
135 if (txq_num
> obj
->max_cnt
) {
136 ret_code
= I40E_ERR_INVALID_HMC_OBJ_COUNT
;
137 hw_dbg(hw
, "i40e_init_lan_hmc: Tx context: asks for 0x%x but max allowed is 0x%x, returns error %d\n",
138 txq_num
, obj
->max_cnt
, ret_code
);
139 goto init_lan_hmc_out
;
142 /* aggregate values into the full LAN object for later */
143 full_obj
->max_cnt
+= obj
->max_cnt
;
144 full_obj
->cnt
+= obj
->cnt
;
146 /* Rx queue context information */
147 obj
= &hw
->hmc
.hmc_obj
[I40E_HMC_LAN_RX
];
148 obj
->max_cnt
= rd32(hw
, I40E_GLHMC_LANQMAX
);
150 obj
->base
= hw
->hmc
.hmc_obj
[I40E_HMC_LAN_TX
].base
+
151 (hw
->hmc
.hmc_obj
[I40E_HMC_LAN_TX
].cnt
*
152 hw
->hmc
.hmc_obj
[I40E_HMC_LAN_TX
].size
);
153 obj
->base
= i40e_align_l2obj_base(obj
->base
);
154 size_exp
= rd32(hw
, I40E_GLHMC_LANRXOBJSZ
);
155 obj
->size
= BIT_ULL(size_exp
);
157 /* validate values requested by driver don't exceed HMC capacity */
158 if (rxq_num
> obj
->max_cnt
) {
159 ret_code
= I40E_ERR_INVALID_HMC_OBJ_COUNT
;
160 hw_dbg(hw
, "i40e_init_lan_hmc: Rx context: asks for 0x%x but max allowed is 0x%x, returns error %d\n",
161 rxq_num
, obj
->max_cnt
, ret_code
);
162 goto init_lan_hmc_out
;
165 /* aggregate values into the full LAN object for later */
166 full_obj
->max_cnt
+= obj
->max_cnt
;
167 full_obj
->cnt
+= obj
->cnt
;
169 /* FCoE context information */
170 obj
= &hw
->hmc
.hmc_obj
[I40E_HMC_FCOE_CTX
];
171 obj
->max_cnt
= rd32(hw
, I40E_GLHMC_FCOEMAX
);
172 obj
->cnt
= fcoe_cntx_num
;
173 obj
->base
= hw
->hmc
.hmc_obj
[I40E_HMC_LAN_RX
].base
+
174 (hw
->hmc
.hmc_obj
[I40E_HMC_LAN_RX
].cnt
*
175 hw
->hmc
.hmc_obj
[I40E_HMC_LAN_RX
].size
);
176 obj
->base
= i40e_align_l2obj_base(obj
->base
);
177 size_exp
= rd32(hw
, I40E_GLHMC_FCOEDDPOBJSZ
);
178 obj
->size
= BIT_ULL(size_exp
);
180 /* validate values requested by driver don't exceed HMC capacity */
181 if (fcoe_cntx_num
> obj
->max_cnt
) {
182 ret_code
= I40E_ERR_INVALID_HMC_OBJ_COUNT
;
183 hw_dbg(hw
, "i40e_init_lan_hmc: FCoE context: asks for 0x%x but max allowed is 0x%x, returns error %d\n",
184 fcoe_cntx_num
, obj
->max_cnt
, ret_code
);
185 goto init_lan_hmc_out
;
188 /* aggregate values into the full LAN object for later */
189 full_obj
->max_cnt
+= obj
->max_cnt
;
190 full_obj
->cnt
+= obj
->cnt
;
192 /* FCoE filter information */
193 obj
= &hw
->hmc
.hmc_obj
[I40E_HMC_FCOE_FILT
];
194 obj
->max_cnt
= rd32(hw
, I40E_GLHMC_FCOEFMAX
);
195 obj
->cnt
= fcoe_filt_num
;
196 obj
->base
= hw
->hmc
.hmc_obj
[I40E_HMC_FCOE_CTX
].base
+
197 (hw
->hmc
.hmc_obj
[I40E_HMC_FCOE_CTX
].cnt
*
198 hw
->hmc
.hmc_obj
[I40E_HMC_FCOE_CTX
].size
);
199 obj
->base
= i40e_align_l2obj_base(obj
->base
);
200 size_exp
= rd32(hw
, I40E_GLHMC_FCOEFOBJSZ
);
201 obj
->size
= BIT_ULL(size_exp
);
203 /* validate values requested by driver don't exceed HMC capacity */
204 if (fcoe_filt_num
> obj
->max_cnt
) {
205 ret_code
= I40E_ERR_INVALID_HMC_OBJ_COUNT
;
206 hw_dbg(hw
, "i40e_init_lan_hmc: FCoE filter: asks for 0x%x but max allowed is 0x%x, returns error %d\n",
207 fcoe_filt_num
, obj
->max_cnt
, ret_code
);
208 goto init_lan_hmc_out
;
211 /* aggregate values into the full LAN object for later */
212 full_obj
->max_cnt
+= obj
->max_cnt
;
213 full_obj
->cnt
+= obj
->cnt
;
215 hw
->hmc
.first_sd_index
= 0;
216 hw
->hmc
.sd_table
.ref_cnt
= 0;
217 l2fpm_size
= i40e_calculate_l2fpm_size(txq_num
, rxq_num
, fcoe_cntx_num
,
219 if (NULL
== hw
->hmc
.sd_table
.sd_entry
) {
220 hw
->hmc
.sd_table
.sd_cnt
= (u32
)
221 (l2fpm_size
+ I40E_HMC_DIRECT_BP_SIZE
- 1) /
222 I40E_HMC_DIRECT_BP_SIZE
;
224 /* allocate the sd_entry members in the sd_table */
225 ret_code
= i40e_allocate_virt_mem(hw
, &hw
->hmc
.sd_table
.addr
,
226 (sizeof(struct i40e_hmc_sd_entry
) *
227 hw
->hmc
.sd_table
.sd_cnt
));
229 goto init_lan_hmc_out
;
230 hw
->hmc
.sd_table
.sd_entry
=
231 (struct i40e_hmc_sd_entry
*)hw
->hmc
.sd_table
.addr
.va
;
233 /* store in the LAN full object for later */
234 full_obj
->size
= l2fpm_size
;
241 * i40e_remove_pd_page - Remove a page from the page descriptor table
242 * @hw: pointer to the HW structure
243 * @hmc_info: pointer to the HMC configuration information structure
244 * @idx: segment descriptor index to find the relevant page descriptor
247 * 1. Marks the entry in pd table (for paged address mode) invalid
248 * 2. write to register PMPDINV to invalidate the backing page in FV cache
249 * 3. Decrement the ref count for pd_entry
251 * 1. caller can deallocate the memory used by pd after this function
254 static i40e_status
i40e_remove_pd_page(struct i40e_hw
*hw
,
255 struct i40e_hmc_info
*hmc_info
,
258 i40e_status ret_code
= 0;
260 if (!i40e_prep_remove_pd_page(hmc_info
, idx
))
261 ret_code
= i40e_remove_pd_page_new(hw
, hmc_info
, idx
, true);
267 * i40e_remove_sd_bp - remove a backing page from a segment descriptor
268 * @hw: pointer to our HW structure
269 * @hmc_info: pointer to the HMC configuration information structure
270 * @idx: the page index
273 * 1. Marks the entry in sd table (for direct address mode) invalid
274 * 2. write to register PMSDCMD, PMSDDATALOW(PMSDDATALOW.PMSDVALID set
275 * to 0) and PMSDDATAHIGH to invalidate the sd page
276 * 3. Decrement the ref count for the sd_entry
278 * 1. caller can deallocate the memory used by backing storage after this
281 static i40e_status
i40e_remove_sd_bp(struct i40e_hw
*hw
,
282 struct i40e_hmc_info
*hmc_info
,
285 i40e_status ret_code
= 0;
287 if (!i40e_prep_remove_sd_bp(hmc_info
, idx
))
288 ret_code
= i40e_remove_sd_bp_new(hw
, hmc_info
, idx
, true);
294 * i40e_create_lan_hmc_object - allocate backing store for hmc objects
295 * @hw: pointer to the HW structure
296 * @info: pointer to i40e_hmc_create_obj_info struct
298 * This will allocate memory for PDs and backing pages and populate
299 * the sd and pd entries.
301 static i40e_status
i40e_create_lan_hmc_object(struct i40e_hw
*hw
,
302 struct i40e_hmc_lan_create_obj_info
*info
)
304 i40e_status ret_code
= 0;
305 struct i40e_hmc_sd_entry
*sd_entry
;
306 u32 pd_idx1
= 0, pd_lmt1
= 0;
307 u32 pd_idx
= 0, pd_lmt
= 0;
308 bool pd_error
= false;
314 ret_code
= I40E_ERR_BAD_PTR
;
315 hw_dbg(hw
, "i40e_create_lan_hmc_object: bad info ptr\n");
318 if (NULL
== info
->hmc_info
) {
319 ret_code
= I40E_ERR_BAD_PTR
;
320 hw_dbg(hw
, "i40e_create_lan_hmc_object: bad hmc_info ptr\n");
323 if (I40E_HMC_INFO_SIGNATURE
!= info
->hmc_info
->signature
) {
324 ret_code
= I40E_ERR_BAD_PTR
;
325 hw_dbg(hw
, "i40e_create_lan_hmc_object: bad signature\n");
329 if (info
->start_idx
>= info
->hmc_info
->hmc_obj
[info
->rsrc_type
].cnt
) {
330 ret_code
= I40E_ERR_INVALID_HMC_OBJ_INDEX
;
331 hw_dbg(hw
, "i40e_create_lan_hmc_object: returns error %d\n",
335 if ((info
->start_idx
+ info
->count
) >
336 info
->hmc_info
->hmc_obj
[info
->rsrc_type
].cnt
) {
337 ret_code
= I40E_ERR_INVALID_HMC_OBJ_COUNT
;
338 hw_dbg(hw
, "i40e_create_lan_hmc_object: returns error %d\n",
343 /* find sd index and limit */
344 I40E_FIND_SD_INDEX_LIMIT(info
->hmc_info
, info
->rsrc_type
,
345 info
->start_idx
, info
->count
,
347 if (sd_idx
>= info
->hmc_info
->sd_table
.sd_cnt
||
348 sd_lmt
> info
->hmc_info
->sd_table
.sd_cnt
) {
349 ret_code
= I40E_ERR_INVALID_SD_INDEX
;
353 I40E_FIND_PD_INDEX_LIMIT(info
->hmc_info
, info
->rsrc_type
,
354 info
->start_idx
, info
->count
, &pd_idx
,
357 /* This is to cover for cases where you may not want to have an SD with
358 * the full 2M memory but something smaller. By not filling out any
359 * size, the function will default the SD size to be 2M.
361 if (info
->direct_mode_sz
== 0)
362 sd_size
= I40E_HMC_DIRECT_BP_SIZE
;
364 sd_size
= info
->direct_mode_sz
;
366 /* check if all the sds are valid. If not, allocate a page and
369 for (j
= sd_idx
; j
< sd_lmt
; j
++) {
370 /* update the sd table entry */
371 ret_code
= i40e_add_sd_table_entry(hw
, info
->hmc_info
, j
,
376 sd_entry
= &info
->hmc_info
->sd_table
.sd_entry
[j
];
377 if (I40E_SD_TYPE_PAGED
== sd_entry
->entry_type
) {
378 /* check if all the pds in this sd are valid. If not,
379 * allocate a page and initialize it.
382 /* find pd_idx and pd_lmt in this sd */
383 pd_idx1
= max(pd_idx
, (j
* I40E_HMC_MAX_BP_COUNT
));
384 pd_lmt1
= min(pd_lmt
,
385 ((j
+ 1) * I40E_HMC_MAX_BP_COUNT
));
386 for (i
= pd_idx1
; i
< pd_lmt1
; i
++) {
387 /* update the pd table entry */
388 ret_code
= i40e_add_pd_table_entry(hw
,
397 /* remove the backing pages from pd_idx1 to i */
398 while (i
&& (i
> pd_idx1
)) {
399 i40e_remove_pd_bp(hw
, info
->hmc_info
,
405 if (!sd_entry
->valid
) {
406 sd_entry
->valid
= true;
407 switch (sd_entry
->entry_type
) {
408 case I40E_SD_TYPE_PAGED
:
409 I40E_SET_PF_SD_ENTRY(hw
,
410 sd_entry
->u
.pd_table
.pd_page_addr
.pa
,
411 j
, sd_entry
->entry_type
);
413 case I40E_SD_TYPE_DIRECT
:
414 I40E_SET_PF_SD_ENTRY(hw
, sd_entry
->u
.bp
.addr
.pa
,
415 j
, sd_entry
->entry_type
);
418 ret_code
= I40E_ERR_INVALID_SD_TYPE
;
426 /* cleanup for sd entries from j to sd_idx */
427 while (j
&& (j
> sd_idx
)) {
428 sd_entry
= &info
->hmc_info
->sd_table
.sd_entry
[j
- 1];
429 switch (sd_entry
->entry_type
) {
430 case I40E_SD_TYPE_PAGED
:
431 pd_idx1
= max(pd_idx
,
432 ((j
- 1) * I40E_HMC_MAX_BP_COUNT
));
433 pd_lmt1
= min(pd_lmt
, (j
* I40E_HMC_MAX_BP_COUNT
));
434 for (i
= pd_idx1
; i
< pd_lmt1
; i
++)
435 i40e_remove_pd_bp(hw
, info
->hmc_info
, i
);
436 i40e_remove_pd_page(hw
, info
->hmc_info
, (j
- 1));
438 case I40E_SD_TYPE_DIRECT
:
439 i40e_remove_sd_bp(hw
, info
->hmc_info
, (j
- 1));
442 ret_code
= I40E_ERR_INVALID_SD_TYPE
;
452 * i40e_configure_lan_hmc - prepare the HMC backing store
453 * @hw: pointer to the hw structure
454 * @model: the model for the layout of the SD/PD tables
456 * - This function will be called once per physical function initialization.
457 * - This function will be called after i40e_init_lan_hmc() and before
458 * any LAN/FCoE HMC objects can be created.
460 i40e_status
i40e_configure_lan_hmc(struct i40e_hw
*hw
,
461 enum i40e_hmc_model model
)
463 struct i40e_hmc_lan_create_obj_info info
;
464 i40e_status ret_code
= 0;
465 u8 hmc_fn_id
= hw
->hmc
.hmc_fn_id
;
466 struct i40e_hmc_obj_info
*obj
;
468 /* Initialize part of the create object info struct */
469 info
.hmc_info
= &hw
->hmc
;
470 info
.rsrc_type
= I40E_HMC_LAN_FULL
;
472 info
.direct_mode_sz
= hw
->hmc
.hmc_obj
[I40E_HMC_LAN_FULL
].size
;
474 /* Build the SD entry for the LAN objects */
476 case I40E_HMC_MODEL_DIRECT_PREFERRED
:
477 case I40E_HMC_MODEL_DIRECT_ONLY
:
478 info
.entry_type
= I40E_SD_TYPE_DIRECT
;
479 /* Make one big object, a single SD */
481 ret_code
= i40e_create_lan_hmc_object(hw
, &info
);
482 if (ret_code
&& (model
== I40E_HMC_MODEL_DIRECT_PREFERRED
))
485 goto configure_lan_hmc_out
;
486 /* else clause falls through the break */
488 case I40E_HMC_MODEL_PAGED_ONLY
:
490 info
.entry_type
= I40E_SD_TYPE_PAGED
;
491 /* Make one big object in the PD table */
493 ret_code
= i40e_create_lan_hmc_object(hw
, &info
);
495 goto configure_lan_hmc_out
;
498 /* unsupported type */
499 ret_code
= I40E_ERR_INVALID_SD_TYPE
;
500 hw_dbg(hw
, "i40e_configure_lan_hmc: Unknown SD type: %d\n",
502 goto configure_lan_hmc_out
;
505 /* Configure and program the FPM registers so objects can be created */
508 obj
= &hw
->hmc
.hmc_obj
[I40E_HMC_LAN_TX
];
509 wr32(hw
, I40E_GLHMC_LANTXBASE(hmc_fn_id
),
510 (u32
)((obj
->base
& I40E_GLHMC_LANTXBASE_FPMLANTXBASE_MASK
) / 512));
511 wr32(hw
, I40E_GLHMC_LANTXCNT(hmc_fn_id
), obj
->cnt
);
514 obj
= &hw
->hmc
.hmc_obj
[I40E_HMC_LAN_RX
];
515 wr32(hw
, I40E_GLHMC_LANRXBASE(hmc_fn_id
),
516 (u32
)((obj
->base
& I40E_GLHMC_LANRXBASE_FPMLANRXBASE_MASK
) / 512));
517 wr32(hw
, I40E_GLHMC_LANRXCNT(hmc_fn_id
), obj
->cnt
);
520 obj
= &hw
->hmc
.hmc_obj
[I40E_HMC_FCOE_CTX
];
521 wr32(hw
, I40E_GLHMC_FCOEDDPBASE(hmc_fn_id
),
522 (u32
)((obj
->base
& I40E_GLHMC_FCOEDDPBASE_FPMFCOEDDPBASE_MASK
) / 512));
523 wr32(hw
, I40E_GLHMC_FCOEDDPCNT(hmc_fn_id
), obj
->cnt
);
526 obj
= &hw
->hmc
.hmc_obj
[I40E_HMC_FCOE_FILT
];
527 wr32(hw
, I40E_GLHMC_FCOEFBASE(hmc_fn_id
),
528 (u32
)((obj
->base
& I40E_GLHMC_FCOEFBASE_FPMFCOEFBASE_MASK
) / 512));
529 wr32(hw
, I40E_GLHMC_FCOEFCNT(hmc_fn_id
), obj
->cnt
);
531 configure_lan_hmc_out
:
536 * i40e_delete_hmc_object - remove hmc objects
537 * @hw: pointer to the HW structure
538 * @info: pointer to i40e_hmc_delete_obj_info struct
540 * This will de-populate the SDs and PDs. It frees
541 * the memory for PDS and backing storage. After this function is returned,
542 * caller should deallocate memory allocated previously for
543 * book-keeping information about PDs and backing storage.
545 static i40e_status
i40e_delete_lan_hmc_object(struct i40e_hw
*hw
,
546 struct i40e_hmc_lan_delete_obj_info
*info
)
548 i40e_status ret_code
= 0;
549 struct i40e_hmc_pd_table
*pd_table
;
550 u32 pd_idx
, pd_lmt
, rel_pd_idx
;
555 ret_code
= I40E_ERR_BAD_PTR
;
556 hw_dbg(hw
, "i40e_delete_hmc_object: bad info ptr\n");
559 if (NULL
== info
->hmc_info
) {
560 ret_code
= I40E_ERR_BAD_PTR
;
561 hw_dbg(hw
, "i40e_delete_hmc_object: bad info->hmc_info ptr\n");
564 if (I40E_HMC_INFO_SIGNATURE
!= info
->hmc_info
->signature
) {
565 ret_code
= I40E_ERR_BAD_PTR
;
566 hw_dbg(hw
, "i40e_delete_hmc_object: bad hmc_info->signature\n");
570 if (NULL
== info
->hmc_info
->sd_table
.sd_entry
) {
571 ret_code
= I40E_ERR_BAD_PTR
;
572 hw_dbg(hw
, "i40e_delete_hmc_object: bad sd_entry\n");
576 if (NULL
== info
->hmc_info
->hmc_obj
) {
577 ret_code
= I40E_ERR_BAD_PTR
;
578 hw_dbg(hw
, "i40e_delete_hmc_object: bad hmc_info->hmc_obj\n");
581 if (info
->start_idx
>= info
->hmc_info
->hmc_obj
[info
->rsrc_type
].cnt
) {
582 ret_code
= I40E_ERR_INVALID_HMC_OBJ_INDEX
;
583 hw_dbg(hw
, "i40e_delete_hmc_object: returns error %d\n",
588 if ((info
->start_idx
+ info
->count
) >
589 info
->hmc_info
->hmc_obj
[info
->rsrc_type
].cnt
) {
590 ret_code
= I40E_ERR_INVALID_HMC_OBJ_COUNT
;
591 hw_dbg(hw
, "i40e_delete_hmc_object: returns error %d\n",
596 I40E_FIND_PD_INDEX_LIMIT(info
->hmc_info
, info
->rsrc_type
,
597 info
->start_idx
, info
->count
, &pd_idx
,
600 for (j
= pd_idx
; j
< pd_lmt
; j
++) {
601 sd_idx
= j
/ I40E_HMC_PD_CNT_IN_SD
;
603 if (I40E_SD_TYPE_PAGED
!=
604 info
->hmc_info
->sd_table
.sd_entry
[sd_idx
].entry_type
)
607 rel_pd_idx
= j
% I40E_HMC_PD_CNT_IN_SD
;
610 &info
->hmc_info
->sd_table
.sd_entry
[sd_idx
].u
.pd_table
;
611 if (pd_table
->pd_entry
[rel_pd_idx
].valid
) {
612 ret_code
= i40e_remove_pd_bp(hw
, info
->hmc_info
, j
);
618 /* find sd index and limit */
619 I40E_FIND_SD_INDEX_LIMIT(info
->hmc_info
, info
->rsrc_type
,
620 info
->start_idx
, info
->count
,
622 if (sd_idx
>= info
->hmc_info
->sd_table
.sd_cnt
||
623 sd_lmt
> info
->hmc_info
->sd_table
.sd_cnt
) {
624 ret_code
= I40E_ERR_INVALID_SD_INDEX
;
628 for (i
= sd_idx
; i
< sd_lmt
; i
++) {
629 if (!info
->hmc_info
->sd_table
.sd_entry
[i
].valid
)
631 switch (info
->hmc_info
->sd_table
.sd_entry
[i
].entry_type
) {
632 case I40E_SD_TYPE_DIRECT
:
633 ret_code
= i40e_remove_sd_bp(hw
, info
->hmc_info
, i
);
637 case I40E_SD_TYPE_PAGED
:
638 ret_code
= i40e_remove_pd_page(hw
, info
->hmc_info
, i
);
651 * i40e_shutdown_lan_hmc - Remove HMC backing store, free allocated memory
652 * @hw: pointer to the hw structure
654 * This must be called by drivers as they are shutting down and being
655 * removed from the OS.
657 i40e_status
i40e_shutdown_lan_hmc(struct i40e_hw
*hw
)
659 struct i40e_hmc_lan_delete_obj_info info
;
660 i40e_status ret_code
;
662 info
.hmc_info
= &hw
->hmc
;
663 info
.rsrc_type
= I40E_HMC_LAN_FULL
;
667 /* delete the object */
668 ret_code
= i40e_delete_lan_hmc_object(hw
, &info
);
670 /* free the SD table entry for LAN */
671 i40e_free_virt_mem(hw
, &hw
->hmc
.sd_table
.addr
);
672 hw
->hmc
.sd_table
.sd_cnt
= 0;
673 hw
->hmc
.sd_table
.sd_entry
= NULL
;
675 /* free memory used for hmc_obj */
676 i40e_free_virt_mem(hw
, &hw
->hmc
.hmc_obj_virt_mem
);
677 hw
->hmc
.hmc_obj
= NULL
;
682 #define I40E_HMC_STORE(_struct, _ele) \
683 offsetof(struct _struct, _ele), \
684 FIELD_SIZEOF(struct _struct, _ele)
686 struct i40e_context_ele
{
693 /* LAN Tx Queue Context */
694 static struct i40e_context_ele i40e_hmc_txq_ce_info
[] = {
695 /* Field Width LSB */
696 {I40E_HMC_STORE(i40e_hmc_obj_txq
, head
), 13, 0 },
697 {I40E_HMC_STORE(i40e_hmc_obj_txq
, new_context
), 1, 30 },
698 {I40E_HMC_STORE(i40e_hmc_obj_txq
, base
), 57, 32 },
699 {I40E_HMC_STORE(i40e_hmc_obj_txq
, fc_ena
), 1, 89 },
700 {I40E_HMC_STORE(i40e_hmc_obj_txq
, timesync_ena
), 1, 90 },
701 {I40E_HMC_STORE(i40e_hmc_obj_txq
, fd_ena
), 1, 91 },
702 {I40E_HMC_STORE(i40e_hmc_obj_txq
, alt_vlan_ena
), 1, 92 },
703 {I40E_HMC_STORE(i40e_hmc_obj_txq
, cpuid
), 8, 96 },
705 {I40E_HMC_STORE(i40e_hmc_obj_txq
, thead_wb
), 13, 0 + 128 },
706 {I40E_HMC_STORE(i40e_hmc_obj_txq
, head_wb_ena
), 1, 32 + 128 },
707 {I40E_HMC_STORE(i40e_hmc_obj_txq
, qlen
), 13, 33 + 128 },
708 {I40E_HMC_STORE(i40e_hmc_obj_txq
, tphrdesc_ena
), 1, 46 + 128 },
709 {I40E_HMC_STORE(i40e_hmc_obj_txq
, tphrpacket_ena
), 1, 47 + 128 },
710 {I40E_HMC_STORE(i40e_hmc_obj_txq
, tphwdesc_ena
), 1, 48 + 128 },
711 {I40E_HMC_STORE(i40e_hmc_obj_txq
, head_wb_addr
), 64, 64 + 128 },
713 {I40E_HMC_STORE(i40e_hmc_obj_txq
, crc
), 32, 0 + (7 * 128) },
714 {I40E_HMC_STORE(i40e_hmc_obj_txq
, rdylist
), 10, 84 + (7 * 128) },
715 {I40E_HMC_STORE(i40e_hmc_obj_txq
, rdylist_act
), 1, 94 + (7 * 128) },
719 /* LAN Rx Queue Context */
720 static struct i40e_context_ele i40e_hmc_rxq_ce_info
[] = {
721 /* Field Width LSB */
722 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, head
), 13, 0 },
723 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, cpuid
), 8, 13 },
724 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, base
), 57, 32 },
725 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, qlen
), 13, 89 },
726 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, dbuff
), 7, 102 },
727 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, hbuff
), 5, 109 },
728 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, dtype
), 2, 114 },
729 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, dsize
), 1, 116 },
730 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, crcstrip
), 1, 117 },
731 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, fc_ena
), 1, 118 },
732 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, l2tsel
), 1, 119 },
733 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, hsplit_0
), 4, 120 },
734 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, hsplit_1
), 2, 124 },
735 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, showiv
), 1, 127 },
736 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, rxmax
), 14, 174 },
737 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, tphrdesc_ena
), 1, 193 },
738 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, tphwdesc_ena
), 1, 194 },
739 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, tphdata_ena
), 1, 195 },
740 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, tphhead_ena
), 1, 196 },
741 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, lrxqthresh
), 3, 198 },
742 { I40E_HMC_STORE(i40e_hmc_obj_rxq
, prefena
), 1, 201 },
747 * i40e_write_byte - replace HMC context byte
748 * @hmc_bits: pointer to the HMC memory
749 * @ce_info: a description of the struct to be read from
750 * @src: the struct to be read from
752 static void i40e_write_byte(u8
*hmc_bits
,
753 struct i40e_context_ele
*ce_info
,
756 u8 src_byte
, dest_byte
, mask
;
760 /* copy from the next struct field */
761 from
= src
+ ce_info
->offset
;
763 /* prepare the bits and mask */
764 shift_width
= ce_info
->lsb
% 8;
765 mask
= (u8
)(BIT(ce_info
->width
) - 1);
770 /* shift to correct alignment */
771 mask
<<= shift_width
;
772 src_byte
<<= shift_width
;
774 /* get the current bits from the target bit string */
775 dest
= hmc_bits
+ (ce_info
->lsb
/ 8);
777 memcpy(&dest_byte
, dest
, sizeof(dest_byte
));
779 dest_byte
&= ~mask
; /* get the bits not changing */
780 dest_byte
|= src_byte
; /* add in the new bits */
782 /* put it all back */
783 memcpy(dest
, &dest_byte
, sizeof(dest_byte
));
787 * i40e_write_word - replace HMC context word
788 * @hmc_bits: pointer to the HMC memory
789 * @ce_info: a description of the struct to be read from
790 * @src: the struct to be read from
792 static void i40e_write_word(u8
*hmc_bits
,
793 struct i40e_context_ele
*ce_info
,
801 /* copy from the next struct field */
802 from
= src
+ ce_info
->offset
;
804 /* prepare the bits and mask */
805 shift_width
= ce_info
->lsb
% 8;
806 mask
= BIT(ce_info
->width
) - 1;
808 /* don't swizzle the bits until after the mask because the mask bits
809 * will be in a different bit position on big endian machines
811 src_word
= *(u16
*)from
;
814 /* shift to correct alignment */
815 mask
<<= shift_width
;
816 src_word
<<= shift_width
;
818 /* get the current bits from the target bit string */
819 dest
= hmc_bits
+ (ce_info
->lsb
/ 8);
821 memcpy(&dest_word
, dest
, sizeof(dest_word
));
823 dest_word
&= ~(cpu_to_le16(mask
)); /* get the bits not changing */
824 dest_word
|= cpu_to_le16(src_word
); /* add in the new bits */
826 /* put it all back */
827 memcpy(dest
, &dest_word
, sizeof(dest_word
));
831 * i40e_write_dword - replace HMC context dword
832 * @hmc_bits: pointer to the HMC memory
833 * @ce_info: a description of the struct to be read from
834 * @src: the struct to be read from
836 static void i40e_write_dword(u8
*hmc_bits
,
837 struct i40e_context_ele
*ce_info
,
845 /* copy from the next struct field */
846 from
= src
+ ce_info
->offset
;
848 /* prepare the bits and mask */
849 shift_width
= ce_info
->lsb
% 8;
851 /* if the field width is exactly 32 on an x86 machine, then the shift
852 * operation will not work because the SHL instructions count is masked
853 * to 5 bits so the shift will do nothing
855 if (ce_info
->width
< 32)
856 mask
= BIT(ce_info
->width
) - 1;
860 /* don't swizzle the bits until after the mask because the mask bits
861 * will be in a different bit position on big endian machines
863 src_dword
= *(u32
*)from
;
866 /* shift to correct alignment */
867 mask
<<= shift_width
;
868 src_dword
<<= shift_width
;
870 /* get the current bits from the target bit string */
871 dest
= hmc_bits
+ (ce_info
->lsb
/ 8);
873 memcpy(&dest_dword
, dest
, sizeof(dest_dword
));
875 dest_dword
&= ~(cpu_to_le32(mask
)); /* get the bits not changing */
876 dest_dword
|= cpu_to_le32(src_dword
); /* add in the new bits */
878 /* put it all back */
879 memcpy(dest
, &dest_dword
, sizeof(dest_dword
));
883 * i40e_write_qword - replace HMC context qword
884 * @hmc_bits: pointer to the HMC memory
885 * @ce_info: a description of the struct to be read from
886 * @src: the struct to be read from
888 static void i40e_write_qword(u8
*hmc_bits
,
889 struct i40e_context_ele
*ce_info
,
897 /* copy from the next struct field */
898 from
= src
+ ce_info
->offset
;
900 /* prepare the bits and mask */
901 shift_width
= ce_info
->lsb
% 8;
903 /* if the field width is exactly 64 on an x86 machine, then the shift
904 * operation will not work because the SHL instructions count is masked
905 * to 6 bits so the shift will do nothing
907 if (ce_info
->width
< 64)
908 mask
= BIT_ULL(ce_info
->width
) - 1;
912 /* don't swizzle the bits until after the mask because the mask bits
913 * will be in a different bit position on big endian machines
915 src_qword
= *(u64
*)from
;
918 /* shift to correct alignment */
919 mask
<<= shift_width
;
920 src_qword
<<= shift_width
;
922 /* get the current bits from the target bit string */
923 dest
= hmc_bits
+ (ce_info
->lsb
/ 8);
925 memcpy(&dest_qword
, dest
, sizeof(dest_qword
));
927 dest_qword
&= ~(cpu_to_le64(mask
)); /* get the bits not changing */
928 dest_qword
|= cpu_to_le64(src_qword
); /* add in the new bits */
930 /* put it all back */
931 memcpy(dest
, &dest_qword
, sizeof(dest_qword
));
935 * i40e_clear_hmc_context - zero out the HMC context bits
936 * @hw: the hardware struct
937 * @context_bytes: pointer to the context bit array (DMA memory)
938 * @hmc_type: the type of HMC resource
940 static i40e_status
i40e_clear_hmc_context(struct i40e_hw
*hw
,
942 enum i40e_hmc_lan_rsrc_type hmc_type
)
944 /* clean the bit array */
945 memset(context_bytes
, 0, (u32
)hw
->hmc
.hmc_obj
[hmc_type
].size
);
951 * i40e_set_hmc_context - replace HMC context bits
952 * @context_bytes: pointer to the context bit array
953 * @ce_info: a description of the struct to be filled
954 * @dest: the struct to be filled
956 static i40e_status
i40e_set_hmc_context(u8
*context_bytes
,
957 struct i40e_context_ele
*ce_info
,
962 for (f
= 0; ce_info
[f
].width
!= 0; f
++) {
964 /* we have to deal with each element of the HMC using the
965 * correct size so that we are correct regardless of the
966 * endianness of the machine
968 switch (ce_info
[f
].size_of
) {
970 i40e_write_byte(context_bytes
, &ce_info
[f
], dest
);
973 i40e_write_word(context_bytes
, &ce_info
[f
], dest
);
976 i40e_write_dword(context_bytes
, &ce_info
[f
], dest
);
979 i40e_write_qword(context_bytes
, &ce_info
[f
], dest
);
988 * i40e_hmc_get_object_va - retrieves an object's virtual address
989 * @hmc_info: pointer to i40e_hmc_info struct
990 * @object_base: pointer to u64 to get the va
991 * @rsrc_type: the hmc resource type
992 * @obj_idx: hmc object index
994 * This function retrieves the object's virtual address from the object
995 * base pointer. This function is used for LAN Queue contexts.
998 i40e_status
i40e_hmc_get_object_va(struct i40e_hmc_info
*hmc_info
,
1000 enum i40e_hmc_lan_rsrc_type rsrc_type
,
1003 u32 obj_offset_in_sd
, obj_offset_in_pd
;
1004 i40e_status ret_code
= 0;
1005 struct i40e_hmc_sd_entry
*sd_entry
;
1006 struct i40e_hmc_pd_entry
*pd_entry
;
1007 u32 pd_idx
, pd_lmt
, rel_pd_idx
;
1008 u64 obj_offset_in_fpm
;
1011 if (NULL
== hmc_info
) {
1012 ret_code
= I40E_ERR_BAD_PTR
;
1013 hw_dbg(hw
, "i40e_hmc_get_object_va: bad hmc_info ptr\n");
1016 if (NULL
== hmc_info
->hmc_obj
) {
1017 ret_code
= I40E_ERR_BAD_PTR
;
1018 hw_dbg(hw
, "i40e_hmc_get_object_va: bad hmc_info->hmc_obj ptr\n");
1021 if (NULL
== object_base
) {
1022 ret_code
= I40E_ERR_BAD_PTR
;
1023 hw_dbg(hw
, "i40e_hmc_get_object_va: bad object_base ptr\n");
1026 if (I40E_HMC_INFO_SIGNATURE
!= hmc_info
->signature
) {
1027 ret_code
= I40E_ERR_BAD_PTR
;
1028 hw_dbg(hw
, "i40e_hmc_get_object_va: bad hmc_info->signature\n");
1031 if (obj_idx
>= hmc_info
->hmc_obj
[rsrc_type
].cnt
) {
1032 hw_dbg(hw
, "i40e_hmc_get_object_va: returns error %d\n",
1034 ret_code
= I40E_ERR_INVALID_HMC_OBJ_INDEX
;
1037 /* find sd index and limit */
1038 I40E_FIND_SD_INDEX_LIMIT(hmc_info
, rsrc_type
, obj_idx
, 1,
1041 sd_entry
= &hmc_info
->sd_table
.sd_entry
[sd_idx
];
1042 obj_offset_in_fpm
= hmc_info
->hmc_obj
[rsrc_type
].base
+
1043 hmc_info
->hmc_obj
[rsrc_type
].size
* obj_idx
;
1045 if (I40E_SD_TYPE_PAGED
== sd_entry
->entry_type
) {
1046 I40E_FIND_PD_INDEX_LIMIT(hmc_info
, rsrc_type
, obj_idx
, 1,
1048 rel_pd_idx
= pd_idx
% I40E_HMC_PD_CNT_IN_SD
;
1049 pd_entry
= &sd_entry
->u
.pd_table
.pd_entry
[rel_pd_idx
];
1050 obj_offset_in_pd
= (u32
)(obj_offset_in_fpm
%
1051 I40E_HMC_PAGED_BP_SIZE
);
1052 *object_base
= (u8
*)pd_entry
->bp
.addr
.va
+ obj_offset_in_pd
;
1054 obj_offset_in_sd
= (u32
)(obj_offset_in_fpm
%
1055 I40E_HMC_DIRECT_BP_SIZE
);
1056 *object_base
= (u8
*)sd_entry
->u
.bp
.addr
.va
+ obj_offset_in_sd
;
1063 * i40e_clear_lan_tx_queue_context - clear the HMC context for the queue
1064 * @hw: the hardware struct
1065 * @queue: the queue we care about
1067 i40e_status
i40e_clear_lan_tx_queue_context(struct i40e_hw
*hw
,
1073 err
= i40e_hmc_get_object_va(&hw
->hmc
, &context_bytes
,
1074 I40E_HMC_LAN_TX
, queue
);
1078 return i40e_clear_hmc_context(hw
, context_bytes
, I40E_HMC_LAN_TX
);
1082 * i40e_set_lan_tx_queue_context - set the HMC context for the queue
1083 * @hw: the hardware struct
1084 * @queue: the queue we care about
1085 * @s: the struct to be filled
1087 i40e_status
i40e_set_lan_tx_queue_context(struct i40e_hw
*hw
,
1089 struct i40e_hmc_obj_txq
*s
)
1094 err
= i40e_hmc_get_object_va(&hw
->hmc
, &context_bytes
,
1095 I40E_HMC_LAN_TX
, queue
);
1099 return i40e_set_hmc_context(context_bytes
,
1100 i40e_hmc_txq_ce_info
, (u8
*)s
);
1104 * i40e_clear_lan_rx_queue_context - clear the HMC context for the queue
1105 * @hw: the hardware struct
1106 * @queue: the queue we care about
1108 i40e_status
i40e_clear_lan_rx_queue_context(struct i40e_hw
*hw
,
1114 err
= i40e_hmc_get_object_va(&hw
->hmc
, &context_bytes
,
1115 I40E_HMC_LAN_RX
, queue
);
1119 return i40e_clear_hmc_context(hw
, context_bytes
, I40E_HMC_LAN_RX
);
1123 * i40e_set_lan_rx_queue_context - set the HMC context for the queue
1124 * @hw: the hardware struct
1125 * @queue: the queue we care about
1126 * @s: the struct to be filled
1128 i40e_status
i40e_set_lan_rx_queue_context(struct i40e_hw
*hw
,
1130 struct i40e_hmc_obj_rxq
*s
)
1135 err
= i40e_hmc_get_object_va(&hw
->hmc
, &context_bytes
,
1136 I40E_HMC_LAN_RX
, queue
);
1140 return i40e_set_hmc_context(context_bytes
,
1141 i40e_hmc_rxq_ce_info
, (u8
*)s
);