forked from OSchip/llvm-project
97 lines
2.9 KiB
ArmAsm
97 lines
2.9 KiB
ArmAsm
// REQUIRES: arm
|
|
// RUN: llvm-mc -filetype=obj -triple=armv7a-none-linux-gnueabi %s -o %t
|
|
// RUN: ld.lld %t -o %t2 2>&1
|
|
// The output file is large, most of it zeroes. We dissassemble only the
|
|
// parts we need to speed up the test and avoid a large output file
|
|
// RUN: llvm-objdump -d %t2 -start-address=1048578 -stop-address=1048586 -triple=thumbv7a-linux-gnueabihf | FileCheck -check-prefix=CHECK1 %s
|
|
// RUN: llvm-objdump -d %t2 -start-address=16777224 -stop-address=16777254 -triple=thumbv7a-linux-gnueabihf | FileCheck -check-prefix=CHECK2 %s
|
|
// RUN: llvm-objdump -d %t2 -start-address=17825818 -stop-address=17825828 -triple=thumbv7a-linux-gnueabihf | FileCheck -check-prefix=CHECK3 %s
|
|
// In this test case a branch that is in range and does not need its range
|
|
// extended can be pushed out of range by another Thunk, necessitating another
|
|
// pass
|
|
|
|
.macro FUNCTION suff
|
|
.section .text.\suff\(), "ax", %progbits
|
|
.thumb
|
|
.balign 0x100000
|
|
.globl tfunc\suff\()
|
|
.type tfunc\suff\(), %function
|
|
tfunc\suff\():
|
|
bx lr
|
|
.endm
|
|
|
|
FUNCTION 00
|
|
.globl _start
|
|
_start:
|
|
bl target
|
|
b.w arm_target
|
|
// arm_target is in range but needs an interworking thunk
|
|
// CHECK1: _start:
|
|
// CHECK1-NEXT: 100002: 00 f3 06 d0 bl #15728652
|
|
// CHECK1-NEXT: 100006: ff f2 ff 97 b.w #15728638 <__Thumbv7ABSLongThunk_arm_target>
|
|
nop
|
|
nop
|
|
nop
|
|
.globl target2
|
|
.type target2, %function
|
|
nop
|
|
|
|
target2:
|
|
FUNCTION 01
|
|
FUNCTION 02
|
|
FUNCTION 03
|
|
FUNCTION 04
|
|
FUNCTION 05
|
|
FUNCTION 06
|
|
FUNCTION 07
|
|
FUNCTION 08
|
|
FUNCTION 09
|
|
FUNCTION 10
|
|
FUNCTION 11
|
|
FUNCTION 12
|
|
FUNCTION 13
|
|
FUNCTION 14
|
|
FUNCTION 15
|
|
|
|
.section .text.16, "ax", %progbits
|
|
.arm
|
|
.globl arm_target
|
|
.type arm_target, %function
|
|
arm_target:
|
|
bx lr
|
|
// CHECK2: __Thumbv7ABSLongThunk_arm_target:
|
|
// CHECK2-NEXT: 1000008: 40 f2 02 0c movw r12, #2
|
|
// CHECK2-NEXT: 100000c: c0 f2 00 1c movt r12, #256
|
|
// CHECK2-NEXT: 1000010: 60 47 bx r12
|
|
// CHECK2: __Thumbv7ABSLongThunk_target:
|
|
// CHECK2-NEXT: 1000012: 40 f2 1b 0c movw r12, #27
|
|
// CHECK2-NEXT: 1000016: c0 f2 10 1c movt r12, #272
|
|
// CHECK2-NEXT: 100001a: 60 47 bx r12
|
|
// CHECK2: __Thumbv7ABSLongThunk_target2:
|
|
// CHECK2-NEXT: 100001c: 40 f2 13 0c movw r12, #19
|
|
// CHECK2-NEXT: 1000020: c0 f2 10 0c movt r12, #16
|
|
// CHECK2-NEXT: 1000024: 60 47 bx r12
|
|
|
|
.section .text.17, "ax", %progbits
|
|
// Just enough space so that bl target is in range if no extension thunks are
|
|
// generated.
|
|
|
|
.space 0x100000 - 12
|
|
|
|
.section .text.18, "ax", %progbits
|
|
.thumb
|
|
.globl target
|
|
.type target, %function
|
|
// target is at maximum ARM branch range away from caller.
|
|
target:
|
|
// Similar case in the backwards direction
|
|
bl target2
|
|
nop
|
|
nop
|
|
bx lr
|
|
// CHECK3: target:
|
|
// CHECK3-NEXT: 110001a: ff f6 ff ff bl #-1048578
|
|
// CHECK3-NEXT: 110001e: 00 bf nop
|
|
// CHECK3-NEXT: 1100020: 00 bf nop
|
|
// CHECK3-NEXT: 1100022: 70 47 bx lr
|