io.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. /*
  2. * Copyright (c) 2011 The Chromium OS Authors.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #ifndef __SANDBOX_ASM_IO_H
  7. #define __SANDBOX_ASM_IO_H
  8. void *phys_to_virt(phys_addr_t paddr);
  9. #define phys_to_virt phys_to_virt
  10. phys_addr_t virt_to_phys(void *vaddr);
  11. #define virt_to_phys virt_to_phys
  12. void *map_physmem(phys_addr_t paddr, unsigned long len, unsigned long flags);
  13. #define map_physmem map_physmem
  14. /*
  15. * Take down a mapping set up by map_physmem().
  16. */
  17. void unmap_physmem(const void *vaddr, unsigned long flags);
  18. #define unmap_physmem unmap_physmem
  19. #include <asm-generic/io.h>
  20. /* For sandbox, we want addresses to point into our RAM buffer */
  21. static inline void *map_sysmem(phys_addr_t paddr, unsigned long len)
  22. {
  23. return map_physmem(paddr, len, MAP_WRBACK);
  24. }
  25. /* Remove a previous mapping */
  26. static inline void unmap_sysmem(const void *vaddr)
  27. {
  28. unmap_physmem(vaddr, MAP_WRBACK);
  29. }
  30. /* Map from a pointer to our RAM buffer */
  31. phys_addr_t map_to_sysmem(const void *ptr);
  32. /* Define nops for sandbox I/O access */
  33. #define readb(addr) ((void)addr, 0)
  34. #define readw(addr) ((void)addr, 0)
  35. #define readl(addr) ((void)addr, 0)
  36. #define writeb(v, addr) ((void)addr)
  37. #define writew(v, addr) ((void)addr)
  38. #define writel(v, addr) ((void)addr)
  39. /* I/O access functions */
  40. int inl(unsigned int addr);
  41. int inw(unsigned int addr);
  42. int inb(unsigned int addr);
  43. void outl(unsigned int value, unsigned int addr);
  44. void outw(unsigned int value, unsigned int addr);
  45. void outb(unsigned int value, unsigned int addr);
  46. #define out_arch(type,endian,a,v) write##type(cpu_to_##endian(v),a)
  47. #define in_arch(type,endian,a) endian##_to_cpu(read##type(a))
  48. #define out_le32(a,v) out_arch(l,le32,a,v)
  49. #define out_le16(a,v) out_arch(w,le16,a,v)
  50. #define in_le32(a) in_arch(l,le32,a)
  51. #define in_le16(a) in_arch(w,le16,a)
  52. #define out_be32(a,v) out_arch(l,be32,a,v)
  53. #define out_be16(a,v) out_arch(w,be16,a,v)
  54. #define in_be32(a) in_arch(l,be32,a)
  55. #define in_be16(a) in_arch(w,be16,a)
  56. #define out_8(a,v) writeb(v,a)
  57. #define in_8(a) readb(a)
  58. #define clrbits(type, addr, clear) \
  59. out_##type((addr), in_##type(addr) & ~(clear))
  60. #define setbits(type, addr, set) \
  61. out_##type((addr), in_##type(addr) | (set))
  62. #define clrsetbits(type, addr, clear, set) \
  63. out_##type((addr), (in_##type(addr) & ~(clear)) | (set))
  64. #define clrbits_be32(addr, clear) clrbits(be32, addr, clear)
  65. #define setbits_be32(addr, set) setbits(be32, addr, set)
  66. #define clrsetbits_be32(addr, clear, set) clrsetbits(be32, addr, clear, set)
  67. #define clrbits_le32(addr, clear) clrbits(le32, addr, clear)
  68. #define setbits_le32(addr, set) setbits(le32, addr, set)
  69. #define clrsetbits_le32(addr, clear, set) clrsetbits(le32, addr, clear, set)
  70. #define clrbits_be16(addr, clear) clrbits(be16, addr, clear)
  71. #define setbits_be16(addr, set) setbits(be16, addr, set)
  72. #define clrsetbits_be16(addr, clear, set) clrsetbits(be16, addr, clear, set)
  73. #define clrbits_le16(addr, clear) clrbits(le16, addr, clear)
  74. #define setbits_le16(addr, set) setbits(le16, addr, set)
  75. #define clrsetbits_le16(addr, clear, set) clrsetbits(le16, addr, clear, set)
  76. #define clrbits_8(addr, clear) clrbits(8, addr, clear)
  77. #define setbits_8(addr, set) setbits(8, addr, set)
  78. #define clrsetbits_8(addr, clear, set) clrsetbits(8, addr, clear, set)
  79. static inline void _insw(volatile u16 *port, void *buf, int ns)
  80. {
  81. }
  82. static inline void _outsw(volatile u16 *port, const void *buf, int ns)
  83. {
  84. }
  85. #define insw(port, buf, ns) _insw((u16 *)port, buf, ns)
  86. #define outsw(port, buf, ns) _outsw((u16 *)port, buf, ns)
  87. /* For systemace.c */
  88. #define out16(addr, val)
  89. #define in16(addr) 0
  90. #include <iotrace.h>
  91. #include <asm/types.h>
  92. #endif