diff options
Diffstat (limited to 'lib/devres.c')
| -rw-r--r-- | lib/devres.c | 83 | 
1 files changed, 62 insertions, 21 deletions
diff --git a/lib/devres.c b/lib/devres.c index 6a0e9bd6524a..f56070cf970b 100644 --- a/lib/devres.c +++ b/lib/devres.c @@ -9,6 +9,7 @@  enum devm_ioremap_type {  	DEVM_IOREMAP = 0,  	DEVM_IOREMAP_NC, +	DEVM_IOREMAP_UC,  	DEVM_IOREMAP_WC,  }; @@ -39,6 +40,9 @@ static void __iomem *__devm_ioremap(struct device *dev, resource_size_t offset,  	case DEVM_IOREMAP_NC:  		addr = ioremap_nocache(offset, size);  		break; +	case DEVM_IOREMAP_UC: +		addr = ioremap_uc(offset, size); +		break;  	case DEVM_IOREMAP_WC:  		addr = ioremap_wc(offset, size);  		break; @@ -69,6 +73,21 @@ void __iomem *devm_ioremap(struct device *dev, resource_size_t offset,  EXPORT_SYMBOL(devm_ioremap);  /** + * devm_ioremap_uc - Managed ioremap_uc() + * @dev: Generic device to remap IO address for + * @offset: Resource address to map + * @size: Size of map + * + * Managed ioremap_uc().  Map is automatically unmapped on driver detach. + */ +void __iomem *devm_ioremap_uc(struct device *dev, resource_size_t offset, +			      resource_size_t size) +{ +	return __devm_ioremap(dev, offset, size, DEVM_IOREMAP_UC); +} +EXPORT_SYMBOL_GPL(devm_ioremap_uc); + +/**   * devm_ioremap_nocache - Managed ioremap_nocache()   * @dev: Generic device to remap IO address for   * @offset: Resource address to map @@ -114,25 +133,9 @@ void devm_iounmap(struct device *dev, void __iomem *addr)  }  EXPORT_SYMBOL(devm_iounmap); -/** - * devm_ioremap_resource() - check, request region, and ioremap resource - * @dev: generic device to handle the resource for - * @res: resource to be handled - * - * Checks that a resource is a valid memory region, requests the memory - * region and ioremaps it. All operations are managed and will be undone - * on driver detach. - * - * Returns a pointer to the remapped memory or an ERR_PTR() encoded error code - * on failure. Usage example: - * - *	res = platform_get_resource(pdev, IORESOURCE_MEM, 0); - *	base = devm_ioremap_resource(&pdev->dev, res); - *	if (IS_ERR(base)) - *		return PTR_ERR(base); - */ -void __iomem *devm_ioremap_resource(struct device *dev, -				    const struct resource *res) +static void __iomem * +__devm_ioremap_resource(struct device *dev, const struct resource *res, +			enum devm_ioremap_type type)  {  	resource_size_t size;  	void __iomem *dest_ptr; @@ -151,7 +154,7 @@ void __iomem *devm_ioremap_resource(struct device *dev,  		return IOMEM_ERR_PTR(-EBUSY);  	} -	dest_ptr = devm_ioremap(dev, res->start, size); +	dest_ptr = __devm_ioremap(dev, res->start, size, type);  	if (!dest_ptr) {  		dev_err(dev, "ioremap failed for resource %pR\n", res);  		devm_release_mem_region(dev, res->start, size); @@ -160,8 +163,46 @@ void __iomem *devm_ioremap_resource(struct device *dev,  	return dest_ptr;  } + +/** + * devm_ioremap_resource() - check, request region, and ioremap resource + * @dev: generic device to handle the resource for + * @res: resource to be handled + * + * Checks that a resource is a valid memory region, requests the memory + * region and ioremaps it. All operations are managed and will be undone + * on driver detach. + * + * Returns a pointer to the remapped memory or an ERR_PTR() encoded error code + * on failure. Usage example: + * + *	res = platform_get_resource(pdev, IORESOURCE_MEM, 0); + *	base = devm_ioremap_resource(&pdev->dev, res); + *	if (IS_ERR(base)) + *		return PTR_ERR(base); + */ +void __iomem *devm_ioremap_resource(struct device *dev, +				    const struct resource *res) +{ +	return __devm_ioremap_resource(dev, res, DEVM_IOREMAP); +}  EXPORT_SYMBOL(devm_ioremap_resource); +/** + * devm_ioremap_resource_wc() - write-combined variant of + *				devm_ioremap_resource() + * @dev: generic device to handle the resource for + * @res: resource to be handled + * + * Returns a pointer to the remapped memory or an ERR_PTR() encoded error code + * on failure. Usage example: + */ +void __iomem *devm_ioremap_resource_wc(struct device *dev, +				       const struct resource *res) +{ +	return __devm_ioremap_resource(dev, res, DEVM_IOREMAP_WC); +} +  /*   * devm_of_iomap - Requests a resource and maps the memory mapped IO   *		   for a given device_node managed by a given device @@ -262,7 +303,7 @@ EXPORT_SYMBOL(devm_ioport_unmap);  /*   * PCI iomap devres   */ -#define PCIM_IOMAP_MAX	PCI_ROM_RESOURCE +#define PCIM_IOMAP_MAX	PCI_STD_NUM_BARS  struct pcim_iomap_devres {  	void __iomem *table[PCIM_IOMAP_MAX];  |