[Devel] [PATCH rh7 1/2] ms/ixgbe: fix possible deadlock in ixgbe_service_task()

Kirill Tkhai ktkhai at virtuozzo.com
Fri Jan 10 18:44:32 MSK 2020


On 10.01.2020 18:31, Konstantin Khorenko wrote:
> From: Taehee Yoo <ap420073 at gmail.com>
> 
> ixgbe_service_task() calls unregister_netdev() under rtnl_lock().
> But unregister_netdev() internally calls rtnl_lock().
> So deadlock would occur.
> 
> Fixes: 59dd45d550c5 ("ixgbe: firmware recovery mode")
> Signed-off-by: Taehee Yoo <ap420073 at gmail.com>
> Tested-by: Andrew Bowers <andrewx.bowers at intel.com>
> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher at intel.com>
> Signed-off-by: David S. Miller <davem at davemloft.net>
> 
> https://jira.sw.ru/browse/PSBM-100722
> 
> (cherry picked from commit 8b6381600d59871fbe44d36522272f961ab42410)
> Signed-off-by: Konstantin Khorenko <khorenko at virtuozzo.com>

Acked-by: Kirill Tkhai <ktkhai at virtuozzo.com>

> ---
>  drivers/net/ethernet/intel/ixgbe/ixgbe_main.c | 5 +----
>  1 file changed, 1 insertion(+), 4 deletions(-)
> 
> diff --git a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c
> index eb87979187cb8..eef479f762f93 100644
> --- a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c
> +++ b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c
> @@ -7950,11 +7950,8 @@ static void ixgbe_service_task(struct work_struct *work)
>  		return;
>  	}
>  	if (ixgbe_check_fw_error(adapter)) {
> -		if (!test_bit(__IXGBE_DOWN, &adapter->state)) {
> -			rtnl_lock();
> +		if (!test_bit(__IXGBE_DOWN, &adapter->state))
>  			unregister_netdev(adapter->netdev);
> -			rtnl_unlock();
> -		}
>  		ixgbe_service_event_complete(adapter);
>  		return;
>  	}
> 



More information about the Devel mailing list