mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-26 14:17:05 +08:00
These changes are designed to standardize the memory management across 'virt64' and 'c906', ensuring efficient handling of address spaces and page tables. Changes: - Creation of ASID management files (`asid.c`) for both 'c906' and 'virt64' architectures, which is essential for maintaining stability. - Extensive updates to the MMU configuration and handling in `mmu.c` and `mmu.h` files. - Addition of functions to manage ASID allocation and switching of page tables. - For c906, accommodated the early memory setup to the one from virt64. Signed-off-by: Shell <smokewood@qq.com>
30 lines
511 B
C
30 lines
511 B
C
/*
|
|
* Copyright (c) 2006-2021, RT-Thread Development Team
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2021-01-30 lizhirui first version
|
|
*/
|
|
|
|
#include <rthw.h>
|
|
#include <rtthread.h>
|
|
|
|
#include <stdint.h>
|
|
#include <riscv.h>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
|
|
#include "riscv_mmu.h"
|
|
|
|
void mmu_enable_user_page_access(void)
|
|
{
|
|
set_csr(sstatus, SSTATUS_SUM);
|
|
}
|
|
|
|
void mmu_disable_user_page_access(void)
|
|
{
|
|
clear_csr(sstatus, SSTATUS_SUM);
|
|
}
|