xref: /kvm-unit-tests/lib/asm-generic/io.h (revision a0940b318d0f5accd753dea734d0ad66b7dfcb28)
13df0ccccSAndrew Jones #ifndef _ASM_GENERIC_IO_H_
23df0ccccSAndrew Jones #define _ASM_GENERIC_IO_H_
33df0ccccSAndrew Jones /*
43df0ccccSAndrew Jones  * asm-generic/io.h
53df0ccccSAndrew Jones  *  adapted from the Linux kernel's include/asm-generic/io.h
63df0ccccSAndrew Jones  *  and arch/arm/include/asm/io.h
73df0ccccSAndrew Jones  *
83df0ccccSAndrew Jones  * Copyright (C) 2014, Red Hat Inc, Andrew Jones <drjones@redhat.com>
93df0ccccSAndrew Jones  *
103df0ccccSAndrew Jones  * This work is licensed under the terms of the GNU LGPL, version 2.
113df0ccccSAndrew Jones  */
123df0ccccSAndrew Jones #include "libcflat.h"
13f4f73de7SAndrew Jones #include "asm/page.h"
142b0de978SAlexander Gordeev #include "asm/barrier.h"
153df0ccccSAndrew Jones 
163df0ccccSAndrew Jones #ifndef __raw_readb
173df0ccccSAndrew Jones static inline u8 __raw_readb(const volatile void *addr)
183df0ccccSAndrew Jones {
193df0ccccSAndrew Jones 	return *(const volatile u8 *)addr;
203df0ccccSAndrew Jones }
213df0ccccSAndrew Jones #endif
223df0ccccSAndrew Jones 
233df0ccccSAndrew Jones #ifndef __raw_readw
243df0ccccSAndrew Jones static inline u16 __raw_readw(const volatile void *addr)
253df0ccccSAndrew Jones {
263df0ccccSAndrew Jones 	return *(const volatile u16 *)addr;
273df0ccccSAndrew Jones }
283df0ccccSAndrew Jones #endif
293df0ccccSAndrew Jones 
303df0ccccSAndrew Jones #ifndef __raw_readl
313df0ccccSAndrew Jones static inline u32 __raw_readl(const volatile void *addr)
323df0ccccSAndrew Jones {
333df0ccccSAndrew Jones 	return *(const volatile u32 *)addr;
343df0ccccSAndrew Jones }
353df0ccccSAndrew Jones #endif
363df0ccccSAndrew Jones 
373df0ccccSAndrew Jones #ifndef __raw_readq
383df0ccccSAndrew Jones static inline u64 __raw_readq(const volatile void *addr)
393df0ccccSAndrew Jones {
403df0ccccSAndrew Jones 	assert(sizeof(unsigned long) == sizeof(u64));
413df0ccccSAndrew Jones 	return *(const volatile u64 *)addr;
423df0ccccSAndrew Jones }
433df0ccccSAndrew Jones #endif
443df0ccccSAndrew Jones 
453df0ccccSAndrew Jones #ifndef __raw_writeb
463df0ccccSAndrew Jones static inline void __raw_writeb(u8 b, volatile void *addr)
473df0ccccSAndrew Jones {
483df0ccccSAndrew Jones 	*(volatile u8 *)addr = b;
493df0ccccSAndrew Jones }
503df0ccccSAndrew Jones #endif
513df0ccccSAndrew Jones 
523df0ccccSAndrew Jones #ifndef __raw_writew
533df0ccccSAndrew Jones static inline void __raw_writew(u16 b, volatile void *addr)
543df0ccccSAndrew Jones {
553df0ccccSAndrew Jones 	*(volatile u16 *)addr = b;
563df0ccccSAndrew Jones }
573df0ccccSAndrew Jones #endif
583df0ccccSAndrew Jones 
593df0ccccSAndrew Jones #ifndef __raw_writel
603df0ccccSAndrew Jones static inline void __raw_writel(u32 b, volatile void *addr)
613df0ccccSAndrew Jones {
623df0ccccSAndrew Jones 	*(volatile u32 *)addr = b;
633df0ccccSAndrew Jones }
643df0ccccSAndrew Jones #endif
653df0ccccSAndrew Jones 
663df0ccccSAndrew Jones #ifndef __raw_writeq
673df0ccccSAndrew Jones static inline void __raw_writeq(u64 b, volatile void *addr)
683df0ccccSAndrew Jones {
693df0ccccSAndrew Jones 	assert(sizeof(unsigned long) == sizeof(u64));
703df0ccccSAndrew Jones 	*(volatile u64 *)addr = b;
713df0ccccSAndrew Jones }
723df0ccccSAndrew Jones #endif
733df0ccccSAndrew Jones 
743df0ccccSAndrew Jones #ifndef __bswap16
753df0ccccSAndrew Jones static inline u16 __bswap16(u16 x)
763df0ccccSAndrew Jones {
773df0ccccSAndrew Jones 	return ((x >> 8) & 0xff) | ((x & 0xff) << 8);
783df0ccccSAndrew Jones }
793df0ccccSAndrew Jones #endif
803df0ccccSAndrew Jones 
813df0ccccSAndrew Jones #ifndef __bswap32
823df0ccccSAndrew Jones static inline u32 __bswap32(u32 x)
833df0ccccSAndrew Jones {
843df0ccccSAndrew Jones 	return ((x & 0xff000000) >> 24) | ((x & 0x00ff0000) >>  8) |
853df0ccccSAndrew Jones 	       ((x & 0x0000ff00) <<  8) | ((x & 0x000000ff) << 24);
863df0ccccSAndrew Jones }
873df0ccccSAndrew Jones #endif
883df0ccccSAndrew Jones 
893df0ccccSAndrew Jones #ifndef __bswap64
903df0ccccSAndrew Jones static inline u64 __bswap64(u64 x)
913df0ccccSAndrew Jones {
923df0ccccSAndrew Jones 	return ((x & 0x00000000000000ffULL) << 56) |
933df0ccccSAndrew Jones 	       ((x & 0x000000000000ff00ULL) << 40) |
943df0ccccSAndrew Jones 	       ((x & 0x0000000000ff0000ULL) << 24) |
953df0ccccSAndrew Jones 	       ((x & 0x00000000ff000000ULL) <<  8) |
963df0ccccSAndrew Jones 	       ((x & 0x000000ff00000000ULL) >>  8) |
973df0ccccSAndrew Jones 	       ((x & 0x0000ff0000000000ULL) >> 24) |
983df0ccccSAndrew Jones 	       ((x & 0x00ff000000000000ULL) >> 40) |
993df0ccccSAndrew Jones 	       ((x & 0xff00000000000000ULL) >> 56);
1003df0ccccSAndrew Jones }
1013df0ccccSAndrew Jones #endif
1023df0ccccSAndrew Jones 
1033df0ccccSAndrew Jones #ifndef __cpu_is_be
1043df0ccccSAndrew Jones #define __cpu_is_be() (0)
1053df0ccccSAndrew Jones #endif
1063df0ccccSAndrew Jones 
1073df0ccccSAndrew Jones #define le16_to_cpu(x) \
10855243010SAndrew Jones 	({ u16 __r = __cpu_is_be() ? __bswap16(x) : ((u16)x); __r; })
1093df0ccccSAndrew Jones #define cpu_to_le16 le16_to_cpu
1103df0ccccSAndrew Jones 
1113df0ccccSAndrew Jones #define le32_to_cpu(x) \
11255243010SAndrew Jones 	({ u32 __r = __cpu_is_be() ? __bswap32(x) : ((u32)x); __r; })
1133df0ccccSAndrew Jones #define cpu_to_le32 le32_to_cpu
1143df0ccccSAndrew Jones 
1153df0ccccSAndrew Jones #define le64_to_cpu(x) \
11655243010SAndrew Jones 	({ u64 __r = __cpu_is_be() ? __bswap64(x) : ((u64)x); __r; })
1173df0ccccSAndrew Jones #define cpu_to_le64 le64_to_cpu
1183df0ccccSAndrew Jones 
1193df0ccccSAndrew Jones #define be16_to_cpu(x) \
12055243010SAndrew Jones 	({ u16 __r = !__cpu_is_be() ? __bswap16(x) : ((u16)x); __r; })
1213df0ccccSAndrew Jones #define cpu_to_be16 be16_to_cpu
1223df0ccccSAndrew Jones 
1233df0ccccSAndrew Jones #define be32_to_cpu(x) \
12455243010SAndrew Jones 	({ u32 __r = !__cpu_is_be() ? __bswap32(x) : ((u32)x); __r; })
1253df0ccccSAndrew Jones #define cpu_to_be32 be32_to_cpu
1263df0ccccSAndrew Jones 
1273df0ccccSAndrew Jones #define be64_to_cpu(x) \
12855243010SAndrew Jones 	({ u64 __r = !__cpu_is_be() ? __bswap64(x) : ((u64)x); __r; })
1293df0ccccSAndrew Jones #define cpu_to_be64 be64_to_cpu
1303df0ccccSAndrew Jones 
1313df0ccccSAndrew Jones #define readb(addr) \
1323df0ccccSAndrew Jones 	({ u8 __r = __raw_readb(addr); rmb(); __r; })
1333df0ccccSAndrew Jones #define readw(addr) \
1343df0ccccSAndrew Jones 	({ u16 __r = le16_to_cpu(__raw_readw(addr)); rmb(); __r; })
1353df0ccccSAndrew Jones #define readl(addr) \
1363df0ccccSAndrew Jones 	({ u32 __r = le32_to_cpu(__raw_readl(addr)); rmb(); __r; })
1373df0ccccSAndrew Jones #define readq(addr) \
1383df0ccccSAndrew Jones 	({ u64 __r = le64_to_cpu(__raw_readq(addr)); rmb(); __r; })
1393df0ccccSAndrew Jones 
1403df0ccccSAndrew Jones #define writeb(b, addr) \
1413df0ccccSAndrew Jones 	({ wmb(); __raw_writeb(b, addr); })
1423df0ccccSAndrew Jones #define writew(b, addr) \
1433df0ccccSAndrew Jones 	({ wmb(); __raw_writew(cpu_to_le16(b), addr); })
1443df0ccccSAndrew Jones #define writel(b, addr) \
1453df0ccccSAndrew Jones 	({ wmb(); __raw_writel(cpu_to_le32(b), addr); })
1463df0ccccSAndrew Jones #define writeq(b, addr) \
1473df0ccccSAndrew Jones 	({ wmb(); __raw_writeq(cpu_to_le64(b), addr); })
1483df0ccccSAndrew Jones 
149*a0940b31SAlexander Gordeev #ifndef inb
150*a0940b31SAlexander Gordeev static inline uint8_t inb(unsigned long port)
151*a0940b31SAlexander Gordeev {
152*a0940b31SAlexander Gordeev 	return readb((const volatile void __iomem *)port);
153*a0940b31SAlexander Gordeev }
154*a0940b31SAlexander Gordeev #endif
155*a0940b31SAlexander Gordeev 
156*a0940b31SAlexander Gordeev #ifndef inw
157*a0940b31SAlexander Gordeev static inline uint16_t inw(unsigned long port)
158*a0940b31SAlexander Gordeev {
159*a0940b31SAlexander Gordeev 	return readw((const volatile void __iomem *)port);
160*a0940b31SAlexander Gordeev }
161*a0940b31SAlexander Gordeev #endif
162*a0940b31SAlexander Gordeev 
163*a0940b31SAlexander Gordeev #ifndef inl
164*a0940b31SAlexander Gordeev static inline uint32_t inl(unsigned long port)
165*a0940b31SAlexander Gordeev {
166*a0940b31SAlexander Gordeev 	return readl((const volatile void __iomem *)port);
167*a0940b31SAlexander Gordeev }
168*a0940b31SAlexander Gordeev #endif
169*a0940b31SAlexander Gordeev 
170*a0940b31SAlexander Gordeev #ifndef outb
171*a0940b31SAlexander Gordeev static inline void outb(uint8_t value, unsigned long port)
172*a0940b31SAlexander Gordeev {
173*a0940b31SAlexander Gordeev 	writeb(value, (volatile void __iomem *)port);
174*a0940b31SAlexander Gordeev }
175*a0940b31SAlexander Gordeev #endif
176*a0940b31SAlexander Gordeev 
177*a0940b31SAlexander Gordeev #ifndef outw
178*a0940b31SAlexander Gordeev static inline void outw(uint16_t value, unsigned long port)
179*a0940b31SAlexander Gordeev {
180*a0940b31SAlexander Gordeev 	writew(value, (volatile void __iomem *)port);
181*a0940b31SAlexander Gordeev }
182*a0940b31SAlexander Gordeev #endif
183*a0940b31SAlexander Gordeev 
184*a0940b31SAlexander Gordeev #ifndef outl
185*a0940b31SAlexander Gordeev static inline void outl(uint32_t value, unsigned long port)
186*a0940b31SAlexander Gordeev {
187*a0940b31SAlexander Gordeev 	writel(value, (volatile void __iomem *)port);
188*a0940b31SAlexander Gordeev }
189*a0940b31SAlexander Gordeev #endif
190*a0940b31SAlexander Gordeev 
1913df0ccccSAndrew Jones #ifndef ioremap
1924f37c3a9SAlexander Gordeev static inline void __iomem *ioremap(phys_addr_t phys_addr, size_t size __unused)
1933df0ccccSAndrew Jones {
1943df0ccccSAndrew Jones 	assert(sizeof(long) == 8 || !(phys_addr >> 32));
1954f37c3a9SAlexander Gordeev 	return (void __iomem *)(unsigned long)phys_addr;
1963df0ccccSAndrew Jones }
1973df0ccccSAndrew Jones #endif
1983df0ccccSAndrew Jones 
199f4f73de7SAndrew Jones #ifndef virt_to_phys
200f4f73de7SAndrew Jones static inline unsigned long virt_to_phys(volatile void *address)
201f4f73de7SAndrew Jones {
202f4f73de7SAndrew Jones 	return __pa((unsigned long)address);
203f4f73de7SAndrew Jones }
20445aeebbfSAlexander Gordeev #endif
205f4f73de7SAndrew Jones 
20645aeebbfSAlexander Gordeev #ifndef phys_to_virt
207f4f73de7SAndrew Jones static inline void *phys_to_virt(unsigned long address)
208f4f73de7SAndrew Jones {
209f4f73de7SAndrew Jones 	return __va(address);
210f4f73de7SAndrew Jones }
211f4f73de7SAndrew Jones #endif
212f4f73de7SAndrew Jones 
2133df0ccccSAndrew Jones #endif /* _ASM_GENERIC_IO_H_ */
214