Multiple race conditions are possible between the rfkill hotplug in the
asus-wmi and eeepc-laptop drivers and the generic PCI bus rescan and device
removal that can be triggered via sysfs.
To avoid those race conditions make asus-wmi and eeepc-laptop use global
PCI rescan-remove locking around the rfkill hotplug.
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
        mutex_unlock(&asus->wmi_lock);
 
        mutex_lock(&asus->hotplug_lock);
+       pci_lock_rescan_remove();
 
        if (asus->wlan.rfkill)
                rfkill_set_sw_state(asus->wlan.rfkill, blocked);
        }
 
 out_unlock:
+       pci_unlock_rescan_remove();
        mutex_unlock(&asus->hotplug_lock);
 }
 
 
                rfkill_set_sw_state(eeepc->wlan_rfkill, blocked);
 
        mutex_lock(&eeepc->hotplug_lock);
+       pci_lock_rescan_remove();
 
        if (eeepc->hotplug_slot) {
                port = acpi_get_pci_dev(handle);
        }
 
 out_unlock:
+       pci_unlock_rescan_remove();
        mutex_unlock(&eeepc->hotplug_lock);
 }