add 8-bit and 16-bit MMIO read/write functions
This commit is contained in:
24
tests/mmio.h
24
tests/mmio.h
@@ -3,6 +3,30 @@
|
|||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
|
static inline void reg_write8(uintptr_t addr, uint8_t data)
|
||||||
|
{
|
||||||
|
volatile uint8_t *ptr = (volatile uint8_t *) addr;
|
||||||
|
*ptr = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline uint8_t reg_read8(uintptr_t addr)
|
||||||
|
{
|
||||||
|
volatile uint8_t *ptr = (volatile uint8_t *) addr;
|
||||||
|
return *ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void reg_write16(uintptr_t addr, uint16_t data)
|
||||||
|
{
|
||||||
|
volatile uint16_t *ptr = (volatile uint16_t *) addr;
|
||||||
|
*ptr = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline uint16_t reg_read16(uintptr_t addr)
|
||||||
|
{
|
||||||
|
volatile uint16_t *ptr = (volatile uint16_t *) addr;
|
||||||
|
return *ptr;
|
||||||
|
}
|
||||||
|
|
||||||
static inline void reg_write32(uintptr_t addr, uint32_t data)
|
static inline void reg_write32(uintptr_t addr, uint32_t data)
|
||||||
{
|
{
|
||||||
volatile uint32_t *ptr = (volatile uint32_t *) addr;
|
volatile uint32_t *ptr = (volatile uint32_t *) addr;
|
||||||
|
|||||||
Reference in New Issue
Block a user