mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
185 lines
7.0 KiB
ArmAsm
185 lines
7.0 KiB
ArmAsm
/*
|
|
* Copyright (c) 2010, Mariano Alvira <mar@devl.org> and other contributors
|
|
* to the MC1322x project (http:/*mc1322x.devl.org) and Contiki.
|
|
*
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. Neither the name of the Institute nor the names of its contributors
|
|
* may be used to endorse or promote products derived from this software
|
|
* without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*
|
|
* This file is part of the Contiki OS.
|
|
*
|
|
*
|
|
*/
|
|
|
|
|
|
/*
|
|
The following lincence is for all parts of this code done by
|
|
Martin Thomas. Code from others used here may have other license terms.
|
|
|
|
Copyright (C) 2004 Martin THOMAS
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
this software and associated documentation files (the "Software"), to deal in
|
|
the Software without restriction, including without limitation the rights to
|
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
|
the Software, and to permit persons to whom the Software is furnished to do so,
|
|
subject to the following conditions:
|
|
|
|
! The above copyright notice and this permission notice shall be included in all
|
|
! copies or substantial portions of the Software.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
|
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
|
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
|
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
/* Standard definitions of Mode bits and Interrupt (I & F) flags in PSRs (program status registers) */
|
|
.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 */
|
|
|
|
.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) */
|
|
|
|
|
|
.section .startup
|
|
|
|
.set _rom_data_init, 0x108d0
|
|
.global _startup
|
|
.func _startup
|
|
|
|
_startup:
|
|
b _begin /* reset - _start */
|
|
ldr PC, Undef_Addr /* Undefined Instruction */
|
|
ldr PC, SWI_Addr /* Software Interrupt */
|
|
ldr PC, PAbt_Addr /* Prefetch Abort */
|
|
ldr PC, DAbt_Addr /* Data Abort */
|
|
nop /* Reserved Vector (holds Philips ISP checksum) */
|
|
|
|
/* see page 71 of "Insiders Guide to the Philips ARM7-Based Microcontrollers" by Trevor Martin */
|
|
/* ldr PC, [PC,#-0x0120] /* Interrupt Request Interrupt (load from VIC) */
|
|
ldr PC, IRQ_Addr /* Interrupt Request Interrupt (load from VIC) */
|
|
ldr r0, =__fiq_handler /* Fast Interrupt Request Interrupt */
|
|
|
|
/* these vectors are used for rom patching */
|
|
.org 0x20
|
|
.code 16
|
|
_RPTV_0_START:
|
|
bx lr /* do nothing */
|
|
|
|
.org 0x60
|
|
_RPTV_1_START:
|
|
bx lr /* do nothing */
|
|
|
|
.org 0xa0
|
|
_RPTV_2_START:
|
|
bx lr /* do nothing */
|
|
|
|
.org 0xe0
|
|
_RPTV_3_START:
|
|
bx lr /* do nothing */
|
|
|
|
.org 0x120
|
|
ROM_var_start: .word 0
|
|
.org 0x7ff
|
|
ROM_var_end: .word 0
|
|
|
|
.code 32
|
|
.align
|
|
_begin:
|
|
/* FIQ mode stack */
|
|
msr CPSR_c, #(MODE_FIQ | I_BIT | F_BIT)
|
|
ldr sp, =__fiq_stack_top__ /* set the FIQ stack pointer */
|
|
|
|
/* IRQ mode stack */
|
|
msr CPSR_c, #(MODE_IRQ | I_BIT | F_BIT)
|
|
ldr sp, =__irq_stack_top__ /* set the IRQ stack pointer */
|
|
|
|
/* Supervisor mode stack */
|
|
msr CPSR_c, #(MODE_SVC | I_BIT | F_BIT)
|
|
ldr sp, =__svc_stack_top__ /* set the SVC stack pointer */
|
|
|
|
/* Undefined mode stack */
|
|
msr CPSR_c, #(MODE_UND | I_BIT | F_BIT)
|
|
ldr sp, =__und_stack_top__ /* set the UND stack pointer */
|
|
|
|
/* Abort mode stack */
|
|
msr CPSR_c, #(MODE_ABT | I_BIT | F_BIT)
|
|
ldr sp, =__abt_stack_top__ /* set the ABT stack pointer */
|
|
|
|
/* System mode stack */
|
|
msr CPSR_c, #(MODE_SYS | I_BIT | F_BIT)
|
|
ldr sp, =__sys_stack_top__ /* set the SYS stack pointer */
|
|
|
|
/* call the rom_data_init function in ROM */
|
|
/* initializes ROM_var space defined by ROM_var_start and ROM_var_end */
|
|
/* this area is used by ROM functions (e.g. nvm_read) */
|
|
ldr r12,=_rom_data_init
|
|
mov lr,pc
|
|
bx r12
|
|
|
|
msr CPSR_c, #(MODE_SYS)
|
|
|
|
/* Clear BSS */
|
|
clear_bss:
|
|
ldr r0, _bss_start /* find start of bss segment */
|
|
ldr r1, _bss_end /* stop here */
|
|
mov r2, #0x00000000 /* clear */
|
|
clbss_l:
|
|
str r2, [r0] /* clear loop... */
|
|
add r0, r0, #4
|
|
cmp r0, r1
|
|
blt clbss_l
|
|
|
|
b main
|
|
|
|
/* Exception vector handlers branching table */
|
|
Undef_Addr: .word UNDEF_Routine /* defined in main.c */
|
|
SWI_Addr: .word ctx_switch /* defined in main.c */
|
|
PAbt_Addr: .word PABT_Routine /* defined in main.c */
|
|
DAbt_Addr: .word DABT_Routine /* defined in main.c */
|
|
IRQ_Addr: .word arm_irq_handler /* defined in main.c */
|
|
__fiq_handler: .word __fiq /* FIQ */
|
|
|
|
__fiq: b . /* FIQ */
|
|
|
|
/*
|
|
* These are defined in the board-specific linker script.
|
|
*/
|
|
.globl _bss_start
|
|
_bss_start:
|
|
.word __bss_start
|
|
|
|
.globl _bss_end
|
|
_bss_end:
|
|
.word _end
|