io.h 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /*
  2. * arch/arm/mach-kirkwood/include/mach/io.h
  3. *
  4. * This file is licensed under the terms of the GNU General Public
  5. * License version 2. This program is licensed "as is" without any
  6. * warranty of any kind, whether express or implied.
  7. */
  8. #ifndef __ASM_ARCH_IO_H
  9. #define __ASM_ARCH_IO_H
  10. #include "kirkwood.h"
  11. #define IO_SPACE_LIMIT 0xffffffff
  12. static inline void __iomem *__io(unsigned long addr)
  13. {
  14. return (void __iomem *)((addr - KIRKWOOD_PCIE_IO_BUS_BASE)
  15. + KIRKWOOD_PCIE_IO_VIRT_BASE);
  16. }
  17. static inline void __iomem *
  18. __arch_ioremap(unsigned long paddr, size_t size, unsigned int mtype)
  19. {
  20. void __iomem *retval;
  21. unsigned long offs = paddr - KIRKWOOD_REGS_PHYS_BASE;
  22. if (mtype == MT_DEVICE && size && offs < KIRKWOOD_REGS_SIZE &&
  23. size <= KIRKWOOD_REGS_SIZE && offs + size <= KIRKWOOD_REGS_SIZE) {
  24. retval = (void __iomem *)KIRKWOOD_REGS_VIRT_BASE + offs;
  25. } else {
  26. retval = __arm_ioremap(paddr, size, mtype);
  27. }
  28. return retval;
  29. }
  30. static inline void
  31. __arch_iounmap(void __iomem *addr)
  32. {
  33. if (addr < (void __iomem *)KIRKWOOD_REGS_VIRT_BASE ||
  34. addr >= (void __iomem *)(KIRKWOOD_REGS_VIRT_BASE + KIRKWOOD_REGS_SIZE))
  35. __iounmap(addr);
  36. }
  37. #define __arch_ioremap(p, s, m) __arch_ioremap(p, s, m)
  38. #define __arch_iounmap(a) __arch_iounmap(a)
  39. #define __io(a) __io(a)
  40. #define __mem_pci(a) (a)
  41. #endif