Commit a77ed5c5 authored by Ahmed Zaki's avatar Ahmed Zaki Committed by Tony Nguyen

iavf: use internal state to free traffic IRQs

If the system tries to close the netdev while iavf_reset_task() is
running, __LINK_STATE_START will be cleared and netif_running() will
return false in iavf_reinit_interrupt_scheme(). This will result in
iavf_free_traffic_irqs() not being called and a leak as follows:

    [7632.489326] remove_proc_entry: removing non-empty directory 'irq/999', leaking at least 'iavf-enp24s0f0v0-TxRx-0'
    [7632.490214] WARNING: CPU: 0 PID: 10 at fs/proc/generic.c:718 remove_proc_entry+0x19b/0x1b0

is shown when pci_disable_msix() is later called. Fix by using the
internal adapter state. The traffic IRQs will always exist if
state == __IAVF_RUNNING.

Fixes: 5b36e8d0 ("i40evf: Enable VF to request an alternate queue allocation")
Signed-off-by: default avatarAhmed Zaki <ahmed.zaki@intel.com>
Tested-by: default avatarRafal Romanowski <rafal.romanowski@intel.com>
Signed-off-by: default avatarTony Nguyen <anthony.l.nguyen@intel.com>
parent 7c4bced3
...@@ -1929,15 +1929,16 @@ static void iavf_free_rss(struct iavf_adapter *adapter) ...@@ -1929,15 +1929,16 @@ static void iavf_free_rss(struct iavf_adapter *adapter)
/** /**
* iavf_reinit_interrupt_scheme - Reallocate queues and vectors * iavf_reinit_interrupt_scheme - Reallocate queues and vectors
* @adapter: board private structure * @adapter: board private structure
* @running: true if adapter->state == __IAVF_RUNNING
* *
* Returns 0 on success, negative on failure * Returns 0 on success, negative on failure
**/ **/
static int iavf_reinit_interrupt_scheme(struct iavf_adapter *adapter) static int iavf_reinit_interrupt_scheme(struct iavf_adapter *adapter, bool running)
{ {
struct net_device *netdev = adapter->netdev; struct net_device *netdev = adapter->netdev;
int err; int err;
if (netif_running(netdev)) if (running)
iavf_free_traffic_irqs(adapter); iavf_free_traffic_irqs(adapter);
iavf_free_misc_irq(adapter); iavf_free_misc_irq(adapter);
iavf_reset_interrupt_capability(adapter); iavf_reset_interrupt_capability(adapter);
...@@ -3053,7 +3054,7 @@ static void iavf_reset_task(struct work_struct *work) ...@@ -3053,7 +3054,7 @@ static void iavf_reset_task(struct work_struct *work)
if ((adapter->flags & IAVF_FLAG_REINIT_MSIX_NEEDED) || if ((adapter->flags & IAVF_FLAG_REINIT_MSIX_NEEDED) ||
(adapter->flags & IAVF_FLAG_REINIT_ITR_NEEDED)) { (adapter->flags & IAVF_FLAG_REINIT_ITR_NEEDED)) {
err = iavf_reinit_interrupt_scheme(adapter); err = iavf_reinit_interrupt_scheme(adapter, running);
if (err) if (err)
goto reset_err; goto reset_err;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment