First round of changes made during debug
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@2880 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
019ddd2b3b
commit
e7f7ca17a4
@ -138,14 +138,16 @@
|
|||||||
#define PG_L2_LOCKED_SIZE (4*CONFIG_PAGING_NLOCKED)
|
#define PG_L2_LOCKED_SIZE (4*CONFIG_PAGING_NLOCKED)
|
||||||
|
|
||||||
/* We position the paged region PTEs immediately after the locked
|
/* We position the paged region PTEs immediately after the locked
|
||||||
* region PTEs.
|
* region PTEs. NOTE that the size of the paged regions is much
|
||||||
|
* larger than the size of the physical paged region. That is the
|
||||||
|
* core of what the On-Demanding Paging feature provides.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define PG_L1_PAGED_PADDR (PGTABLE_BASE_PADDR + ((PG_PAGED_VBASE >> 20) << 2))
|
#define PG_L1_PAGED_PADDR (PGTABLE_BASE_PADDR + ((PG_PAGED_VBASE >> 20) << 2))
|
||||||
#define PG_L1_PAGED_VADDR (PGTABLE_BASE_VADDR + ((PG_PAGED_VBASE >> 20) << 2))
|
#define PG_L1_PAGED_VADDR (PGTABLE_BASE_VADDR + ((PG_PAGED_VBASE >> 20) << 2))
|
||||||
#define PG_L2_PAGED_PADDR (PG_L2_BASE_PADDR + PG_L2_LOCKED_SIZE)
|
#define PG_L2_PAGED_PADDR (PG_L2_BASE_PADDR + PG_L2_LOCKED_SIZE)
|
||||||
#define PG_L2_PAGED_VADDR (PG_L2_BASE_VADDR + PG_L2_LOCKED_SIZE)
|
#define PG_L2_PAGED_VADDR (PG_L2_BASE_VADDR + PG_L2_LOCKED_SIZE)
|
||||||
#define PG_L2_PAGED_SIZE (4*CONFIG_PAGING_NPPAGED)
|
#define PG_L2_PAGED_SIZE (4*CONFIG_PAGING_NVPAGED)
|
||||||
|
|
||||||
/* This describes the overall text region */
|
/* This describes the overall text region */
|
||||||
|
|
||||||
@ -346,16 +348,17 @@
|
|||||||
|
|
||||||
orr \tmp, \ppage, \mmuflags
|
orr \tmp, \ppage, \mmuflags
|
||||||
|
|
||||||
/* Write value into table at the current table address */
|
/* Write value into table at the current table address
|
||||||
|
* (and increment the L2 page table address by 4)
|
||||||
|
*/
|
||||||
|
|
||||||
str \tmp, [\l2], #4
|
str \tmp, [\l2], #4
|
||||||
|
|
||||||
/* Update the physical addresses that will correspond to the next
|
/* Update the physical address that will correspond to the next
|
||||||
* table entry.
|
* table entry.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
add \ppage, \ppage, #CONFIG_PAGING_PAGESIZE
|
add \ppage, \ppage, #CONFIG_PAGING_PAGESIZE
|
||||||
add \l2, \l2, #4
|
|
||||||
|
|
||||||
/* Decrement the number of pages written */
|
/* Decrement the number of pages written */
|
||||||
|
|
||||||
@ -417,7 +420,9 @@
|
|||||||
|
|
||||||
orr \tmp, \l2, \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.
|
||||||
|
* (and increment the L1 table address by 4)
|
||||||
|
*/
|
||||||
|
|
||||||
str \tmp, [\l1], #4
|
str \tmp, [\l1], #4
|
||||||
|
|
||||||
|
@ -188,17 +188,20 @@ __start:
|
|||||||
* We could probably make the the pg_l1span and pg_l2map macros into
|
* We could probably make the the pg_l1span and pg_l2map macros into
|
||||||
* call-able subroutines, but we would have to be carefully during
|
* call-able subroutines, but we would have to be carefully during
|
||||||
* this phase while we are operating in a physical address space.
|
* this phase while we are operating in a physical address space.
|
||||||
|
*
|
||||||
|
* NOTE: That the value of r5 (L1 table base address) must be
|
||||||
|
* preserved through the following.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
adr r0, .Ltxtspan
|
adr r0, .Ltxtspan
|
||||||
ldmia r0, {r0, r1, r2, r3}
|
ldmia r0, {r0, r1, r2, r3}
|
||||||
pg_l1span r0, r1, r2, r3, r4
|
pg_l1span r0, r1, r2, r3, r5
|
||||||
|
|
||||||
/* Then populate the L2 table for the locked text region only. */
|
/* Then populate the L2 table for the locked text region only. */
|
||||||
|
|
||||||
adr r0, .Ltxtmap
|
adr r0, .Ltxtmap
|
||||||
ldmia r0, {r0, r1, r2, r3}
|
ldmia r0, {r0, r1, r2, r3}
|
||||||
pg_l2map r0, r1, r2, r3, r4
|
pg_l2map r0, r1, r2, r3, r5
|
||||||
|
|
||||||
/* Make sure that the page table is itself mapped and and read/write-able.
|
/* Make sure that the page table is itself mapped and and read/write-able.
|
||||||
* First, populate the L1 table:
|
* First, populate the L1 table:
|
||||||
@ -206,19 +209,22 @@ __start:
|
|||||||
|
|
||||||
adr r0, .Lptabspan
|
adr r0, .Lptabspan
|
||||||
ldmia r0, {r0, r1, r2, r3}
|
ldmia r0, {r0, r1, r2, r3}
|
||||||
pg_l1span r0, r1, r2, r3, r4
|
pg_l1span r0, r1, r2, r3, r5
|
||||||
|
|
||||||
/* Then populate the L2 table. */
|
/* Then populate the L2 table. */
|
||||||
|
|
||||||
adr r0, .Lptabmap
|
adr r0, .Lptabmap
|
||||||
ldmia r0, {r0, r1, r2, r3}
|
ldmia r0, {r0, r1, r2, r3}
|
||||||
pg_l2map r0, r1, r2, r3, r4
|
pg_l2map r0, r1, r2, r3, r5
|
||||||
|
|
||||||
#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
|
||||||
* address space. Now, we have the first 1MB mapping to both phyical and
|
* address space. Now, we have the first 1MB mapping to both phyical and
|
||||||
* virtual addresses. The rest of the .text mapping will be completed in
|
* virtual addresses. The rest of the .text mapping will be completed in
|
||||||
* .Lvstart once we have moved the physical mapping out of the way.
|
* .Lvstart once we have moved the physical mapping out of the way.
|
||||||
|
*
|
||||||
|
* Here we expect to have:
|
||||||
|
* r4 = Address of the base of the L1 table
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ldr r2, .LCvpgtable /* r2=virt. page table */
|
ldr r2, .LCvpgtable /* r2=virt. page table */
|
||||||
@ -231,7 +237,11 @@ __start:
|
|||||||
#endif
|
#endif
|
||||||
#endif /* CONFIG_ARCH_ROMPGTABLE */
|
#endif /* CONFIG_ARCH_ROMPGTABLE */
|
||||||
|
|
||||||
/* The following logic will set up the ARM920/ARM926 for normal operation */
|
/* The following logic will set up the ARM920/ARM926 for normal operation.
|
||||||
|
*
|
||||||
|
* Here we expect to have:
|
||||||
|
* r4 = Address of the base of the L1 table
|
||||||
|
*/
|
||||||
|
|
||||||
mov r0, #0
|
mov r0, #0
|
||||||
mcr p15, 0, r0, c7, c7 /* Invalidate I,D caches */
|
mcr p15, 0, r0, c7, c7 /* Invalidate I,D caches */
|
||||||
@ -317,8 +327,10 @@ __start:
|
|||||||
/* Get TMP=2 Processor ID register */
|
/* Get TMP=2 Processor ID register */
|
||||||
|
|
||||||
mrc p15, 0, r1, c0, c0, 0 /* read id reg */
|
mrc p15, 0, r1, c0, c0, 0 /* read id reg */
|
||||||
mov r1, r1
|
mov r1,r1 /* Null-avoiding nop */
|
||||||
mov r1, r1
|
mov r1,r1 /* Null-avoiding nop */
|
||||||
|
|
||||||
|
/* And "jump" to .Lvstart */
|
||||||
|
|
||||||
mov pc, lr
|
mov pc, lr
|
||||||
|
|
||||||
|
@ -251,7 +251,7 @@
|
|||||||
# define NUTTX_START_VADDR LPC313X_EXTSDRAM0_VSECTION
|
# define NUTTX_START_VADDR LPC313X_EXTSDRAM0_VSECTION
|
||||||
#elif defined(CONFIG_BOOT_RUNFROMEXTSRAM)
|
#elif defined(CONFIG_BOOT_RUNFROMEXTSRAM)
|
||||||
# define NUTTX_START_VADDR LPC313X_EXTSRAM0_VADDR
|
# define NUTTX_START_VADDR LPC313X_EXTSRAM0_VADDR
|
||||||
#else /* CONFIG_BOOT_RUNFROMISRAM */
|
#else /* CONFIG_BOOT_RUNFROMISRAM, CONFIG_PAGING */
|
||||||
# define NUTTX_START_VADDR LPC313X_INTSRAM0_VADDR
|
# define NUTTX_START_VADDR LPC313X_INTSRAM0_VADDR
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -284,7 +284,7 @@
|
|||||||
* where the vector table was place.
|
* where the vector table was place.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
# ifdef CONFIG_ARCH_ROMPGTABLE /* Vectors located at 0x0000:0000 */
|
# ifdef CONFIG_ARCH_LOWVECTORS /* Vectors located at 0x0000:0000 */
|
||||||
|
|
||||||
/* In this case, ISRAM0 will be shadowed at address 0x0000:0000. The page
|
/* In this case, ISRAM0 will be shadowed at address 0x0000:0000. The page
|
||||||
* table must lie at the top 16Kb of ISRAM1 (or ISRAM0 if this is a LPC3130)
|
* table must lie at the top 16Kb of ISRAM1 (or ISRAM0 if this is a LPC3130)
|
||||||
|
Loading…
Reference in New Issue
Block a user