diff options
author | Rob Herring <rob.herring@calxeda.com> | 2012-02-10 18:05:13 -0500 |
---|---|---|
committer | Rob Herring <rob.herring@calxeda.com> | 2012-03-06 22:22:01 -0500 |
commit | 4fe7ef3a0811c33137ace0ed424dd0c01dd2d75e (patch) | |
tree | 046a63d0c5db517529e86c914bb2fb493a4adee6 /arch/arm/mm | |
parent | 47168824fa71b52ca3f4c18ddf0c42ff35192235 (diff) |
ARM: provide runtime hook for ioremap/iounmap
We have compile time over-ride of ioremap and iounmap, but an run-time
override is needed for multi-platform builds. This adds an extra function
pointer check, but ioremap is not peformance critical. The option for
compile time selection remains.
The caller variant is used here to provide correct caller information as
ARM can only support level 0 for __builtin_return_address.
Signed-off-by: Rob Herring <rob.herring@calxeda.com>
Cc: Russell King <linux@arm.linux.org.uk>
Reviewed-by: Arnd Bergmann <arnd@arndb.de>
Reviewed-by: Nicolas Pitre <nico@linaro.org>
Diffstat (limited to 'arch/arm/mm')
-rw-r--r-- | arch/arm/mm/ioremap.c | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/arch/arm/mm/ioremap.c b/arch/arm/mm/ioremap.c index 80632e8d7538..024629046f1f 100644 --- a/arch/arm/mm/ioremap.c +++ b/arch/arm/mm/ioremap.c | |||
@@ -306,11 +306,15 @@ __arm_ioremap_pfn(unsigned long pfn, unsigned long offset, size_t size, | |||
306 | } | 306 | } |
307 | EXPORT_SYMBOL(__arm_ioremap_pfn); | 307 | EXPORT_SYMBOL(__arm_ioremap_pfn); |
308 | 308 | ||
309 | void __iomem * (*arch_ioremap_caller)(unsigned long, size_t, | ||
310 | unsigned int, void *) = | ||
311 | __arm_ioremap_caller; | ||
312 | |||
309 | void __iomem * | 313 | void __iomem * |
310 | __arm_ioremap(unsigned long phys_addr, size_t size, unsigned int mtype) | 314 | __arm_ioremap(unsigned long phys_addr, size_t size, unsigned int mtype) |
311 | { | 315 | { |
312 | return __arm_ioremap_caller(phys_addr, size, mtype, | 316 | return arch_ioremap_caller(phys_addr, size, mtype, |
313 | __builtin_return_address(0)); | 317 | __builtin_return_address(0)); |
314 | } | 318 | } |
315 | EXPORT_SYMBOL(__arm_ioremap); | 319 | EXPORT_SYMBOL(__arm_ioremap); |
316 | 320 | ||
@@ -369,4 +373,11 @@ void __iounmap(volatile void __iomem *io_addr) | |||
369 | 373 | ||
370 | vunmap(addr); | 374 | vunmap(addr); |
371 | } | 375 | } |
372 | EXPORT_SYMBOL(__iounmap); | 376 | |
377 | void (*arch_iounmap)(volatile void __iomem *) = __iounmap; | ||
378 | |||
379 | void __arm_iounmap(volatile void __iomem *io_addr) | ||
380 | { | ||
381 | arch_iounmap(io_addr); | ||
382 | } | ||
383 | EXPORT_SYMBOL(__arm_iounmap); | ||