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