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:
patacongo 2010-08-22 16:46:42 +00:00
parent 019ddd2b3b
commit e7f7ca17a4
3 changed files with 32 additions and 15 deletions

View File

@ -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

View File

@ -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

View File

@ -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)