7#ifndef ZEPHYR_INCLUDE_KERNEL_INTERNAL_MM_H
8#define ZEPHYR_INCLUDE_KERNEL_INTERNAL_MM_H
42#define K_MEM_VIRT_OFFSET ((CONFIG_KERNEL_VM_BASE + CONFIG_KERNEL_VM_OFFSET) - \
43 (DT_CHOSEN_SRAM_ADDR + CONFIG_SRAM_OFFSET))
45#define K_MEM_VIRT_OFFSET 0
48#if DT_CHOSEN_SRAM_ADDR != 0
49#define IS_SRAM_ADDRESS_LOWER(ADDR) ((ADDR) >= DT_CHOSEN_SRAM_ADDR)
51#define IS_SRAM_ADDRESS_LOWER(ADDR) true
54#if (DT_CHOSEN_SRAM_ADDR + DT_CHOSEN_SRAM_SIZE) != 0
55#define IS_SRAM_ADDRESS_UPPER(ADDR) \
56 ((ADDR) < (DT_CHOSEN_SRAM_ADDR + DT_CHOSEN_SRAM_SIZE))
58#define IS_SRAM_ADDRESS_UPPER(ADDR) false
61#define IS_SRAM_ADDRESS(ADDR) \
62 (IS_SRAM_ADDRESS_LOWER(ADDR) && \
63 IS_SRAM_ADDRESS_UPPER(ADDR))
74#define K_MEM_PHYS_ADDR(virt) ((virt) - K_MEM_VIRT_OFFSET)
85#define K_MEM_VIRT_ADDR(phys) ((phys) + K_MEM_VIRT_OFFSET)
87#if K_MEM_VIRT_OFFSET != 0
91#define K_MEM_IS_VM_KERNEL 1
93#error "XIP and a virtual memory kernel are not allowed"
119#if defined(CONFIG_KERNEL_VM_USE_CUSTOM_MEM_RANGE_CHECK)
121 "address %p not in permanent mappings", virt);
122#elif defined(CONFIG_MMU)
124#
if CONFIG_KERNEL_VM_BASE != 0
125 (addr >= CONFIG_KERNEL_VM_BASE) &&
127#
if (CONFIG_KERNEL_VM_BASE + CONFIG_KERNEL_VM_SIZE) != 0
128 (addr < (CONFIG_KERNEL_VM_BASE +
129 (CONFIG_KERNEL_VM_SIZE))),
133 "address %p not in permanent mappings", virt);
137 "physical address 0x%lx not in RAM",
138 (
unsigned long)addr);
161#if defined(CONFIG_KERNEL_VM_USE_CUSTOM_MEM_RANGE_CHECK)
163 "physical address 0x%lx not in RAM", (
unsigned long)phys);
166 "physical address 0x%lx not in RAM", (
unsigned long)phys);
void * k_mem_map_phys_guard(uintptr_t phys, size_t size, uint32_t flags, bool is_anon)
Map memory into virtual address space with guard pages.
#define K_MEM_PHYS_ADDR(virt)
Get physical address from virtual address.
Definition mm.h:74
#define K_MEM_VIRT_ADDR(phys)
Get virtual address from physical address.
Definition mm.h:85
void k_mem_map_phys_bare(uint8_t **virt_ptr, uintptr_t phys, size_t size, uint32_t flags)
Map a physical memory region into the kernel's virtual address space.
void k_mem_unmap_phys_guard(void *addr, size_t size, bool is_anon)
Un-map memory mapped via k_mem_map_phys_guard().
static uintptr_t k_mem_phys_addr(void *virt)
Get physical address from virtual address.
Definition mm.h:115
#define IS_SRAM_ADDRESS(ADDR)
Definition mm.h:61
void k_mem_unmap_phys_bare(uint8_t *virt, size_t size)
Unmap a virtual memory region from kernel's virtual address space.
static void * k_mem_virt_addr(uintptr_t phys)
Get virtual address from physical address.
Definition mm.h:159
bool sys_mm_is_virt_addr_in_range(void *virt)
Check if a virtual address is within range of virtual memory.
bool sys_mm_is_phys_addr_in_range(uintptr_t phys)
Check if a physical address is within range of physical memory.
flags
Definition parser.h:97
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINTPTR_TYPE__ uintptr_t
Definition stdint.h:105