ae78672c56
o Use a directory layout that is more akin to the i386 boot layout. o Create a libat91 for library routines that are used by one or more of the boot loaders. o Create bootiic for booting from an iic part. o Create bootspi for booting from an spi part. o Optimize the size of many of these routines (especially emac.c). Except for the emac.c optimizations, all these have been tested. o eliminate the inc directory, libat91 superceeds it. o Move linker.cfg up a layer to allow it to be shared.
111 lines
2.9 KiB
ArmAsm
111 lines
2.9 KiB
ArmAsm
/*******************************************************************************
|
|
*
|
|
* Filename: arm_init.s
|
|
*
|
|
* Initialization for C-environment and basic operation. Adapted from
|
|
* ATMEL cstartup.s.
|
|
*
|
|
* Revision information:
|
|
*
|
|
* 20AUG2004 kb_admin initial creation
|
|
* 12JAN2005 kb_admin updated for 16KB eeprom
|
|
* Atmel stack prevents loading full size at once
|
|
*
|
|
* BEGIN_KBDD_BLOCK
|
|
* No warranty, expressed or implied, is included with this software. It is
|
|
* provided "AS IS" and no warranty of any kind including statutory or aspects
|
|
* relating to merchantability or fitness for any purpose is provided. All
|
|
* intellectual property rights of others is maintained with the respective
|
|
* owners. This software is not copyrighted and is intended for reference
|
|
* only.
|
|
* END_BLOCK
|
|
*
|
|
* $FreeBSD$
|
|
******************************************************************************/
|
|
|
|
.equ TWI_EEPROM_SIZE, 0x2000
|
|
.equ ARM_MODE_USER, 0x10
|
|
.equ ARM_MODE_FIQ, 0x11
|
|
.equ ARM_MODE_IRQ, 0x12
|
|
.equ ARM_MODE_SVC, 0x13
|
|
.equ ARM_MODE_ABORT, 0x17
|
|
.equ ARM_MODE_UNDEF, 0x1B
|
|
.equ ARM_MODE_SYS, 0x1F
|
|
|
|
.equ I_BIT, 0x80
|
|
.equ F_BIT, 0x40
|
|
.equ T_BIT, 0x20
|
|
|
|
/*
|
|
* Stack definitions
|
|
*
|
|
* Start near top of internal RAM.
|
|
*/
|
|
|
|
.equ END_INT_SRAM, 0x4000
|
|
.equ SVC_STACK_START, (END_INT_SRAM - 0x4)
|
|
.equ SVC_STACK_USE, 0x21800000
|
|
|
|
start:
|
|
|
|
/* vectors - must reside at address 0 */
|
|
/* the format of this table is defined in the datasheet */
|
|
B InitReset @; reset
|
|
undefvec:
|
|
B undefvec @; Undefined Instruction
|
|
swivec:
|
|
B swivec @; Software Interrupt
|
|
pabtvec:
|
|
B pabtvec @; Prefetch Abort
|
|
dabtvec:
|
|
B dabtvec @; Data Abort
|
|
rsvdvec:
|
|
.long (TWI_EEPROM_SIZE >> 9)
|
|
irqvec:
|
|
ldr pc, [pc,#-0xF20] @; IRQ : read the AIC
|
|
fiqvec:
|
|
B fiqvec @; FIQ
|
|
|
|
|
|
InitReset:
|
|
|
|
/* Set stack and init for SVC */
|
|
ldr r1, = SVC_STACK_START
|
|
mov sp, r1 @; Init stack SYS
|
|
|
|
msr cpsr_c, #(ARM_MODE_SVC | I_BIT | F_BIT)
|
|
mov sp, r1 @ ; Init stack SYS
|
|
|
|
/* Perform system initialization */
|
|
|
|
.extern _init
|
|
|
|
bl _init
|
|
|
|
ldr r1, = SVC_STACK_USE
|
|
mov sp, r1 @ ; Move the stack to SDRAM
|
|
|
|
/* Start execution at main */
|
|
|
|
.extern main
|
|
_main:
|
|
__main:
|
|
bl main
|
|
|
|
/* main should not return. If it does, spin forever */
|
|
|
|
infiniteLoop:
|
|
b infiniteLoop
|
|
|
|
/* the following section is used to store boot commands in */
|
|
/* non-volatile memory. */
|
|
|
|
.global BootCommandSection
|
|
BootCommandSection:
|
|
.string "Bootloader for KB9202 Evaluation Board."
|
|
.string "c 0x20210000 0x10100000 0x80000 "
|
|
.string "m 0 0 0 0 0 0 "
|
|
.string "t 0x20000100 console=ttyS0,115200 root=/dev/ram rw initrd=0x20210000,654933"
|
|
.string "e 0x10000000 "
|
|
.string " "
|