Fix data region mappin
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@2871 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
3db7ecd49b
commit
4512507356
@ -84,6 +84,10 @@
|
|||||||
# endif
|
# endif
|
||||||
|
|
||||||
#define PT_SIZE (PTE_NPAGES * 4)
|
#define PT_SIZE (PTE_NPAGES * 4)
|
||||||
|
|
||||||
|
/* We position the data section PTE's just after the text section PTE's */
|
||||||
|
|
||||||
|
#define PG_L2_DATA_PADDR (PG_L2_BASE_PADDR + 4*PG_TEXT_NPAGES)
|
||||||
#endif /* CONFIG_PAGING */
|
#endif /* CONFIG_PAGING */
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -100,20 +104,22 @@
|
|||||||
* written. This macro is used when CONFIG_PAGING is enable. This case,
|
* written. This macro is used when CONFIG_PAGING is enable. This case,
|
||||||
* it is used asfollows:
|
* it is used asfollows:
|
||||||
*
|
*
|
||||||
* ldr r0, =PG_LOCKED_PBASE
|
* ldr r0, =PG_L2_BASE_PADDR
|
||||||
* ldr r1, =CONFIG_PAGING_NLOCKED
|
* ldr r1, =PG_LOCKED_PBASE
|
||||||
* ldr r2, =MMUFLAGS
|
* ldr r2, =CONFIG_PAGING_NLOCKED
|
||||||
|
* ldr r3, =MMUFLAGS
|
||||||
* pg_map r0, r1, r2, r3, r4
|
* pg_map r0, r1, r2, r3, r4
|
||||||
*
|
*
|
||||||
* Inputs:
|
* Inputs:
|
||||||
|
* l2 - Physical start address in the L2 page table (modified)
|
||||||
* paddr - The physical address of the start of the region to span. Must
|
* paddr - The physical address of the start of the region to span. Must
|
||||||
* be aligned to 1Mb section boundaries (modified)
|
* be aligned to 1Mb section boundaries (modified)
|
||||||
* npages - Number of pages to write in the section (modified)
|
* npages - Number of pages to write in the section (modified)
|
||||||
* mmuflags - L2 MMU FLAGS
|
* mmuflags - L2 MMU FLAGS
|
||||||
*
|
*
|
||||||
* Scratch registers (modified): tmp1, tmp2
|
* Scratch registers (modified): tmp
|
||||||
* tmp1 - Physical address in the L2 page table.
|
* l2 - Physical address in the L2 page table.
|
||||||
* tmp2 - scratch
|
* tmp - scratch
|
||||||
*
|
*
|
||||||
* Assumptions:
|
* Assumptions:
|
||||||
* - The MMU is not yet enabled
|
* - The MMU is not yet enabled
|
||||||
@ -123,31 +129,25 @@
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_PAGING
|
#ifdef CONFIG_PAGING
|
||||||
.macro pg_map, paddr, npages, mmuflags, tmp1, tmp2
|
.macro pg_map, paddr, npages, mmuflags, l2, tmp
|
||||||
|
|
||||||
/* tmp1 = Physical address of the start of the L2 page table
|
|
||||||
* tmp2 = MMU flags
|
|
||||||
*/
|
|
||||||
|
|
||||||
ldr \tmp1, =PG_L2_BASE_PADDR
|
|
||||||
b 2f
|
b 2f
|
||||||
1:
|
1:
|
||||||
/* Write the one L2 entries. First, get tmp2 = (paddr | mmuflags),
|
/* Write the one L2 entries. First, get tmp = (paddr | mmuflags),
|
||||||
* the value to write into the L2 PTE
|
* the value to write into the L2 PTE
|
||||||
*/
|
*/
|
||||||
|
|
||||||
orr \tmp2, \paddr, \mmuflags
|
orr \tmp, \paddr, \mmuflags
|
||||||
|
|
||||||
/* Write value into table at the current table address */
|
/* Write value into table at the current table address */
|
||||||
|
|
||||||
str \tmp2, [\tmp1], #4
|
str \tmp, [\l2], #4
|
||||||
|
|
||||||
/* Update the physical addresses that will correspond to the next
|
/* Update the physical addresses that will correspond to the next
|
||||||
* table entry.
|
* table entry.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
add \paddr, \paddr, #CONFIG_PAGING_PAGESIZE
|
add \paddr, \paddr, #CONFIG_PAGING_PAGESIZE
|
||||||
add \tmp1, \tmp1, #4
|
add \l2, \l2, #4
|
||||||
|
|
||||||
/* Decrement the number of pages written */
|
/* Decrement the number of pages written */
|
||||||
|
|
||||||
@ -169,23 +169,25 @@
|
|||||||
* macro is used when CONFIG_PAGING is enable. This case, it is used as
|
* macro is used when CONFIG_PAGING is enable. This case, it is used as
|
||||||
* follows:
|
* follows:
|
||||||
*
|
*
|
||||||
* ldr r0, =PG_LOCKED_PBASE
|
* ldr r0, =PG_L2_BASE_PADDR
|
||||||
* ldr r1, =(CONFIG_PAGING_NLOCKED+CONFIG_PAGING_NPAGES)
|
* ldr r1, =PG_LOCKED_PBASE
|
||||||
* ldr r2, =MMU_FLAGS
|
* ldr r2, =(CONFIG_PAGING_NLOCKED+CONFIG_PAGING_NPAGES)
|
||||||
|
* ldr r3, =MMU_FLAGS
|
||||||
* pg_span r0, r1, r2, r3, r4
|
* pg_span r0, r1, r2, r3, r4
|
||||||
*
|
*
|
||||||
* Inputs (unmodified unless noted):
|
* Inputs (unmodified unless noted):
|
||||||
|
* l2 - Physical start address in the L2 page table (modified)
|
||||||
* addr - The virtual address of the start of the region to span. Must
|
* addr - The virtual address of the start of the region to span. Must
|
||||||
* be aligned to 1Mb section boundaries (modified)
|
* be aligned to 1Mb section boundaries (modified)
|
||||||
* npages - Number of pages to required to span that memory region (modified)
|
* npages - Number of pages to required to span that memory region (modified)
|
||||||
* mmuflags - L1 MMU flags to use
|
* mmuflags - L1 MMU flags to use
|
||||||
*
|
*
|
||||||
* Scratch registers (modified):
|
* Scratch registers (modified):
|
||||||
* addr, npages, tmp1, tmp2
|
* addr, npages, tmp
|
||||||
* addr - Physical address in the L1 page table.
|
* l2 - L2 page table physical address
|
||||||
|
* addr - Physical address in the L1 page table.
|
||||||
* npages - The number of pages remaining to be accounted for
|
* npages - The number of pages remaining to be accounted for
|
||||||
* tmp1 - L2 page table physical address
|
* tmp - scratch
|
||||||
* tmp2 - scratch
|
|
||||||
*
|
*
|
||||||
* Return:
|
* Return:
|
||||||
* Nothing of interest.
|
* Nothing of interest.
|
||||||
@ -197,36 +199,32 @@
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_PAGING
|
#ifdef CONFIG_PAGING
|
||||||
.macro pg_span, addr, npages, mmuflags, tmp1, tmp2
|
.macro pg_span, l2, addr, npages, mmuflags, tmp
|
||||||
|
|
||||||
/* tmp1 = Physical address of the start of the L2 page table */
|
|
||||||
|
|
||||||
ldr \tmp1, =PG_L2_BASE_PADDR
|
|
||||||
|
|
||||||
/* Get addr = the L1 page table address coresponding to the virtual
|
/* Get addr = the L1 page table address coresponding to the virtual
|
||||||
* address of the start of memory region to be mapped.
|
* address of the start of memory region to be mapped.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ldr \tmp2, =PGTABLE_BASE_PADDR
|
ldr \tmp, =PGTABLE_BASE_PADDR
|
||||||
lsr \addr, \addr, #20
|
lsr \addr, \addr, #20
|
||||||
add \addr, \tmp2, \addr, lsl #2
|
add \addr, \tmp, \addr, lsl #2
|
||||||
b 2f
|
b 2f
|
||||||
1:
|
1:
|
||||||
/* Write the L1 table entry that refers to this (unmapped) coarse page
|
/* Write the L1 table entry that refers to this (unmapped) coarse page
|
||||||
* table.
|
* table.
|
||||||
*
|
*
|
||||||
* tmp2 = (paddr | mmuflags), the value to write into the page table
|
* tmp = (paddr | mmuflags), the value to write into the page table
|
||||||
*/
|
*/
|
||||||
|
|
||||||
orr \tmp2, \tmp1, \mmuflags
|
orr \tmp, \l2, \mmuflags
|
||||||
|
|
||||||
/* Write the value into the L1 table at the correct offset. */
|
/* Write the value into the L1 table at the correct offset. */
|
||||||
|
|
||||||
str \tmp2, [\addr], #4
|
str \tmp, [\addr], #4
|
||||||
|
|
||||||
/* Update the L2 page table address for the next L1 table entry. */
|
/* Update the L2 page table address for the next L1 table entry. */
|
||||||
|
|
||||||
add \tmp1, \tmp1, #PT_SIZE /* Next L2 page table start paddr */
|
add \l2, \l2, #PT_SIZE /* Next L2 page table start paddr */
|
||||||
|
|
||||||
/* Update the number of pages that we have account for (with
|
/* Update the number of pages that we have account for (with
|
||||||
* non-mappings
|
* non-mappings
|
||||||
|
@ -182,16 +182,14 @@ __start:
|
|||||||
#ifdef CONFIG_PAGING
|
#ifdef CONFIG_PAGING
|
||||||
/* Populate the L1 table for the locked and paged text regions */
|
/* Populate the L1 table for the locked and paged text regions */
|
||||||
|
|
||||||
ldr r0, =PG_LOCKED_PBASE
|
adr r0, .Ltxtspan
|
||||||
ldr r1, =PG_TEXT_NPAGES
|
ldmia r0, {r0, r1, r2, r3}
|
||||||
ldr r2, =MMU_L1_TEXTFLAGS
|
|
||||||
pg_span r0, r1, r2, r3, r4
|
pg_span r0, r1, r2, r3, r4
|
||||||
|
|
||||||
/* Populate the L2 table for the locked text region only */
|
/* Populate the L2 table for the locked text region only */
|
||||||
|
|
||||||
ldr r0, =PG_LOCKED_PBASE
|
adr r0, .Ltxtmap
|
||||||
ldr r1, =CONFIG_PAGING_NLOCKED
|
ldmia r0, {r0, r1, r2, r3}
|
||||||
ldr r2, =MMU_L2_TEXTFLAGS
|
|
||||||
pg_map r0, r1, r2, r3, r4
|
pg_map r0, r1, r2, r3, r4
|
||||||
#else
|
#else
|
||||||
/* Create a virtual single section mapping for the first MB of the .text
|
/* Create a virtual single section mapping for the first MB of the .text
|
||||||
@ -355,20 +353,18 @@ __start:
|
|||||||
#if defined(CONFIG_PAGING)
|
#if defined(CONFIG_PAGING)
|
||||||
/* Populate the L1 table for the data regions */
|
/* Populate the L1 table for the data regions */
|
||||||
|
|
||||||
ldr r0, =PG_PAGED_PBASE
|
adr r0, .Ldatamap
|
||||||
ldr r1, =PG_DATA_NPAGED
|
ldmia r0, {r0, r1, r2, r3}
|
||||||
ldr r2, =MMU_L1_DATAFLAGS
|
|
||||||
pg_span r0, r1, r2, r3, r4
|
pg_span r0, r1, r2, r3, r4
|
||||||
|
|
||||||
/* Populate the L2 table for the data region */
|
/* Populate the L2 table for the data region */
|
||||||
|
|
||||||
ldr r0, =PG_PAGED_PBASE
|
adr r0, .Ldatamap
|
||||||
ldr r1, =PG_DATA_NPAGED
|
ldmia r0, {r0, r1, r2, r3, r4}
|
||||||
ldr r2, =MMU_L2_DATAFLAGS
|
pg_map r0, r1, r2, r4, r3
|
||||||
pg_map r0, r1, r2, r3, r4
|
|
||||||
|
|
||||||
#elif defined(CONFIG_BOOT_RUNFROMFLASH)
|
#elif defined(CONFIG_BOOT_RUNFROMFLASH)
|
||||||
# error "Logic not implemented"
|
# error "Logic not implemented"
|
||||||
#else
|
#else
|
||||||
/* Now setup the pagetables for our normal SDRAM mappings mapped region.
|
/* Now setup the pagetables for our normal SDRAM mappings mapped region.
|
||||||
* We round NUTTX_START_VADDR down to the nearest megabyte boundary.
|
* We round NUTTX_START_VADDR down to the nearest megabyte boundary.
|
||||||
@ -440,7 +436,7 @@ __start:
|
|||||||
mov lr, #0
|
mov lr, #0
|
||||||
b os_start
|
b os_start
|
||||||
|
|
||||||
/* Variables:
|
/* Text-section constants:
|
||||||
*
|
*
|
||||||
* _sbss is the start of the BSS region (see ld.script)
|
* _sbss is the start of the BSS region (see ld.script)
|
||||||
* _ebss is the end of the BSS regsion (see ld.script)
|
* _ebss is the end of the BSS regsion (see ld.script)
|
||||||
@ -454,8 +450,31 @@ __start:
|
|||||||
.long _sbss
|
.long _sbss
|
||||||
.long _ebss
|
.long _ebss
|
||||||
.long _ebss+CONFIG_IDLETHREAD_STACKSIZE-4
|
.long _ebss+CONFIG_IDLETHREAD_STACKSIZE-4
|
||||||
|
|
||||||
|
#ifdef CONFIG_PAGING
|
||||||
|
.Ltxtspan:
|
||||||
|
.long PG_L2_BASE_PADDR
|
||||||
|
.long PG_LOCKED_PBASE
|
||||||
|
.long PG_TEXT_NPAGES
|
||||||
|
.long MMU_L1_TEXTFLAGS
|
||||||
|
|
||||||
|
.Ltxtmap:
|
||||||
|
.long PG_L2_BASE_PADDR
|
||||||
|
.long PG_LOCKED_PBASE
|
||||||
|
.long CONFIG_PAGING_NLOCKED
|
||||||
|
.long MMU_L2_TEXTFLAGS
|
||||||
|
|
||||||
|
.Ldatamap:
|
||||||
|
.long PG_L2_DATA_PADDR
|
||||||
|
.long PG_DATA_PBASE
|
||||||
|
.long PG_DATA_NPAGED
|
||||||
|
.long MMU_L1_DATAFLAGS
|
||||||
|
.long MMU_L2_DATAFLAGS
|
||||||
|
#endif
|
||||||
.size .Lvstart, .-.Lvstart
|
.size .Lvstart, .-.Lvstart
|
||||||
|
|
||||||
|
/* Data section variables */
|
||||||
|
|
||||||
/* This global variable is unsigned long g_heapbase and is
|
/* This global variable is unsigned long g_heapbase and is
|
||||||
* exported from here only because of its coupling to .Linitparms
|
* exported from here only because of its coupling to .Linitparms
|
||||||
* above.
|
* above.
|
||||||
|
@ -117,11 +117,15 @@
|
|||||||
#define PG_PAGED_PEND (PG_PAGED_PBASE + PG_PAGED_SIZE)
|
#define PG_PAGED_PEND (PG_PAGED_PBASE + PG_PAGED_SIZE)
|
||||||
#define PG_PAGED_VEND (PG_PAGED_VBASE + PG_PAGED_SIZE)
|
#define PG_PAGED_VEND (PG_PAGED_VBASE + PG_PAGED_SIZE)
|
||||||
|
|
||||||
|
/* Size of the overall text section */
|
||||||
|
|
||||||
|
#define PG_TEXT_NPAGES (CONFIG_PAGING_NLOCKED + CONFIG_PAGING_NPAGED)
|
||||||
|
#define PG_TEXT_SIZE (PG_TEXT_NPAGES << PAGESHIFT)
|
||||||
|
|
||||||
/* CONFIG_PAGING_NDATA - This is the number of data pages in the memory
|
/* CONFIG_PAGING_NDATA - This is the number of data pages in the memory
|
||||||
* map. The size of data address region will then be:
|
* map. The size of data address region will then be:
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define PG_TEXT_NPAGES (CONFIG_PAGING_NLOCKED + CONFIG_PAGING_NPAGED)
|
|
||||||
#define PG_RAM_PAGES (CONFIG_DRAM_SIZE >> PAGESHIFT)
|
#define PG_RAM_PAGES (CONFIG_DRAM_SIZE >> PAGESHIFT)
|
||||||
#if PG_RAM_PAGES <= PG_TEXT_NPAGES
|
#if PG_RAM_PAGES <= PG_TEXT_NPAGES
|
||||||
# error "Not enough memory for this page layout"
|
# error "Not enough memory for this page layout"
|
||||||
|
Loading…
Reference in New Issue
Block a user