mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
lib: devres: prepare devm_ioremap_resource() for more variants
We want to add the write-combined variant of devm_ioremap_resource(). Let's first implement __devm_ioremap_resource() which takes an additional argument type. The types are the same as for __devm_ioremap(). The existing devm_ioremap_resource() now simply calls __devm_ioremap_resource() with regular DEVM_IOREMAP type. Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com> Reviewed-by: Arnd Bergmann <arnd@arndb.de> Link: https://lore.kernel.org/r/20191022084318.22256-3-brgl@bgdev.pl Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
4154abca29
commit
6e92482275
57
lib/devres.c
57
lib/devres.c
@ -114,6 +114,37 @@ void devm_iounmap(struct device *dev, void __iomem *addr)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(devm_iounmap);
|
EXPORT_SYMBOL(devm_iounmap);
|
||||||
|
|
||||||
|
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;
|
||||||
|
|
||||||
|
BUG_ON(!dev);
|
||||||
|
|
||||||
|
if (!res || resource_type(res) != IORESOURCE_MEM) {
|
||||||
|
dev_err(dev, "invalid resource\n");
|
||||||
|
return IOMEM_ERR_PTR(-EINVAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
size = resource_size(res);
|
||||||
|
|
||||||
|
if (!devm_request_mem_region(dev, res->start, size, dev_name(dev))) {
|
||||||
|
dev_err(dev, "can't request region for resource %pR\n", res);
|
||||||
|
return IOMEM_ERR_PTR(-EBUSY);
|
||||||
|
}
|
||||||
|
|
||||||
|
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);
|
||||||
|
dest_ptr = IOMEM_ERR_PTR(-ENOMEM);
|
||||||
|
}
|
||||||
|
|
||||||
|
return dest_ptr;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* devm_ioremap_resource() - check, request region, and ioremap resource
|
* devm_ioremap_resource() - check, request region, and ioremap resource
|
||||||
* @dev: generic device to handle the resource for
|
* @dev: generic device to handle the resource for
|
||||||
@ -134,31 +165,7 @@ EXPORT_SYMBOL(devm_iounmap);
|
|||||||
void __iomem *devm_ioremap_resource(struct device *dev,
|
void __iomem *devm_ioremap_resource(struct device *dev,
|
||||||
const struct resource *res)
|
const struct resource *res)
|
||||||
{
|
{
|
||||||
resource_size_t size;
|
return __devm_ioremap_resource(dev, res, DEVM_IOREMAP);
|
||||||
void __iomem *dest_ptr;
|
|
||||||
|
|
||||||
BUG_ON(!dev);
|
|
||||||
|
|
||||||
if (!res || resource_type(res) != IORESOURCE_MEM) {
|
|
||||||
dev_err(dev, "invalid resource\n");
|
|
||||||
return IOMEM_ERR_PTR(-EINVAL);
|
|
||||||
}
|
|
||||||
|
|
||||||
size = resource_size(res);
|
|
||||||
|
|
||||||
if (!devm_request_mem_region(dev, res->start, size, dev_name(dev))) {
|
|
||||||
dev_err(dev, "can't request region for resource %pR\n", res);
|
|
||||||
return IOMEM_ERR_PTR(-EBUSY);
|
|
||||||
}
|
|
||||||
|
|
||||||
dest_ptr = devm_ioremap(dev, res->start, size);
|
|
||||||
if (!dest_ptr) {
|
|
||||||
dev_err(dev, "ioremap failed for resource %pR\n", res);
|
|
||||||
devm_release_mem_region(dev, res->start, size);
|
|
||||||
dest_ptr = IOMEM_ERR_PTR(-ENOMEM);
|
|
||||||
}
|
|
||||||
|
|
||||||
return dest_ptr;
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(devm_ioremap_resource);
|
EXPORT_SYMBOL(devm_ioremap_resource);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user