summaryrefslogtreecommitdiff
path: root/ld/testsuite/ld-arm/stm32l4xx-cannot-fix-far-ldm.s
blob: 7ba9a167584e48e5c57cb0b7c3b69d5edc6d6244 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
        .syntax unified
        .cpu cortex-m4
        .fpu fpv4-sp-d16
        .text
        .align  1
        .thumb
        .thumb_func
        .global _start
_start:
        .space 0xFFFF00

        @ Multiple load, case #2
        @ ldm rx, {...} ->
        @ mov ry, rx where ry is the lowest register from upper_list
        @ ldm ry!, { lower_list }
        @ ldm ry,  { upper_list }
        ldm.w  r0, {r1-r9}

	.space 0x100

        @ Check that the linker never generates a wrong branch
        @ ldm rx, {...} -> ldm rx, {...}
        @ Emit a warning during the link phase and keep the same instruction

	ldm.w  r9, {r1-r9}

        nop