2020-02-04 09:20:29 +08:00
|
|
|
#ifndef _HW_COMMON_H_
|
|
|
|
#define _HW_COMMON_H_
|
|
|
|
#include <stdint.h>
|
2021-03-15 19:27:36 +05:30
|
|
|
static inline void csr_writeb(uint8_t value, uint32_t addr) {
|
|
|
|
*((volatile uint8_t *)addr) = value;
|
2020-02-04 09:20:29 +08:00
|
|
|
}
|
|
|
|
|
2021-03-15 19:27:36 +05:30
|
|
|
static inline uint8_t csr_readb(uint32_t addr) {
|
|
|
|
return *(volatile uint8_t *)addr;
|
2020-02-04 09:20:29 +08:00
|
|
|
}
|
|
|
|
|
2021-03-15 19:27:36 +05:30
|
|
|
static inline void csr_writew(uint16_t value, uint32_t addr) {
|
|
|
|
*((volatile uint16_t *)addr) = value;
|
2020-02-04 09:20:29 +08:00
|
|
|
}
|
|
|
|
|
2021-03-15 19:27:36 +05:30
|
|
|
static inline uint16_t csr_readw(uint32_t addr) {
|
|
|
|
return *(volatile uint16_t *)addr;
|
2020-02-04 09:20:29 +08:00
|
|
|
}
|
|
|
|
|
2021-03-15 19:27:36 +05:30
|
|
|
static inline void csr_writel(uint32_t value, uint32_t addr) {
|
|
|
|
*((volatile uint32_t *)addr) = value;
|
2020-02-04 09:20:29 +08:00
|
|
|
}
|
|
|
|
|
2021-03-15 19:27:36 +05:30
|
|
|
static inline uint32_t csr_readl(uint32_t addr) {
|
|
|
|
return *(volatile uint32_t *)addr;
|
2020-02-04 09:20:29 +08:00
|
|
|
}
|
2020-05-30 10:44:13 +01:00
|
|
|
#endif /* _HW_COMMON_H_ */
|