io.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Copyright (c) 2011 The Chromium OS Authors.
  4. */
  5. #ifndef __SANDBOX_ASM_IO_H
  6. #define __SANDBOX_ASM_IO_H
  7. void *phys_to_virt(phys_addr_t paddr);
  8. #define phys_to_virt phys_to_virt
  9. phys_addr_t virt_to_phys(void *vaddr);
  10. #define virt_to_phys virt_to_phys
  11. void *map_physmem(phys_addr_t paddr, unsigned long len, unsigned long flags);
  12. #define map_physmem map_physmem
  13. /*
  14. * Take down a mapping set up by map_physmem().
  15. */
  16. void unmap_physmem(const void *vaddr, unsigned long flags);
  17. #define unmap_physmem unmap_physmem
  18. #include <asm-generic/io.h>
  19. /* For sandbox, we want addresses to point into our RAM buffer */
  20. static inline void *map_sysmem(phys_addr_t paddr, unsigned long len)
  21. {
  22. return map_physmem(paddr, len, MAP_WRBACK);
  23. }
  24. /* Remove a previous mapping */
  25. static inline void unmap_sysmem(const void *vaddr)
  26. {
  27. unmap_physmem(vaddr, MAP_WRBACK);
  28. }
  29. /* Map from a pointer to our RAM buffer */
  30. phys_addr_t map_to_sysmem(const void *ptr);
  31. /* Define nops for sandbox I/O access */
  32. #define readb(addr) ((void)addr, 0)
  33. #define readw(addr) ((void)addr, 0)
  34. #define readl(addr) ((void)addr, 0)
  35. #ifdef CONFIG_SANDBOX64
  36. #define readq(addr) ((void)addr, 0)
  37. #endif
  38. #define writeb(v, addr) ((void)addr)
  39. #define writew(v, addr) ((void)addr)
  40. #define writel(v, addr) ((void)addr)
  41. #ifdef CONFIG_SANDBOX64
  42. #define writeq(v, addr) ((void)addr)
  43. #endif
  44. /*
  45. * Clear and set bits in one shot. These macros can be used to clear and
  46. * set multiple bits in a register using a single call. These macros can
  47. * also be used to set a multiple-bit bit pattern using a mask, by
  48. * specifying the mask in the 'clear' parameter and the new bit pattern
  49. * in the 'set' parameter.
  50. */
  51. #define out_arch(type,endian,a,v) write##type(cpu_to_##endian(v),a)
  52. #define in_arch(type,endian,a) endian##_to_cpu(read##type(a))
  53. #define out_le64(a,v) out_arch(q,le64,a,v)
  54. #define out_le32(a,v) out_arch(l,le32,a,v)
  55. #define out_le16(a,v) out_arch(w,le16,a,v)
  56. #define in_le64(a) in_arch(q,le64,a)
  57. #define in_le32(a) in_arch(l,le32,a)
  58. #define in_le16(a) in_arch(w,le16,a)
  59. #define out_be32(a,v) out_arch(l,be32,a,v)
  60. #define out_be16(a,v) out_arch(w,be16,a,v)
  61. #define in_be32(a) in_arch(l,be32,a)
  62. #define in_be16(a) in_arch(w,be16,a)
  63. #define out_8(a,v) writeb(v,a)
  64. #define in_8(a) readb(a)
  65. #define clrbits(type, addr, clear) \
  66. out_##type((addr), in_##type(addr) & ~(clear))
  67. #define setbits(type, addr, set) \
  68. out_##type((addr), in_##type(addr) | (set))
  69. #define clrsetbits(type, addr, clear, set) \
  70. out_##type((addr), (in_##type(addr) & ~(clear)) | (set))
  71. #define clrbits_be32(addr, clear) clrbits(be32, addr, clear)
  72. #define setbits_be32(addr, set) setbits(be32, addr, set)
  73. #define clrsetbits_be32(addr, clear, set) clrsetbits(be32, addr, clear, set)
  74. #define clrbits_le32(addr, clear) clrbits(le32, addr, clear)
  75. #define setbits_le32(addr, set) setbits(le32, addr, set)
  76. #define clrsetbits_le32(addr, clear, set) clrsetbits(le32, addr, clear, set)
  77. #define clrbits_be16(addr, clear) clrbits(be16, addr, clear)
  78. #define setbits_be16(addr, set) setbits(be16, addr, set)
  79. #define clrsetbits_be16(addr, clear, set) clrsetbits(be16, addr, clear, set)
  80. #define clrbits_le16(addr, clear) clrbits(le16, addr, clear)
  81. #define setbits_le16(addr, set) setbits(le16, addr, set)
  82. #define clrsetbits_le16(addr, clear, set) clrsetbits(le16, addr, clear, set)
  83. #define clrbits_8(addr, clear) clrbits(8, addr, clear)
  84. #define setbits_8(addr, set) setbits(8, addr, set)
  85. #define clrsetbits_8(addr, clear, set) clrsetbits(8, addr, clear, set)
  86. /* I/O access functions */
  87. int inl(unsigned int addr);
  88. int inw(unsigned int addr);
  89. int inb(unsigned int addr);
  90. void outl(unsigned int value, unsigned int addr);
  91. void outw(unsigned int value, unsigned int addr);
  92. void outb(unsigned int value, unsigned int addr);
  93. #define out_arch(type,endian,a,v) write##type(cpu_to_##endian(v),a)
  94. #define in_arch(type,endian,a) endian##_to_cpu(read##type(a))
  95. #define out_le32(a,v) out_arch(l,le32,a,v)
  96. #define out_le16(a,v) out_arch(w,le16,a,v)
  97. #define in_le32(a) in_arch(l,le32,a)
  98. #define in_le16(a) in_arch(w,le16,a)
  99. #define out_be32(a,v) out_arch(l,be32,a,v)
  100. #define out_be16(a,v) out_arch(w,be16,a,v)
  101. #define in_be32(a) in_arch(l,be32,a)
  102. #define in_be16(a) in_arch(w,be16,a)
  103. #define out_8(a,v) writeb(v,a)
  104. #define in_8(a) readb(a)
  105. #define clrbits(type, addr, clear) \
  106. out_##type((addr), in_##type(addr) & ~(clear))
  107. #define setbits(type, addr, set) \
  108. out_##type((addr), in_##type(addr) | (set))
  109. #define clrsetbits(type, addr, clear, set) \
  110. out_##type((addr), (in_##type(addr) & ~(clear)) | (set))
  111. #define clrbits_be32(addr, clear) clrbits(be32, addr, clear)
  112. #define setbits_be32(addr, set) setbits(be32, addr, set)
  113. #define clrsetbits_be32(addr, clear, set) clrsetbits(be32, addr, clear, set)
  114. #define clrbits_le32(addr, clear) clrbits(le32, addr, clear)
  115. #define setbits_le32(addr, set) setbits(le32, addr, set)
  116. #define clrsetbits_le32(addr, clear, set) clrsetbits(le32, addr, clear, set)
  117. #define clrbits_be16(addr, clear) clrbits(be16, addr, clear)
  118. #define setbits_be16(addr, set) setbits(be16, addr, set)
  119. #define clrsetbits_be16(addr, clear, set) clrsetbits(be16, addr, clear, set)
  120. #define clrbits_le16(addr, clear) clrbits(le16, addr, clear)
  121. #define setbits_le16(addr, set) setbits(le16, addr, set)
  122. #define clrsetbits_le16(addr, clear, set) clrsetbits(le16, addr, clear, set)
  123. #define clrbits_8(addr, clear) clrbits(8, addr, clear)
  124. #define setbits_8(addr, set) setbits(8, addr, set)
  125. #define clrsetbits_8(addr, clear, set) clrsetbits(8, addr, clear, set)
  126. static inline void _insw(volatile u16 *port, void *buf, int ns)
  127. {
  128. }
  129. static inline void _outsw(volatile u16 *port, const void *buf, int ns)
  130. {
  131. }
  132. #define insw(port, buf, ns) _insw((u16 *)port, buf, ns)
  133. #define outsw(port, buf, ns) _outsw((u16 *)port, buf, ns)
  134. #include <iotrace.h>
  135. #include <asm/types.h>
  136. #endif