File: stm32l4xx-cannot-fix-far-ldm.s

package info (click to toggle)
binutils-m68hc1x 1%3A2.35.1-3
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 335,580 kB
  • sloc: ansic: 1,187,755; asm: 674,290; cpp: 130,744; exp: 70,774; makefile: 56,048; sh: 22,128; yacc: 14,459; lisp: 13,803; perl: 2,112; ada: 1,681; lex: 1,649; pascal: 1,446; cs: 879; sed: 195; xml: 95; awk: 25
file content (27 lines) | stat: -rw-r--r-- 650 bytes parent folder | download | duplicates (26)
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