diff options
Diffstat (limited to 'drivers/acpi/pci_root.c')
| -rw-r--r-- | drivers/acpi/pci_root.c | 101 | 
1 files changed, 25 insertions, 76 deletions
diff --git a/drivers/acpi/pci_root.c b/drivers/acpi/pci_root.c index 7928d4dc705..b3cc69c5caf 100644 --- a/drivers/acpi/pci_root.c +++ b/drivers/acpi/pci_root.c @@ -45,9 +45,9 @@  ACPI_MODULE_NAME("pci_root");  #define ACPI_PCI_ROOT_CLASS		"pci_bridge"  #define ACPI_PCI_ROOT_DEVICE_NAME	"PCI Root Bridge" -static int acpi_pci_root_add(struct acpi_device *device); -static int acpi_pci_root_remove(struct acpi_device *device, int type); -static int acpi_pci_root_start(struct acpi_device *device); +static int acpi_pci_root_add(struct acpi_device *device, +			     const struct acpi_device_id *not_used); +static void acpi_pci_root_remove(struct acpi_device *device);  #define ACPI_PCIE_REQ_SUPPORT (OSC_EXT_PCI_CONFIG_SUPPORT \  				| OSC_ACTIVE_STATE_PWR_SUPPORT \ @@ -58,17 +58,11 @@ static const struct acpi_device_id root_device_ids[] = {  	{"PNP0A03", 0},  	{"", 0},  }; -MODULE_DEVICE_TABLE(acpi, root_device_ids); -static struct acpi_driver acpi_pci_root_driver = { -	.name = "pci_root", -	.class = ACPI_PCI_ROOT_CLASS, +static struct acpi_scan_handler pci_root_handler = {  	.ids = root_device_ids, -	.ops = { -		.add = acpi_pci_root_add, -		.remove = acpi_pci_root_remove, -		.start = acpi_pci_root_start, -		}, +	.attach = acpi_pci_root_add, +	.detach = acpi_pci_root_remove,  };  /* Lock to protect both acpi_pci_roots and acpi_pci_drivers lists */ @@ -188,21 +182,6 @@ static acpi_status try_get_root_bridge_busnr(acpi_handle handle,  	return AE_OK;  } -static void acpi_pci_bridge_scan(struct acpi_device *device) -{ -	int status; -	struct acpi_device *child = NULL; - -	if (device->flags.bus_address) -		if (device->parent && device->parent->ops.bind) { -			status = device->parent->ops.bind(device); -			if (!status) { -				list_for_each_entry(child, &device->children, node) -					acpi_pci_bridge_scan(child); -			} -		} -} -  static u8 pci_osc_uuid_str[] = "33DB4D5B-1FF7-401C-9657-7441C03DD766";  static acpi_status acpi_pci_run_osc(acpi_handle handle, @@ -445,14 +424,15 @@ out:  }  EXPORT_SYMBOL(acpi_pci_osc_control_set); -static int acpi_pci_root_add(struct acpi_device *device) +static int acpi_pci_root_add(struct acpi_device *device, +			     const struct acpi_device_id *not_used)  {  	unsigned long long segment, bus;  	acpi_status status;  	int result;  	struct acpi_pci_root *root;  	acpi_handle handle; -	struct acpi_device *child; +	struct acpi_pci_driver *driver;  	u32 flags, base_flags;  	bool is_osc_granted = false; @@ -603,21 +583,6 @@ static int acpi_pci_root_add(struct acpi_device *device)  		goto out_del_root;  	} -	/* -	 * Attach ACPI-PCI Context -	 * ----------------------- -	 * Thus binding the ACPI and PCI devices. -	 */ -	result = acpi_pci_bind_root(device); -	if (result) -		goto out_del_root; - -	/* -	 * Scan and bind all _ADR-Based Devices -	 */ -	list_for_each_entry(child, &device->children, node) -		acpi_pci_bridge_scan(child); -  	/* ASPM setting */  	if (is_osc_granted) {  		if (acpi_gbl_FADT.boot_flags & ACPI_FADT_NO_ASPM) @@ -632,24 +597,6 @@ static int acpi_pci_root_add(struct acpi_device *device)  	if (device->wakeup.flags.run_wake)  		device_set_run_wake(root->bus->bridge, true); -	return 0; - -out_del_root: -	mutex_lock(&acpi_pci_root_lock); -	list_del(&root->node); -	mutex_unlock(&acpi_pci_root_lock); - -	acpi_pci_irq_del_prt(root->segment, root->secondary.start); -end: -	kfree(root); -	return result; -} - -static int acpi_pci_root_start(struct acpi_device *device) -{ -	struct acpi_pci_root *root = acpi_driver_data(device); -	struct acpi_pci_driver *driver; -  	if (system_state != SYSTEM_BOOTING)  		pci_assign_unassigned_bus_resources(root->bus); @@ -664,11 +611,20 @@ static int acpi_pci_root_start(struct acpi_device *device)  		pci_enable_bridges(root->bus);  	pci_bus_add_devices(root->bus); +	return 1; -	return 0; +out_del_root: +	mutex_lock(&acpi_pci_root_lock); +	list_del(&root->node); +	mutex_unlock(&acpi_pci_root_lock); + +	acpi_pci_irq_del_prt(root->segment, root->secondary.start); +end: +	kfree(root); +	return result;  } -static int acpi_pci_root_remove(struct acpi_device *device, int type) +static void acpi_pci_root_remove(struct acpi_device *device)  {  	acpi_status status;  	acpi_handle handle; @@ -696,21 +652,14 @@ static int acpi_pci_root_remove(struct acpi_device *device, int type)  	list_del(&root->node);  	mutex_unlock(&acpi_pci_root_lock);  	kfree(root); -	return 0;  } -static int __init acpi_pci_root_init(void) +void __init acpi_pci_root_init(void)  {  	acpi_hest_init(); -	if (acpi_pci_disabled) -		return 0; - -	pci_acpi_crs_quirks(); -	if (acpi_bus_register_driver(&acpi_pci_root_driver) < 0) -		return -ENODEV; - -	return 0; +	if (!acpi_pci_disabled) { +		pci_acpi_crs_quirks(); +		acpi_scan_add_handler(&pci_root_handler); +	}  } - -subsys_initcall(acpi_pci_root_init);  |