2013-05-13 23:39:51 +02:00
|
|
|
/* Copyright (c) 2012-2013 Red Hat, Inc. All rights reserved.
|
|
|
|
|
|
|
|
This copyrighted material is made available to anyone wishing to use, modify,
|
|
|
|
copy, or redistribute it subject to the terms and conditions of the BSD
|
|
|
|
License. This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY expressed or implied, including the implied warranties
|
|
|
|
of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. A copy of this license
|
|
|
|
is available at http://www.opensource.org/licenses. Any Red Hat trademarks that
|
|
|
|
are incorporated in the source code or documentation are not subject to the BSD
|
|
|
|
License and may only be used or replicated with the express permission of
|
|
|
|
Red Hat, Inc.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "memmodel.h"
|
|
|
|
|
2014-01-30 03:46:34 +01:00
|
|
|
;; The linker links all .crt_* sections in asciibetical order at the
|
|
|
|
;; same place. So, the four digits in .crt_NNNN determine the link
|
|
|
|
;; order, so, keep them in sequential order here. The first two
|
|
|
|
;; digits are set here, the second two allow users to insert code
|
|
|
|
;; between code fragments here.
|
|
|
|
|
|
|
|
#if L0
|
2013-05-13 23:39:51 +02:00
|
|
|
.section ".resetvec", "a"
|
|
|
|
__msp430_resetvec_hook:
|
|
|
|
.word __start
|
|
|
|
|
2014-01-30 03:46:34 +01:00
|
|
|
.section ".crt_0000init", "ax", @progbits
|
|
|
|
.refsym __msp430_resetvec_hook
|
|
|
|
#ifdef MINRT
|
|
|
|
.refsym __crt0_call_just_main
|
|
|
|
#else
|
|
|
|
.refsym __crt0_call_init_then_main
|
|
|
|
#endif
|
2013-05-13 23:39:51 +02:00
|
|
|
.global __start
|
|
|
|
__start:
|
|
|
|
mov_ #__stack, R1
|
|
|
|
|
|
|
|
;; Disable watchdog timer.
|
|
|
|
MOV #0x5a80, &0x15C
|
2014-01-30 03:46:34 +01:00
|
|
|
#endif
|
2013-05-13 23:39:51 +02:00
|
|
|
|
2014-01-30 03:46:34 +01:00
|
|
|
#if Lbss
|
|
|
|
.section ".crt_0100bss", "ax", @progbits
|
|
|
|
|
|
|
|
.global __crt0_init_bss
|
|
|
|
__crt0_init_bss:
|
|
|
|
|
2013-05-13 23:39:51 +02:00
|
|
|
mov_ #__bssstart, R12
|
|
|
|
clr.w R13
|
|
|
|
mov.w #__bsssize, R14
|
|
|
|
#ifdef __MSP430X_LARGE__
|
|
|
|
clr.w R15 ; We assume that __bsssize is never > 64M
|
|
|
|
#endif
|
|
|
|
call_ #memset
|
2014-01-30 03:46:34 +01:00
|
|
|
#endif
|
2013-05-13 23:39:51 +02:00
|
|
|
|
2014-11-13 11:18:57 +01:00
|
|
|
#ifdef __MSP430X_LARGE__
|
|
|
|
#if Lhigh_bss
|
|
|
|
;; Note - this section is only included in the
|
|
|
|
;; startup code of the application if it is needed.
|
|
|
|
|
|
|
|
.section ".crt_0150high_bss", "ax", @progbits
|
|
|
|
|
|
|
|
.global __crt0_init_high_bss
|
|
|
|
__crt0_init_high_bss:
|
|
|
|
|
|
|
|
mov_ #llo(__high_bssstart), R12
|
|
|
|
mov_ #lhi(__high_bssstart), R13
|
|
|
|
mov.w #llo(__high_bsssize), R14
|
|
|
|
mov.w #lhi(__high_bsssize), R15
|
|
|
|
call_ #memset
|
|
|
|
#endif /* Lhigh_bss */
|
|
|
|
#endif /* __MSP430X_LARGE__ */
|
|
|
|
|
2014-01-30 03:46:34 +01:00
|
|
|
#if Lmovedata
|
|
|
|
.section ".crt_0200movedata", "ax", @progbits
|
|
|
|
|
|
|
|
.global __crt0_movedata
|
|
|
|
__crt0_movedata:
|
|
|
|
|
2013-05-13 23:39:51 +02:00
|
|
|
mov_ #__datastart, R12
|
|
|
|
mov_ #__romdatastart, R13
|
|
|
|
|
|
|
|
;; memmove and memcpy do not currently work when src == dst
|
|
|
|
cmp_ R12, R13
|
|
|
|
jeq 1f
|
|
|
|
|
|
|
|
mov.w #__romdatacopysize, R14
|
|
|
|
#ifdef __MSP430X_LARGE__
|
|
|
|
clr.w R15 ; We assume that __romdatacopysize is never > 64M
|
|
|
|
#endif
|
|
|
|
call_ #memmove
|
|
|
|
1:
|
2014-01-30 03:46:34 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if Lmain_minrt
|
|
|
|
.section ".crt_0300main", "ax", @progbits
|
|
|
|
.global __crt0_call_just_main
|
|
|
|
__crt0_call_just_main:
|
|
|
|
clr.w R12 ; Set argc == 0
|
|
|
|
call_ #main
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if Lmain
|
|
|
|
.section ".crt_0300main", "ax", @progbits
|
|
|
|
.global __crt0_call_init_then_main
|
|
|
|
__crt0_call_init_then_main:
|
2013-05-13 23:39:51 +02:00
|
|
|
call_ #__msp430_init
|
|
|
|
|
|
|
|
clr.w R12 ; Set argc == 0
|
|
|
|
call_ #main
|
2014-01-30 03:46:34 +01:00
|
|
|
#endif
|
2013-05-13 23:39:51 +02:00
|
|
|
|
2014-01-30 03:46:34 +01:00
|
|
|
#if Lcallexit
|
|
|
|
.section ".crt_0400main_exit", "ax", @progbits
|
|
|
|
.global __crt0_call_exit
|
|
|
|
__crt0_call_exit:
|
2013-05-13 23:39:51 +02:00
|
|
|
call_ #_exit
|
2014-01-30 03:46:34 +01:00
|
|
|
#endif
|
2013-05-13 23:39:51 +02:00
|
|
|
|
|
|
|
;----------------------------------------
|
|
|
|
|
2014-01-30 03:46:34 +01:00
|
|
|
#ifndef MINRT
|
|
|
|
#if L0
|
|
|
|
.section ".crt_0500main_init", "ax", @progbits
|
2013-05-13 23:39:51 +02:00
|
|
|
.global _msp430_run_init_array
|
|
|
|
.type _msp430_run_init_array,@function
|
|
|
|
_msp430_run_init_array:
|
|
|
|
mov_ #__init_array_start, R4
|
|
|
|
mov_ #__init_array_end, R5
|
|
|
|
mov_ #PTRsz, R6
|
|
|
|
br_ #_msp430_run_array
|
|
|
|
|
|
|
|
.global _msp430_run_preinit_array
|
|
|
|
.type _msp430_run_preinit_array,@function
|
|
|
|
_msp430_run_preinit_array:
|
|
|
|
mov_ #__preinit_array_start, R4
|
|
|
|
mov_ #__preinit_array_end, R5
|
|
|
|
mov_ #PTRsz, R6
|
|
|
|
br_ #_msp430_run_array
|
|
|
|
|
|
|
|
.global _msp430_run_fini_array
|
|
|
|
.type _msp430_run_fini_array,@function
|
|
|
|
_msp430_run_fini_array:
|
|
|
|
mov_ #__fini_array_start, R4
|
|
|
|
mov_ #__fini_array_end, R5
|
|
|
|
mov_ #-PTRsz, R6
|
|
|
|
br_ #_msp430_run_array
|
|
|
|
|
|
|
|
_msp430_run_array:
|
|
|
|
cmp_ R4, R5
|
|
|
|
jeq _msp430_run_done
|
|
|
|
mov_ @R4, R7
|
|
|
|
add_ R6, R4
|
|
|
|
call_ @R7
|
|
|
|
br_ _msp430_run_array
|
|
|
|
|
|
|
|
_msp430_run_done:
|
|
|
|
ret_
|
|
|
|
|
|
|
|
;----------------------------------------
|
|
|
|
|
|
|
|
.section .init,"ax"
|
|
|
|
|
|
|
|
.global __msp430_init
|
|
|
|
__msp430_init:
|
|
|
|
|
|
|
|
.section .fini,"ax"
|
|
|
|
|
|
|
|
.global __msp430_fini
|
|
|
|
__msp430_fini:
|
|
|
|
call_ #_msp430_run_fini_array
|
2014-01-30 03:46:34 +01:00
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif
|