12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- #ifndef _XTENSA_IO_H
- #define _XTENSA_IO_H
- #ifdef __KERNEL__
- #include <asm/byteorder.h>
- #include <asm/page.h>
- #include <asm/vectors.h>
- #include <linux/bug.h>
- #include <linux/kernel.h>
- #include <linux/types.h>
- #define IOADDR(x) (XCHAL_KIO_BYPASS_VADDR + (x))
- #define IO_SPACE_LIMIT ~0
- #ifdef CONFIG_MMU
- void __iomem *xtensa_ioremap_nocache(unsigned long addr, unsigned long size);
- void __iomem *xtensa_ioremap_cache(unsigned long addr, unsigned long size);
- void xtensa_iounmap(volatile void __iomem *addr);
- static inline void __iomem *ioremap_nocache(unsigned long offset,
- unsigned long size)
- {
- if (offset >= XCHAL_KIO_PADDR
- && offset - XCHAL_KIO_PADDR < XCHAL_KIO_SIZE)
- return (void*)(offset-XCHAL_KIO_PADDR+XCHAL_KIO_BYPASS_VADDR);
- else
- return xtensa_ioremap_nocache(offset, size);
- }
- static inline void __iomem *ioremap_cache(unsigned long offset,
- unsigned long size)
- {
- if (offset >= XCHAL_KIO_PADDR
- && offset - XCHAL_KIO_PADDR < XCHAL_KIO_SIZE)
- return (void*)(offset-XCHAL_KIO_PADDR+XCHAL_KIO_CACHED_VADDR);
- else
- return xtensa_ioremap_cache(offset, size);
- }
- #define ioremap_cache ioremap_cache
- #define ioremap_wc ioremap_nocache
- #define ioremap_wt ioremap_nocache
- static inline void __iomem *ioremap(unsigned long offset, unsigned long size)
- {
- return ioremap_nocache(offset, size);
- }
- static inline void iounmap(volatile void __iomem *addr)
- {
- unsigned long va = (unsigned long) addr;
- if (!(va >= XCHAL_KIO_CACHED_VADDR &&
- va - XCHAL_KIO_CACHED_VADDR < XCHAL_KIO_SIZE) &&
- !(va >= XCHAL_KIO_BYPASS_VADDR &&
- va - XCHAL_KIO_BYPASS_VADDR < XCHAL_KIO_SIZE))
- xtensa_iounmap(addr);
- }
- #define virt_to_bus virt_to_phys
- #define bus_to_virt phys_to_virt
- #endif
- #endif
- #include <asm-generic/io.h>
- #endif
|