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