107 lines
1.9 KiB
C
107 lines
1.9 KiB
C
/*
|
|
* Copyright (c) 2006-2023, RT-Thread Development Team
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Email: opensource_embedded@phytium.com.cn
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2023-04-27 huanghe first version
|
|
* 2023-07-27 zhangyan add qspi io space
|
|
*
|
|
*/
|
|
|
|
#include "rtconfig.h"
|
|
#include <board.h>
|
|
#include <mmu.h>
|
|
|
|
/* mmu config */
|
|
#ifdef RT_USING_SMART
|
|
#if defined(TARGET_ARMV8_AARCH64)
|
|
struct mem_desc platform_mem_desc[] =
|
|
{
|
|
{ KERNEL_VADDR_START,
|
|
KERNEL_VADDR_START + 0x0fffffff,
|
|
(rt_size_t)ARCH_MAP_FAILED,
|
|
NORMAL_MEM
|
|
}
|
|
};
|
|
#else
|
|
struct mem_desc platform_mem_desc[] =
|
|
{
|
|
{ KERNEL_VADDR_START,
|
|
KERNEL_VADDR_START + 0x10000000,
|
|
(rt_size_t)ARCH_MAP_FAILED,
|
|
NORMAL_MEM
|
|
}
|
|
};
|
|
#endif
|
|
#else
|
|
|
|
#if defined(TARGET_ARMV8_AARCH64)
|
|
|
|
struct mem_desc platform_mem_desc[] = {
|
|
{KERNEL_VADDR_START, DDR_END_ADDRESS , KERNEL_VADDR_START, NORMAL_MEM},
|
|
{
|
|
0x28000000U,
|
|
0x32B36FFFU,
|
|
0x28000000U,
|
|
DEVICE_MEM
|
|
},
|
|
{
|
|
0x00001000U,
|
|
0x0FFFFFFFU,
|
|
0x00001000U,
|
|
DEVICE_MEM
|
|
},
|
|
};
|
|
#else
|
|
struct mem_desc platform_mem_desc[] =
|
|
{
|
|
{
|
|
0x00U,
|
|
0x00U + 0x40000000U,
|
|
0x00U,
|
|
DEVICE_MEM
|
|
},
|
|
{
|
|
0x40000000U,
|
|
0x40000000U + 0x10000000U,
|
|
0x40000000U,
|
|
DEVICE_MEM
|
|
},
|
|
{
|
|
0x50000000U,
|
|
0x50000000U + 0x30000000U,
|
|
0x50000000U,
|
|
DEVICE_MEM
|
|
},
|
|
{
|
|
0x80000000U,
|
|
0xffffffffU,
|
|
0x80000000U,
|
|
NORMAL_MEM
|
|
},
|
|
#if defined(TARGET_ARMV8_AARCH64)
|
|
{
|
|
0x1000000000,
|
|
0x1000000000 + 0x1000000000,
|
|
0x1000000000,
|
|
DEVICE_MEM
|
|
},
|
|
{
|
|
0x2000000000,
|
|
0x2000000000 + 0x2000000000,
|
|
0x2000000000,
|
|
NORMAL_MEM
|
|
},
|
|
#endif
|
|
};
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
const rt_uint32_t platform_mem_desc_size = sizeof(platform_mem_desc) / sizeof(platform_mem_desc[0]);
|