diff options
Diffstat (limited to 'drivers/acpi/acpi_platform.c')
| -rw-r--r-- | drivers/acpi/acpi_platform.c | 25 | 
1 files changed, 23 insertions, 2 deletions
| diff --git a/drivers/acpi/acpi_platform.c b/drivers/acpi/acpi_platform.c index 159f7f19abce..b4c1a6a51da4 100644 --- a/drivers/acpi/acpi_platform.c +++ b/drivers/acpi/acpi_platform.c @@ -17,6 +17,7 @@  #include <linux/kernel.h>  #include <linux/module.h>  #include <linux/dma-mapping.h> +#include <linux/pci.h>  #include <linux/platform_device.h>  #include "internal.h" @@ -30,9 +31,26 @@ static const struct acpi_device_id forbidden_id_list[] = {  	{"", 0},  }; +static void acpi_platform_fill_resource(struct acpi_device *adev, +	const struct resource *src, struct resource *dest) +{ +	struct device *parent; + +	*dest = *src; + +	/* +	 * If the device has parent we need to take its resources into +	 * account as well because this device might consume part of those. +	 */ +	parent = acpi_get_first_physical_node(adev->parent); +	if (parent && dev_is_pci(parent)) +		dest->parent = pci_find_resource(to_pci_dev(parent), dest); +} +  /**   * acpi_create_platform_device - Create platform device for ACPI device node   * @adev: ACPI device node to create a platform device for. + * @properties: Optional collection of build-in properties.   *   * Check if the given @adev can be represented as a platform device and, if   * that's the case, create and register a platform device, populate its common @@ -40,7 +58,8 @@ static const struct acpi_device_id forbidden_id_list[] = {   *   * Name of the platform device will be the same as @adev's.   */ -struct platform_device *acpi_create_platform_device(struct acpi_device *adev) +struct platform_device *acpi_create_platform_device(struct acpi_device *adev, +					struct property_entry *properties)  {  	struct platform_device *pdev = NULL;  	struct platform_device_info pdevinfo; @@ -70,7 +89,8 @@ struct platform_device *acpi_create_platform_device(struct acpi_device *adev)  		}  		count = 0;  		list_for_each_entry(rentry, &resource_list, node) -			resources[count++] = *rentry->res; +			acpi_platform_fill_resource(adev, rentry->res, +						    &resources[count++]);  		acpi_dev_free_resource_list(&resource_list);  	} @@ -88,6 +108,7 @@ struct platform_device *acpi_create_platform_device(struct acpi_device *adev)  	pdevinfo.res = resources;  	pdevinfo.num_res = count;  	pdevinfo.fwnode = acpi_fwnode_handle(adev); +	pdevinfo.properties = properties;  	if (acpi_dma_supported(adev))  		pdevinfo.dma_mask = DMA_BIT_MASK(32); |