diff options
| author | Mark Brown <broonie@kernel.org> | 2016-02-09 21:20:39 +0300 | 
|---|---|---|
| committer | Mark Brown <broonie@kernel.org> | 2016-02-09 21:20:39 +0300 | 
| commit | fcdcc79628a1919bde9acf239e364f65bab6327c (patch) | |
| tree | 5499be387cf3028c90ac083b1cf866ebed7bf7e0 /drivers/base/platform.c | |
| parent | 7a8d44bc89e5cddcd5c0704a11a90484d36ba6ba (diff) | |
| parent | a0a90718f18264dc904d34a580f332006f5561e9 (diff) | |
| download | linux-fcdcc79628a1919bde9acf239e364f65bab6327c.tar.xz | |
Merge branch 'topic/acpi' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi into spi-pxa2xx
Diffstat (limited to 'drivers/base/platform.c')
| -rw-r--r-- | drivers/base/platform.c | 46 | 
1 files changed, 45 insertions, 1 deletions
| diff --git a/drivers/base/platform.c b/drivers/base/platform.c index 1dd6d3bf1098..73d6e5d39e33 100644 --- a/drivers/base/platform.c +++ b/drivers/base/platform.c @@ -26,6 +26,7 @@  #include <linux/acpi.h>  #include <linux/clk/clk-conf.h>  #include <linux/limits.h> +#include <linux/property.h>  #include "base.h"  #include "power/power.h" @@ -117,6 +118,26 @@ int platform_get_irq(struct platform_device *dev, unsigned int num)  EXPORT_SYMBOL_GPL(platform_get_irq);  /** + * platform_irq_count - Count the number of IRQs a platform device uses + * @dev: platform device + * + * Return: Number of IRQs a platform device uses or EPROBE_DEFER + */ +int platform_irq_count(struct platform_device *dev) +{ +	int ret, nr = 0; + +	while ((ret = platform_get_irq(dev, nr)) >= 0) +		nr++; + +	if (ret == -EPROBE_DEFER) +		return ret; + +	return nr; +} +EXPORT_SYMBOL_GPL(platform_irq_count); + +/**   * platform_get_resource_byname - get a resource for a device by name   * @dev: platform device   * @type: resource type @@ -299,6 +320,22 @@ int platform_device_add_data(struct platform_device *pdev, const void *data,  EXPORT_SYMBOL_GPL(platform_device_add_data);  /** + * platform_device_add_properties - add built-in properties to a platform device + * @pdev: platform device to add properties to + * @pset: properties to add + * + * The function will take deep copy of the properties in @pset and attach + * the copy to the platform device. The memory associated with properties + * will be freed when the platform device is released. + */ +int platform_device_add_properties(struct platform_device *pdev, +				   const struct property_set *pset) +{ +	return device_add_property_set(&pdev->dev, pset); +} +EXPORT_SYMBOL_GPL(platform_device_add_properties); + +/**   * platform_device_add - add a platform device to device hierarchy   * @pdev: platform device we're adding   * @@ -409,6 +446,8 @@ void platform_device_del(struct platform_device *pdev)  			if (r->parent)  				release_resource(r);  		} + +		device_remove_property_set(&pdev->dev);  	}  }  EXPORT_SYMBOL_GPL(platform_device_del); @@ -487,6 +526,12 @@ struct platform_device *platform_device_register_full(  	if (ret)  		goto err; +	if (pdevinfo->pset) { +		ret = platform_device_add_properties(pdev, pdevinfo->pset); +		if (ret) +			goto err; +	} +  	ret = platform_device_add(pdev);  	if (ret) {  err: @@ -552,7 +597,6 @@ static void platform_drv_shutdown(struct device *_dev)  	if (drv->shutdown)  		drv->shutdown(dev); -	dev_pm_domain_detach(_dev, true);  }  /** | 
