mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-12 08:00:09 +00:00
[ARM] Add a common typesafe __io implementation
As Al did for Versatile in 2ad4f86b60b649fd7428265c08d73a3bd360c81b, add a typesafe __io implementation for platforms to use. Convert platforms to use this new simple typesafe implementation. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:
parent
cd32a48dc5
commit
0560cf5aa5
@ -79,6 +79,14 @@ extern void __iounmap(volatile void __iomem *addr);
|
|||||||
*/
|
*/
|
||||||
extern void __readwrite_bug(const char *fn);
|
extern void __readwrite_bug(const char *fn);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* A typesafe __io() helper
|
||||||
|
*/
|
||||||
|
static inline void __iomem *__typesafe_io(unsigned long addr)
|
||||||
|
{
|
||||||
|
return (void __iomem *)addr;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Now, pick up the machine-defined IO definitions
|
* Now, pick up the machine-defined IO definitions
|
||||||
*/
|
*/
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
* We don't actually have real ISA nor PCI buses, but there is so many
|
* We don't actually have real ISA nor PCI buses, but there is so many
|
||||||
* drivers out there that might just work if we fake them...
|
* drivers out there that might just work if we fake them...
|
||||||
*/
|
*/
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -23,8 +23,8 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xFFFFFFFF
|
#define IO_SPACE_LIMIT 0xFFFFFFFF
|
||||||
|
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
|
@ -22,8 +22,8 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We don't support ins[lb]/outs[lb]. Make them fault.
|
* We don't support ins[lb]/outs[lb]. Make them fault.
|
||||||
|
@ -29,8 +29,7 @@
|
|||||||
* We don't actually have real ISA nor PCI buses, but there is so many
|
* We don't actually have real ISA nor PCI buses, but there is so many
|
||||||
* drivers out there that might just work if we fake them...
|
* drivers out there that might just work if we fake them...
|
||||||
*/
|
*/
|
||||||
#define PCIO_BASE 0
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __io(a) ((void __iomem *)(PCIO_BASE + (a)))
|
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
#define __mem_isa(a) (a)
|
#define __mem_isa(a) (a)
|
||||||
|
|
||||||
|
@ -4,5 +4,5 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
#define __io(p) ((void __iomem *)(p))
|
#define __io(p) __typesafe_io(p)
|
||||||
#define __mem_pci(p) (p)
|
#define __mem_pci(p) (p)
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -239,7 +239,7 @@ __ixp4xx_readsl(const volatile void __iomem *bus_addr, u32 *vaddr, u32 count)
|
|||||||
|
|
||||||
#ifndef CONFIG_PCI
|
#ifndef CONFIG_PCI
|
||||||
|
|
||||||
#define __io(v) v
|
#define __io(v) __typesafe_io(v)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -15,11 +15,7 @@
|
|||||||
/*
|
/*
|
||||||
* There are not real ISA nor PCI buses, so we fake it.
|
* There are not real ISA nor PCI buses, so we fake it.
|
||||||
*/
|
*/
|
||||||
static inline void __iomem *__io(unsigned long addr)
|
#define __io(a) __typesafe_io(a)
|
||||||
{
|
#define __mem_pci(a) (a)
|
||||||
return (void __iomem *)addr;
|
|
||||||
}
|
|
||||||
#define __io(a) __io(a)
|
|
||||||
#define __mem_pci(a) (a)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
/* No ISA or PCI bus on this machine. */
|
/* No ISA or PCI bus on this machine. */
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif /* __ASM_ARCH_IO_H */
|
#endif /* __ASM_ARCH_IO_H */
|
||||||
|
@ -23,11 +23,7 @@
|
|||||||
|
|
||||||
void __iomem *__msm_ioremap(unsigned long phys_addr, size_t size, unsigned int mtype);
|
void __iomem *__msm_ioremap(unsigned long phys_addr, size_t size, unsigned int mtype);
|
||||||
|
|
||||||
static inline void __iomem *__io(unsigned long addr)
|
#define __io(a) __typesafe_io(a)
|
||||||
{
|
|
||||||
return (void __iomem *)addr;
|
|
||||||
}
|
|
||||||
#define __io(a) __io(a)
|
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff /* XXX */
|
#define IO_SPACE_LIMIT 0xffffffff /* XXX */
|
||||||
|
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
#define __mem_isa(a) (IO_BASE + (a))
|
#define __mem_isa(a) (IO_BASE + (a))
|
||||||
|
|
||||||
|
@ -38,14 +38,9 @@ __arch_iounmap(void __iomem *addr)
|
|||||||
__iounmap(addr);
|
__iounmap(addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void __iomem *__io(unsigned long addr)
|
|
||||||
{
|
|
||||||
return (void __iomem *)addr;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define __arch_ioremap(p, s, m) __arch_ioremap(p, s, m)
|
#define __arch_ioremap(p, s, m) __arch_ioremap(p, s, m)
|
||||||
#define __arch_iounmap(a) __arch_iounmap(a)
|
#define __arch_iounmap(a) __arch_iounmap(a)
|
||||||
#define __io(a) __io(a)
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
* We don't actually have real ISA nor PCI buses, but there is so many
|
* We don't actually have real ISA nor PCI buses, but there is so many
|
||||||
* drivers out there that might just work if we fake them...
|
* drivers out there that might just work if we fake them...
|
||||||
*/
|
*/
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -22,12 +22,7 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
static inline void __iomem *__io(unsigned long addr)
|
#define __io(a) __typesafe_io(a)
|
||||||
{
|
#define __mem_pci(a) (a)
|
||||||
return (void __iomem *)addr;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define __io(a) __io(a)
|
|
||||||
#define __mem_pci(a) (a)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -16,11 +16,7 @@
|
|||||||
* We don't actually have real ISA nor PCI buses, but there is so many
|
* We don't actually have real ISA nor PCI buses, but there is so many
|
||||||
* drivers out there that might just work if we fake them...
|
* drivers out there that might just work if we fake them...
|
||||||
*/
|
*/
|
||||||
static inline void __iomem *__io(unsigned long addr)
|
#define __io(a) __typesafe_io(a)
|
||||||
{
|
#define __mem_pci(a) (a)
|
||||||
return (void __iomem *)addr;
|
|
||||||
}
|
|
||||||
#define __io(a) __io(a)
|
|
||||||
#define __mem_pci(a) (a)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -22,11 +22,7 @@
|
|||||||
|
|
||||||
#define IO_SPACE_LIMIT 0xffffffff
|
#define IO_SPACE_LIMIT 0xffffffff
|
||||||
|
|
||||||
static inline void __iomem *__io(unsigned long addr)
|
#define __io(a) __typesafe_io(a)
|
||||||
{
|
#define __mem_pci(a) (a)
|
||||||
return (void __iomem *)addr;
|
|
||||||
}
|
|
||||||
#define __io(a) __io(a)
|
|
||||||
#define __mem_pci(a) (a)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -35,8 +35,8 @@ __mx3_ioremap(unsigned long phys_addr, size_t size, unsigned int mtype)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* io address mapping macro */
|
/* io address mapping macro */
|
||||||
#define __io(a) ((void __iomem *)(a))
|
#define __io(a) __typesafe_io(a)
|
||||||
|
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -42,8 +42,8 @@
|
|||||||
* We don't actually have real ISA nor PCI buses, but there is so many
|
* We don't actually have real ISA nor PCI buses, but there is so many
|
||||||
* drivers out there that might just work if we fake them...
|
* drivers out there that might just work if we fake them...
|
||||||
*/
|
*/
|
||||||
#define __io(a) ((void __iomem *)(PCIO_BASE + (a)))
|
#define __io(a) __typesafe_io(a)
|
||||||
#define __mem_pci(a) (a)
|
#define __mem_pci(a) (a)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* ----------------------------------------------------------------------------
|
* ----------------------------------------------------------------------------
|
||||||
@ -51,8 +51,6 @@
|
|||||||
* ----------------------------------------------------------------------------
|
* ----------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define PCIO_BASE 0
|
|
||||||
|
|
||||||
#if defined(CONFIG_ARCH_OMAP1)
|
#if defined(CONFIG_ARCH_OMAP1)
|
||||||
|
|
||||||
#define IO_PHYS 0xFFFB0000
|
#define IO_PHYS 0xFFFB0000
|
||||||
|
Loading…
x
Reference in New Issue
Block a user