io.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  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. /*
  40. * Clear and set bits in one shot. These macros can be used to clear and
  41. * set multiple bits in a register using a single call. These macros can
  42. * also be used to set a multiple-bit bit pattern using a mask, by
  43. * specifying the mask in the 'clear' parameter and the new bit pattern
  44. * in the 'set' parameter.
  45. */
  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_le64(a,v) out_arch(q,le64,a,v)
  49. #define out_le32(a,v) out_arch(l,le32,a,v)
  50. #define out_le16(a,v) out_arch(w,le16,a,v)
  51. #define in_le64(a) in_arch(q,le64,a)
  52. #define in_le32(a) in_arch(l,le32,a)
  53. #define in_le16(a) in_arch(w,le16,a)
  54. #define out_be32(a,v) out_arch(l,be32,a,v)
  55. #define out_be16(a,v) out_arch(w,be16,a,v)
  56. #define in_be32(a) in_arch(l,be32,a)
  57. #define in_be16(a) in_arch(w,be16,a)
  58. #define out_8(a,v) writeb(v,a)
  59. #define in_8(a) readb(a)
  60. #define clrbits(type, addr, clear) \
  61. out_##type((addr), in_##type(addr) & ~(clear))
  62. #define setbits(type, addr, set) \
  63. out_##type((addr), in_##type(addr) | (set))
  64. #define clrsetbits(type, addr, clear, set) \
  65. out_##type((addr), (in_##type(addr) & ~(clear)) | (set))
  66. #define clrbits_be32(addr, clear) clrbits(be32, addr, clear)
  67. #define setbits_be32(addr, set) setbits(be32, addr, set)
  68. #define clrsetbits_be32(addr, clear, set) clrsetbits(be32, addr, clear, set)
  69. #define clrbits_le32(addr, clear) clrbits(le32, addr, clear)
  70. #define setbits_le32(addr, set) setbits(le32, addr, set)
  71. #define clrsetbits_le32(addr, clear, set) clrsetbits(le32, addr, clear, set)
  72. #define clrbits_be16(addr, clear) clrbits(be16, addr, clear)
  73. #define setbits_be16(addr, set) setbits(be16, addr, set)
  74. #define clrsetbits_be16(addr, clear, set) clrsetbits(be16, addr, clear, set)
  75. #define clrbits_le16(addr, clear) clrbits(le16, addr, clear)
  76. #define setbits_le16(addr, set) setbits(le16, addr, set)
  77. #define clrsetbits_le16(addr, clear, set) clrsetbits(le16, addr, clear, set)
  78. #define clrbits_8(addr, clear) clrbits(8, addr, clear)
  79. #define setbits_8(addr, set) setbits(8, addr, set)
  80. #define clrsetbits_8(addr, clear, set) clrsetbits(8, addr, clear, set)
  81. /* I/O access functions */
  82. int inl(unsigned int addr);
  83. int inw(unsigned int addr);
  84. int inb(unsigned int addr);
  85. void outl(unsigned int value, unsigned int addr);
  86. void outw(unsigned int value, unsigned int addr);
  87. void outb(unsigned int value, unsigned int addr);
  88. #define out_arch(type,endian,a,v) write##type(cpu_to_##endian(v),a)
  89. #define in_arch(type,endian,a) endian##_to_cpu(read##type(a))
  90. #define out_le32(a,v) out_arch(l,le32,a,v)
  91. #define out_le16(a,v) out_arch(w,le16,a,v)
  92. #define in_le32(a) in_arch(l,le32,a)
  93. #define in_le16(a) in_arch(w,le16,a)
  94. #define out_be32(a,v) out_arch(l,be32,a,v)
  95. #define out_be16(a,v) out_arch(w,be16,a,v)
  96. #define in_be32(a) in_arch(l,be32,a)
  97. #define in_be16(a) in_arch(w,be16,a)
  98. #define out_8(a,v) writeb(v,a)
  99. #define in_8(a) readb(a)
  100. #define clrbits(type, addr, clear) \
  101. out_##type((addr), in_##type(addr) & ~(clear))
  102. #define setbits(type, addr, set) \
  103. out_##type((addr), in_##type(addr) | (set))
  104. #define clrsetbits(type, addr, clear, set) \
  105. out_##type((addr), (in_##type(addr) & ~(clear)) | (set))
  106. #define clrbits_be32(addr, clear) clrbits(be32, addr, clear)
  107. #define setbits_be32(addr, set) setbits(be32, addr, set)
  108. #define clrsetbits_be32(addr, clear, set) clrsetbits(be32, addr, clear, set)
  109. #define clrbits_le32(addr, clear) clrbits(le32, addr, clear)
  110. #define setbits_le32(addr, set) setbits(le32, addr, set)
  111. #define clrsetbits_le32(addr, clear, set) clrsetbits(le32, addr, clear, set)
  112. #define clrbits_be16(addr, clear) clrbits(be16, addr, clear)
  113. #define setbits_be16(addr, set) setbits(be16, addr, set)
  114. #define clrsetbits_be16(addr, clear, set) clrsetbits(be16, addr, clear, set)
  115. #define clrbits_le16(addr, clear) clrbits(le16, addr, clear)
  116. #define setbits_le16(addr, set) setbits(le16, addr, set)
  117. #define clrsetbits_le16(addr, clear, set) clrsetbits(le16, addr, clear, set)
  118. #define clrbits_8(addr, clear) clrbits(8, addr, clear)
  119. #define setbits_8(addr, set) setbits(8, addr, set)
  120. #define clrsetbits_8(addr, clear, set) clrsetbits(8, addr, clear, set)
  121. static inline void _insw(volatile u16 *port, void *buf, int ns)
  122. {
  123. }
  124. static inline void _outsw(volatile u16 *port, const void *buf, int ns)
  125. {
  126. }
  127. #define insw(port, buf, ns) _insw((u16 *)port, buf, ns)
  128. #define outsw(port, buf, ns) _outsw((u16 *)port, buf, ns)
  129. /* For systemace.c */
  130. #define out16(addr, val)
  131. #define in16(addr) 0
  132. #include <iotrace.h>
  133. #include <asm/types.h>
  134. #endif