risc-v/bl808, sg2000: Configure MMU to cache Kernel Text, Data and Heap (T-Head C906)
This PR configures the BL808 and SG2000 MMU (inside T-Head C906) to cache the the Kernel Text, Data and Heap. We set the MMU Flags (Shareable, Bufferable and Cacheable) as explained in this article: https://lupyuen.github.io/articles/plic3#appendix-mmu-caching-for-t-head-c906 This PR fixes the Slow Memory Access for NuttX Kernel in BL808 and SG2000: https://github.com/apache/nuttx/issues/12696 In the next PR, we will fix the Slow Memory Access for NuttX Apps, by caching the User Text and Data. arch/risc-v/src/bl808/bl808_mm_init.c: Added MMU Flags (Shareable, Bufferable and Cacheable) for BL808 Kernel Text, Data and Heap arch/risc-v/src/sg2000/sg2000_mm_init.c: Added MMU Flags (Shareable, Bufferable and Cacheable) for SG2000 Kernel Text, Data and Heap
This commit is contained in:
parent
d6c67c555f
commit
bdf60d7966
@ -40,13 +40,24 @@
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/* T-Head C906 MMU requires Strong Order and Shareable for I/O Memory */
|
||||
/* T-Head C906 MMU Extensions */
|
||||
|
||||
#define MMU_THEAD_SHAREABLE (1ul << 60)
|
||||
#define MMU_THEAD_BUFFERABLE (1ul << 61)
|
||||
#define MMU_THEAD_CACHEABLE (1ul << 62)
|
||||
#define MMU_THEAD_STRONG_ORDER (1ul << 63)
|
||||
|
||||
/* T-Head C906 MMU requires Strong Order and Shareable for I/O Memory */
|
||||
|
||||
#define MMU_THEAD_IO_FLAGS (MMU_IO_FLAGS | MMU_THEAD_SHAREABLE | \
|
||||
MMU_THEAD_STRONG_ORDER)
|
||||
|
||||
/* T-Head C906 MMU requires Kernel Memory to be explicitly cached */
|
||||
|
||||
#define MMU_THEAD_PMA_FLAGS (MMU_THEAD_SHAREABLE | \
|
||||
MMU_THEAD_BUFFERABLE | \
|
||||
MMU_THEAD_CACHEABLE)
|
||||
|
||||
/* Map the I/O and PLIC Memory with vaddr = paddr mappings */
|
||||
|
||||
#define MMU_IO_BASE (0x00000000ul)
|
||||
@ -258,10 +269,12 @@ void bl808_kernel_mappings(void)
|
||||
/* Map the kernel text and data for L2/L3 */
|
||||
|
||||
binfo("map kernel text\n");
|
||||
map_region(KFLASH_START, KFLASH_START, KFLASH_SIZE, MMU_KTEXT_FLAGS);
|
||||
map_region(KFLASH_START, KFLASH_START, KFLASH_SIZE,
|
||||
MMU_KTEXT_FLAGS | MMU_THEAD_PMA_FLAGS);
|
||||
|
||||
binfo("map kernel data\n");
|
||||
map_region(KSRAM_START, KSRAM_START, KSRAM_SIZE, MMU_KDATA_FLAGS);
|
||||
map_region(KSRAM_START, KSRAM_START, KSRAM_SIZE,
|
||||
MMU_KDATA_FLAGS | MMU_THEAD_PMA_FLAGS);
|
||||
|
||||
/* Connect the L1 and L2 page tables for the kernel text and data */
|
||||
|
||||
@ -272,7 +285,7 @@ void bl808_kernel_mappings(void)
|
||||
|
||||
binfo("map the page pool\n");
|
||||
mmu_ln_map_region(2, PGT_L2_VBASE, PGPOOL_START, PGPOOL_START, PGPOOL_SIZE,
|
||||
MMU_KDATA_FLAGS);
|
||||
MMU_KDATA_FLAGS | MMU_THEAD_PMA_FLAGS);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
|
@ -40,13 +40,24 @@
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/* T-Head C906 MMU requires Strong Order and Shareable for I/O Memory */
|
||||
/* T-Head C906 MMU Extensions */
|
||||
|
||||
#define MMU_THEAD_SHAREABLE (1ul << 60)
|
||||
#define MMU_THEAD_BUFFERABLE (1ul << 61)
|
||||
#define MMU_THEAD_CACHEABLE (1ul << 62)
|
||||
#define MMU_THEAD_STRONG_ORDER (1ul << 63)
|
||||
|
||||
/* T-Head C906 MMU requires Strong Order and Shareable for I/O Memory */
|
||||
|
||||
#define MMU_THEAD_IO_FLAGS (MMU_IO_FLAGS | MMU_THEAD_SHAREABLE | \
|
||||
MMU_THEAD_STRONG_ORDER)
|
||||
|
||||
/* T-Head C906 MMU requires Kernel Memory to be explicitly cached */
|
||||
|
||||
#define MMU_THEAD_PMA_FLAGS (MMU_THEAD_SHAREABLE | \
|
||||
MMU_THEAD_BUFFERABLE | \
|
||||
MMU_THEAD_CACHEABLE)
|
||||
|
||||
/* Map the I/O and PLIC Memory with vaddr = paddr mappings */
|
||||
|
||||
#define MMU_IO_BASE (0x00000000ul)
|
||||
@ -258,10 +269,12 @@ void sg2000_kernel_mappings(void)
|
||||
/* Map the kernel text and data for L2/L3 */
|
||||
|
||||
binfo("map kernel text\n");
|
||||
map_region(KFLASH_START, KFLASH_START, KFLASH_SIZE, MMU_KTEXT_FLAGS);
|
||||
map_region(KFLASH_START, KFLASH_START, KFLASH_SIZE,
|
||||
MMU_KTEXT_FLAGS | MMU_THEAD_PMA_FLAGS);
|
||||
|
||||
binfo("map kernel data\n");
|
||||
map_region(KSRAM_START, KSRAM_START, KSRAM_SIZE, MMU_KDATA_FLAGS);
|
||||
map_region(KSRAM_START, KSRAM_START, KSRAM_SIZE,
|
||||
MMU_KDATA_FLAGS | MMU_THEAD_PMA_FLAGS);
|
||||
|
||||
/* Connect the L1 and L2 page tables for the kernel text and data */
|
||||
|
||||
@ -272,7 +285,7 @@ void sg2000_kernel_mappings(void)
|
||||
|
||||
binfo("map the page pool\n");
|
||||
mmu_ln_map_region(2, PGT_L2_VBASE, PGPOOL_START, PGPOOL_START, PGPOOL_SIZE,
|
||||
MMU_KDATA_FLAGS);
|
||||
MMU_KDATA_FLAGS | MMU_THEAD_PMA_FLAGS);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
|
Loading…
Reference in New Issue
Block a user