mirror of
https://github.com/torvalds/linux.git
synced 2024-12-22 10:56:40 +00:00
i40e: Fix the case where per TC queue count was higher than queues enabled
When the driver or hardware gets less interrupt vectors than the actual number of CPU cores, limit the queue count for the priority queue traffic class (TC) queues. This will fix a warning with multiple function mode where systems regularly have more cores than vectors. Also add extra comment for readability. Change-ID: I4f02226263aa3995e1f5ee5503eac0cd6ee12fbd Signed-off-by: Anjali Singhai Jain <anjali.singhai@intel.com> Tested-by: Jim Young <james.m.young@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
parent
a68de58d27
commit
7f9ff47683
@ -1512,7 +1512,12 @@ static void i40e_vsi_setup_queue_map(struct i40e_vsi *vsi,
|
||||
vsi->tc_config.numtc = numtc;
|
||||
vsi->tc_config.enabled_tc = enabled_tc ? enabled_tc : 1;
|
||||
/* Number of queues per enabled TC */
|
||||
num_tc_qps = vsi->alloc_queue_pairs/numtc;
|
||||
/* In MFP case we can have a much lower count of MSIx
|
||||
* vectors available and so we need to lower the used
|
||||
* q count.
|
||||
*/
|
||||
qcount = min_t(int, vsi->alloc_queue_pairs, pf->num_lan_msix);
|
||||
num_tc_qps = qcount / numtc;
|
||||
num_tc_qps = min_t(int, num_tc_qps, I40E_MAX_QUEUES_PER_TC);
|
||||
|
||||
/* Setup queue offset/count for all TCs for given VSI */
|
||||
|
Loading…
Reference in New Issue
Block a user