Linux 3.12.5
[linux/fpc-iii.git] / include / asm-generic / io-64-nonatomic-lo-hi.h
blobca546b1ff8b5539db5da033933e54770d5fdc101
1 #ifndef _ASM_IO_64_NONATOMIC_LO_HI_H_
2 #define _ASM_IO_64_NONATOMIC_LO_HI_H_
4 #include <linux/io.h>
5 #include <asm-generic/int-ll64.h>
7 #ifndef readq
8 static inline __u64 readq(const volatile void __iomem *addr)
10 const volatile u32 __iomem *p = addr;
11 u32 low, high;
13 low = readl(p);
14 high = readl(p + 1);
16 return low + ((u64)high << 32);
18 #endif
20 #ifndef writeq
21 static inline void writeq(__u64 val, volatile void __iomem *addr)
23 writel(val, addr);
24 writel(val >> 32, addr + 4);
26 #endif
28 #endif /* _ASM_IO_64_NONATOMIC_LO_HI_H_ */