|
|
|
@ -55,7 +55,11 @@ |
|
|
|
|
*/ |
|
|
|
|
_vectors: |
|
|
|
|
|
|
|
|
|
#ifndef CONFIG_M5271 |
|
|
|
|
.long 0x00000000, _START |
|
|
|
|
#else |
|
|
|
|
.long 0x00000000, 0x400 /* Flash offset is 0 until we setup CS0 */ |
|
|
|
|
#endif |
|
|
|
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
|
|
|
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
|
|
|
|
.long _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT, _FAULT |
|
|
|
@ -124,26 +128,42 @@ _start: |
|
|
|
|
movec %d0, %RAMBAR0 |
|
|
|
|
#endif /* #if defined(CONFIG_M5272) || defined(CONFIG_M5249) */ |
|
|
|
|
|
|
|
|
|
#ifdef CONFIG_M5282 |
|
|
|
|
#if defined(CONFIG_M5282) || defined(CONFIG_M5271) |
|
|
|
|
/* Initialize IPSBAR */ |
|
|
|
|
move.l #(CFG_MBAR + 1), %d0 /* set IPSBAR address + valid flag */ |
|
|
|
|
move.l %d0, 0x40000000 |
|
|
|
|
|
|
|
|
|
#ifdef CONFIG_M5282 |
|
|
|
|
/* Initialize FLASHBAR: locate internal Flash and validate it */ |
|
|
|
|
move.l #(CFG_INT_FLASH_BASE + 0x21), %d0 |
|
|
|
|
movec %d0, %RAMBAR0 |
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
/* Initialize RAMBAR1: locate SRAM and validate it */ |
|
|
|
|
move.l #(CFG_INIT_RAM_ADDR + 0x21), %d0 |
|
|
|
|
movec %d0, %RAMBAR1 |
|
|
|
|
#ifdef CONFIG_M5271 |
|
|
|
|
move.l #(_flash_setup-CFG_FLASH_BASE), %a0 |
|
|
|
|
move.l #(_flash_setup_end-CFG_FLASH_BASE), %a1 |
|
|
|
|
move.l #(CFG_INIT_RAM_ADDR), %a2 |
|
|
|
|
_copy_flash: |
|
|
|
|
move.l (%a0)+, (%a2)+ |
|
|
|
|
cmp.l %a0, %a1 |
|
|
|
|
bgt.s _copy_flash |
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
jmp CFG_INIT_RAM_ADDR |
|
|
|
|
_after_flash_copy: |
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
#if 0 |
|
|
|
|
/* invalidate and disable cache */ |
|
|
|
|
move.l #0x01000000, %d0 /* Invalidate cache cmd */ |
|
|
|
|
movec %d0, %CACR /* Invalidate cache */ |
|
|
|
|
move.l #0, %d0 |
|
|
|
|
movec %d0, %ACR0 |
|
|
|
|
movec %d0, %ACR1 |
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
/* set stackpointer to end of internal ram to get some stackspace for the first c-code */ |
|
|
|
|
move.l #(CFG_INIT_RAM_ADDR + CFG_INIT_SP_OFFSET), %sp |
|
|
|
@ -158,6 +178,18 @@ _start: |
|
|
|
|
|
|
|
|
|
/*------------------------------------------------------------------------------*/ |
|
|
|
|
|
|
|
|
|
#ifdef CONFIG_M5271 |
|
|
|
|
_flash_setup: |
|
|
|
|
move.l #0x1000, %d0 |
|
|
|
|
move.w %d0, 0x40000080 |
|
|
|
|
move.l #0x2180, %d0 |
|
|
|
|
move.w %d0, 0x4000008A |
|
|
|
|
move.l #0x3f0001, %d0 |
|
|
|
|
move.l %d0, 0x40000084 |
|
|
|
|
jmp _after_flash_copy.L |
|
|
|
|
_flash_setup_end: |
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
/* |
|
|
|
|
* void relocate_code (addr_sp, gd, addr_moni) |
|
|
|
|
* |
|
|
|
|