2014-05-20 14:22:24 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
|
|
*
|
2014-07-31 19:45:27 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2014-05-20 14:22:24 +02:00
|
|
|
*/
|
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
/* ***************************************************************************************************************
|
|
|
|
|
2014-08-02 12:21:55 +02:00
|
|
|
startup.s STARTUP ASSEMBLY CODE
|
|
|
|
-----------------------
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
|
2014-08-02 12:21:55 +02:00
|
|
|
Module includes the interrupt vectors and start-up code.
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
*************************************************************************************************************** */
|
|
|
|
|
|
|
|
.extern __start_start
|
|
|
|
.extern __stack_end
|
|
|
|
.extern __fiq_handler
|
|
|
|
|
|
|
|
/* Stack Positions */
|
|
|
|
.extern __stack_usr_start
|
|
|
|
.extern __stack_abt_start
|
|
|
|
.extern __stack_und_start
|
|
|
|
.extern __stack_fiq_start
|
|
|
|
.extern __start_irq_start
|
|
|
|
.extern __start_svc_start
|
|
|
|
|
|
|
|
/* Standard definitions of Mode bits and Interrupt (I & F) flags in PSRs (program status registers) */
|
2014-08-02 12:21:55 +02:00
|
|
|
.set MODE_USR, 0x10 /* Normal User Mode */
|
|
|
|
.set MODE_FIQ, 0x11 /* FIQ Processing Fast Interrupts Mode */
|
|
|
|
.set MODE_IRQ, 0x12 /* IRQ Processing Standard Interrupts Mode */
|
|
|
|
.set MODE_SVC, 0x13 /* Supervisor Processing Software Interrupts Mode */
|
|
|
|
.set MODE_ABT, 0x17 /* Abort Processing memory Faults Mode */
|
|
|
|
.set MODE_UND, 0x1B /* Undefined Processing Undefined Instructions Mode */
|
|
|
|
.set MODE_SYS, 0x1F /* System Running Priviledged Operating System Tasks Mode */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-08-02 12:21:55 +02:00
|
|
|
.set I_BIT, 0x80 /* when I bit is set, IRQ is disabled (program status registers) */
|
|
|
|
.set F_BIT, 0x40 /* when F bit is set, FIQ is disabled (program status registers) */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
.text
|
|
|
|
.arm
|
|
|
|
|
|
|
|
/* Exception vectors and handler addresses.
|
|
|
|
It is 64 bytes and can be mapped (see documentation 1.4.2). */
|
|
|
|
.section .vectors
|
|
|
|
/* Exception Vectors */
|
2019-07-25 22:41:08 +02:00
|
|
|
ldr PC, reset_addr /* Reset */
|
|
|
|
ldr PC, undef_addr /* Undefined Instruction */
|
|
|
|
ldr PC, swi_addr /* Software Interrupt */
|
|
|
|
ldr PC, pabt_addr /* Prefetch Abort */
|
|
|
|
ldr PC, dabt_addr /* Data Abort */
|
2014-08-02 12:21:55 +02:00
|
|
|
nop /* Reserved Vector (holds Philips ISP checksum) */
|
2010-09-22 15:10:42 +02:00
|
|
|
/* see page 71 of "Insiders Guide to the Philips ARM7-Based Microcontrollers" by Trevor Martin */
|
2014-08-02 12:21:55 +02:00
|
|
|
/* ldr PC, [PC,#-0x0120] /* Interrupt Request Interrupt (load from VIC) */
|
2019-07-25 22:41:08 +02:00
|
|
|
ldr PC, irq_addr /* Interrupt Request Interrupt (load from VIC) */
|
2014-08-02 12:21:55 +02:00
|
|
|
ldr r0, =__fiq_handler /* Fast Interrupt Request Interrupt */
|
|
|
|
ldr pc, [r0] /* jump to handler in pointer at __fiq_handler */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/* Exception vector handlers branching table */
|
2019-07-25 22:41:08 +02:00
|
|
|
reset_addr: .word reset_handler /* defined in this module below */
|
|
|
|
undef_addr: .word isr_undef /* defined in arm7_common/vectors.c */
|
|
|
|
swi_addr: .word ctx_switch /* defined in arm7_common/common.s */
|
|
|
|
pabt_addr: .word isr_pabt /* defined in arm7_common/vectors.c */
|
|
|
|
dabt_addr: .word isr_dabt /* defined in arm7_common/vectors.c */
|
|
|
|
irq_addr: .word arm_irq_handler /* defined in arm7_common/common.s */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/* Begin of boot code */
|
|
|
|
.text
|
|
|
|
.arm
|
|
|
|
.section .init
|
|
|
|
|
|
|
|
.global _startup
|
|
|
|
.func _startup
|
|
|
|
|
|
|
|
_startup:
|
2019-07-25 22:41:08 +02:00
|
|
|
ldr pc, =reset_handler
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2019-07-25 22:41:08 +02:00
|
|
|
/*.func reset_handler */
|
|
|
|
reset_handler:
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
.section .init0
|
2014-08-02 12:21:55 +02:00
|
|
|
/* Setup a stack for each mode - note that this only sets up a usable stack
|
|
|
|
for User mode. Also each mode is setup with interrupts initially disabled. */
|
|
|
|
ldr r0, = __stack_end
|
|
|
|
msr CPSR_c, #MODE_UND|I_BIT|F_BIT /* Undefined Instruction Mode */
|
|
|
|
ldr sp, =__stack_und_start
|
|
|
|
msr CPSR_c, #MODE_ABT|I_BIT|F_BIT /* Abort Mode */
|
|
|
|
ldr sp, =__stack_abt_start
|
|
|
|
msr CPSR_c, #MODE_FIQ|I_BIT|F_BIT /* FIQ Mode */
|
|
|
|
ldr sp, =__stack_fiq_start
|
|
|
|
msr CPSR_c, #MODE_IRQ|I_BIT|F_BIT /* IRQ Mode */
|
|
|
|
ldr sp, =__stack_irq_start
|
|
|
|
msr CPSR_c, #MODE_SVC|I_BIT|F_BIT /* Supervisor Mode */
|
|
|
|
ldr sp, =__stack_svc_start
|
|
|
|
msr CPSR_c, #MODE_SYS|I_BIT|F_BIT /* User Mode */
|
|
|
|
ldr sp, =__stack_usr_start
|
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
bl bootloader
|
|
|
|
b kernel_init
|
|
|
|
|
|
|
|
/* Infinite Loop */
|
|
|
|
.section .fini0
|
2014-08-02 12:21:55 +02:00
|
|
|
__main_exit: B __main_exit
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
|
|
|
|
.endfunc
|
|
|
|
.end
|