123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669 |
- #ifndef ZEPHYR_INCLUDE_SYS_MEM_MANAGE_H
- #define ZEPHYR_INCLUDE_SYS_MEM_MANAGE_H
- #include <sys/util.h>
- #include <toolchain.h>
- #define K_MEM_CACHE_NONE 2
- #define K_MEM_CACHE_WT 1
- #define K_MEM_CACHE_WB 0
- #define K_MEM_CACHE_MASK (BIT(3) - 1)
- #define K_MEM_PERM_RW BIT(3)
- #define K_MEM_PERM_EXEC BIT(4)
- #define K_MEM_PERM_USER BIT(5)
- #ifdef CONFIG_MMU
- #define Z_MEM_VM_OFFSET ((CONFIG_KERNEL_VM_BASE + CONFIG_KERNEL_VM_OFFSET) - \
- (CONFIG_SRAM_BASE_ADDRESS + CONFIG_SRAM_OFFSET))
- #else
- #define Z_MEM_VM_OFFSET 0
- #endif
- #define Z_MEM_PHYS_ADDR(virt) ((virt) - Z_MEM_VM_OFFSET)
- #define Z_MEM_VIRT_ADDR(phys) ((phys) + Z_MEM_VM_OFFSET)
- #if Z_MEM_VM_OFFSET != 0
- #define Z_VM_KERNEL 1
- #ifdef CONFIG_XIP
- #error "XIP and a virtual memory kernel are not allowed"
- #endif
- #endif
- #ifndef _ASMLANGUAGE
- #include <stdint.h>
- #include <stddef.h>
- #include <inttypes.h>
- #include <sys/__assert.h>
- struct k_mem_paging_stats_t {
- #ifdef CONFIG_DEMAND_PAGING_STATS
- struct {
-
- unsigned long cnt;
-
- unsigned long irq_locked;
-
- unsigned long irq_unlocked;
- #ifndef CONFIG_DEMAND_PAGING_ALLOW_IRQ
-
- unsigned long in_isr;
- #endif
- } pagefaults;
- struct {
-
- unsigned long clean;
-
- unsigned long dirty;
- } eviction;
- #endif
- };
- struct k_mem_paging_histogram_t {
- #ifdef CONFIG_DEMAND_PAGING_TIMING_HISTOGRAM
-
- unsigned long counts[CONFIG_DEMAND_PAGING_TIMING_HISTOGRAM_NUM_BINS];
-
- unsigned long bounds[CONFIG_DEMAND_PAGING_TIMING_HISTOGRAM_NUM_BINS];
- #endif
- };
- static inline uintptr_t z_mem_phys_addr(void *virt)
- {
- uintptr_t addr = (uintptr_t)virt;
- #ifdef CONFIG_MMU
- __ASSERT((addr >= CONFIG_KERNEL_VM_BASE) &&
- (addr < (CONFIG_KERNEL_VM_BASE +
- (CONFIG_KERNEL_VM_SIZE))),
- "address %p not in permanent mappings", virt);
- #else
-
- __ASSERT((addr >= CONFIG_SRAM_BASE_ADDRESS) &&
- (addr < (CONFIG_SRAM_BASE_ADDRESS +
- (CONFIG_SRAM_SIZE * 1024UL))),
- "physical address 0x%lx not in RAM",
- (unsigned long)addr);
- #endif
-
- return Z_MEM_PHYS_ADDR(addr);
- }
- static inline void *z_mem_virt_addr(uintptr_t phys)
- {
- __ASSERT((phys >= CONFIG_SRAM_BASE_ADDRESS) &&
- (phys < (CONFIG_SRAM_BASE_ADDRESS +
- (CONFIG_SRAM_SIZE * 1024UL))),
- "physical address 0x%lx not in RAM", (unsigned long)phys);
-
- return (void *)Z_MEM_VIRT_ADDR(phys);
- }
- #ifdef __cplusplus
- extern "C" {
- #endif
- void z_phys_map(uint8_t **virt_ptr, uintptr_t phys, size_t size,
- uint32_t flags);
- void z_phys_unmap(uint8_t *virt, size_t size);
- #define K_MEM_MAP_UNINIT BIT(16)
- #define K_MEM_MAP_LOCK BIT(17)
- #define K_MEM_MAP_GUARD __DEPRECATED_MACRO BIT(18)
- size_t k_mem_free_get(void);
- void *k_mem_map(size_t size, uint32_t flags);
- void k_mem_unmap(void *addr, size_t size);
- size_t k_mem_region_align(uintptr_t *aligned_addr, size_t *aligned_size,
- uintptr_t addr, size_t size, size_t align);
- int k_mem_page_out(void *addr, size_t size);
- void k_mem_page_in(void *addr, size_t size);
- void k_mem_pin(void *addr, size_t size);
- void k_mem_unpin(void *addr, size_t size);
- __syscall void k_mem_paging_stats_get(struct k_mem_paging_stats_t *stats);
- struct k_thread;
- __syscall
- void k_mem_paging_thread_stats_get(struct k_thread *thread,
- struct k_mem_paging_stats_t *stats);
- __syscall void k_mem_paging_histogram_eviction_get(
- struct k_mem_paging_histogram_t *hist);
- __syscall void k_mem_paging_histogram_backing_store_page_in_get(
- struct k_mem_paging_histogram_t *hist);
- __syscall void k_mem_paging_histogram_backing_store_page_out_get(
- struct k_mem_paging_histogram_t *hist);
- #include <syscalls/mem_manage.h>
- struct z_page_frame *k_mem_paging_eviction_select(bool *dirty);
- void k_mem_paging_eviction_init(void);
- int k_mem_paging_backing_store_location_get(struct z_page_frame *pf,
- uintptr_t *location,
- bool page_fault);
- void k_mem_paging_backing_store_location_free(uintptr_t location);
- void k_mem_paging_backing_store_page_out(uintptr_t location);
- void k_mem_paging_backing_store_page_in(uintptr_t location);
- void k_mem_paging_backing_store_page_finalize(struct z_page_frame *pf,
- uintptr_t location);
- void k_mem_paging_backing_store_init(void);
- #ifdef __cplusplus
- }
- #endif
- #endif
- #endif
|