mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-12-21 04:42:53 +08:00
e25de718de
ld * config/tc-msp430.c (msp430_make_init_symbols): Define __crt0_init_bss symbol when .lower.bss or .either.bss sections exist. Define __crt0_movedata when .lower.data or .either.data sections exist. * testsuite/gas/msp430/either-data-bss-sym.d: New test. * testsuite/gas/msp430/low-data-bss-sym.d: New test. * testsuite/gas/msp430/either-data-bss-sym.s: New test source. * testsuite/gas/msp430/low-data-bss-sym.s: New test source. * testsuite/gas/msp430/msp430.exp: Run new tests. Enable large code model when running -mdata-region={upper,either} tests.
45 lines
748 B
ArmAsm
45 lines
748 B
ArmAsm
.file "tester.c"
|
|
.text
|
|
.global foo
|
|
.section .rodata
|
|
.LC0:
|
|
.string "bar"
|
|
.section .data,"aw",@progbits
|
|
.balign 2
|
|
.type foo, @object
|
|
.size foo, 2
|
|
foo:
|
|
.short .LC0
|
|
.section .text,"ax",@progbits
|
|
.balign 2
|
|
.global main
|
|
.type main, @function
|
|
main:
|
|
; start of function
|
|
; framesize_regs: 0
|
|
; framesize_locals: 2
|
|
; framesize_outgoing: 0
|
|
; framesize: 2
|
|
; elim ap -> fp 2
|
|
; elim fp -> sp 2
|
|
; saved regs:(none)
|
|
; start of prologue
|
|
SUB.W #2, R1
|
|
; end of prologue
|
|
MOV.W #1, @R1
|
|
BR #.L2
|
|
.L3:
|
|
MOV.W &foo, R12
|
|
ADD.W #-1, R12
|
|
MOV.W R12, &foo
|
|
.L2:
|
|
MOV.W @R1, R12
|
|
CMP.W #0, R12 { JNE .L3
|
|
MOV.B #0, R12
|
|
; start of epilogue
|
|
.refsym __crt0_call_exit
|
|
ADD.W #2, R1
|
|
RET
|
|
.size main, .-main
|
|
.ident "GCC: (jozef) 7.3.2"
|