i40evf: Reorder configure_clsflower to avoid deadlock on error
While doing some code review I noticed that we can get into a state where we exit with the "IN_CRITICAL_TASK" bit set while notifying the PF of flower filters. This patch is meant to address that plus tweak the ordering of the while loop waiting on it slightly so that we don't wait an extra period after we have failed for the last time. Signed-off-by: Alexander Duyck <alexander.h.duyck@intel.com> Tested-by: Andrew Bowers <andrewx.bowers@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
Родитель
e3c72f3d37
Коммит
640a8af584
|
@ -2791,14 +2791,7 @@ static int i40evf_configure_clsflower(struct i40evf_adapter *adapter,
|
||||||
{
|
{
|
||||||
int tc = tc_classid_to_hwtc(adapter->netdev, cls_flower->classid);
|
int tc = tc_classid_to_hwtc(adapter->netdev, cls_flower->classid);
|
||||||
struct i40evf_cloud_filter *filter = NULL;
|
struct i40evf_cloud_filter *filter = NULL;
|
||||||
int err = 0, count = 50;
|
int err = -EINVAL, count = 50;
|
||||||
|
|
||||||
while (test_and_set_bit(__I40EVF_IN_CRITICAL_TASK,
|
|
||||||
&adapter->crit_section)) {
|
|
||||||
udelay(1);
|
|
||||||
if (--count == 0)
|
|
||||||
return -EINVAL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (tc < 0) {
|
if (tc < 0) {
|
||||||
dev_err(&adapter->pdev->dev, "Invalid traffic class\n");
|
dev_err(&adapter->pdev->dev, "Invalid traffic class\n");
|
||||||
|
@ -2806,10 +2799,16 @@ static int i40evf_configure_clsflower(struct i40evf_adapter *adapter,
|
||||||
}
|
}
|
||||||
|
|
||||||
filter = kzalloc(sizeof(*filter), GFP_KERNEL);
|
filter = kzalloc(sizeof(*filter), GFP_KERNEL);
|
||||||
if (!filter) {
|
if (!filter)
|
||||||
err = -ENOMEM;
|
return -ENOMEM;
|
||||||
goto clearout;
|
|
||||||
|
while (test_and_set_bit(__I40EVF_IN_CRITICAL_TASK,
|
||||||
|
&adapter->crit_section)) {
|
||||||
|
if (--count == 0)
|
||||||
|
goto err;
|
||||||
|
udelay(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
filter->cookie = cls_flower->cookie;
|
filter->cookie = cls_flower->cookie;
|
||||||
|
|
||||||
/* set the mask to all zeroes to begin with */
|
/* set the mask to all zeroes to begin with */
|
||||||
|
@ -2834,7 +2833,7 @@ static int i40evf_configure_clsflower(struct i40evf_adapter *adapter,
|
||||||
err:
|
err:
|
||||||
if (err)
|
if (err)
|
||||||
kfree(filter);
|
kfree(filter);
|
||||||
clearout:
|
|
||||||
clear_bit(__I40EVF_IN_CRITICAL_TASK, &adapter->crit_section);
|
clear_bit(__I40EVF_IN_CRITICAL_TASK, &adapter->crit_section);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
Загрузка…
Ссылка в новой задаче