return retval;
 
 #endif
-       pci_disable_device(pdev);
+       if (!test_and_set_bit(__IXGBEVF_DISABLED, &adapter->state))
+               pci_disable_device(pdev);
 
        return 0;
 }
                dev_err(&pdev->dev, "Cannot enable PCI device from suspend\n");
                return err;
        }
+       smp_mb__before_clear_bit();
+       clear_bit(__IXGBEVF_DISABLED, &adapter->state);
        pci_set_master(pdev);
 
        ixgbevf_reset(adapter);
        pci_release_regions(pdev);
 err_pci_reg:
 err_dma:
-       pci_disable_device(pdev);
+       if (!test_and_set_bit(__IXGBEVF_DISABLED, &adapter->state))
+               pci_disable_device(pdev);
        return err;
 }
 
 
        free_netdev(netdev);
 
-       pci_disable_device(pdev);
+       if (!test_and_set_bit(__IXGBEVF_DISABLED, &adapter->state))
+               pci_disable_device(pdev);
 }
 
 /**
        struct net_device *netdev = pci_get_drvdata(pdev);
        struct ixgbevf_adapter *adapter = netdev_priv(netdev);
 
+       rtnl_lock();
        netif_device_detach(netdev);
 
-       if (state == pci_channel_io_perm_failure)
+       if (state == pci_channel_io_perm_failure) {
+               rtnl_unlock();
                return PCI_ERS_RESULT_DISCONNECT;
+       }
 
        if (netif_running(netdev))
                ixgbevf_down(adapter);
 
-       pci_disable_device(pdev);
+       if (!test_and_set_bit(__IXGBEVF_DISABLED, &adapter->state))
+               pci_disable_device(pdev);
+       rtnl_unlock();
 
        /* Request a slot slot reset. */
        return PCI_ERS_RESULT_NEED_RESET;
                return PCI_ERS_RESULT_DISCONNECT;
        }
 
+       smp_mb__before_clear_bit();
+       clear_bit(__IXGBEVF_DISABLED, &adapter->state);
        pci_set_master(pdev);
 
        ixgbevf_reset(adapter);