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

package info (click to toggle)
binutils-djgpp 2.35.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 321,228 kB
  • sloc: ansic: 1,162,947; asm: 671,219; cpp: 134,012; exp: 70,783; makefile: 55,860; sh: 22,254; yacc: 14,459; lisp: 13,806; perl: 2,008; lex: 1,649; pascal: 307; sed: 195; awk: 25
file content (27 lines) | stat: -rw-r--r-- 650 bytes parent folder | download | duplicates (24)
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