io.h: read/write[bwl] should use barrier
Add barrier() calls to low-level read/write io calls so that their callers don't need to. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
@@ -2,24 +2,34 @@
|
||||
#define __GENERIC_IO_H
|
||||
|
||||
#include <stdint.h> // uint32_t
|
||||
#include "compiler.h" // barrier
|
||||
|
||||
static inline void writel(void *addr, uint32_t val) {
|
||||
barrier();
|
||||
*(volatile uint32_t *)addr = val;
|
||||
}
|
||||
static inline void writew(void *addr, uint16_t val) {
|
||||
barrier();
|
||||
*(volatile uint16_t *)addr = val;
|
||||
}
|
||||
static inline void writeb(void *addr, uint8_t val) {
|
||||
barrier();
|
||||
*(volatile uint8_t *)addr = val;
|
||||
}
|
||||
static inline uint32_t readl(const void *addr) {
|
||||
return *(volatile const uint32_t *)addr;
|
||||
uint32_t val = *(volatile const uint32_t *)addr;
|
||||
barrier();
|
||||
return val;
|
||||
}
|
||||
static inline uint16_t readw(const void *addr) {
|
||||
return *(volatile const uint16_t *)addr;
|
||||
uint16_t val = *(volatile const uint16_t *)addr;
|
||||
barrier();
|
||||
return val;
|
||||
}
|
||||
static inline uint8_t readb(const void *addr) {
|
||||
return *(volatile const uint8_t *)addr;
|
||||
uint8_t val = *(volatile const uint8_t *)addr;
|
||||
barrier();
|
||||
return val;
|
||||
}
|
||||
|
||||
#endif // io.h
|
||||
|
||||
Reference in New Issue
Block a user