llvm/test/CodeGen/ARM/space-directive.ll
Tim Northover 5bd311bf17 ARM: add @llvm.arm.space intrinsic for testing ConstantIslands.
Creating tests for the ConstantIslands pass is very difficult, since it depends
on precise layout details. Having the ability to precisely inject a number of
bytes into the stream helps greatly.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@221903 91177308-0d34-0410-b5e6-96231b3b80d8
2014-11-13 17:58:48 +00:00

20 lines
472 B
LLVM

; RUN: llc -mtriple=armv7 -o - %s | FileCheck %s
define i32 @test_space() minsize {
; CHECK-LABEL: test_space:
; CHECK: ldr {{r[0-9]+}}, [[CPENTRY:.?LCPI[0-9]+_[0-9]+]]
; CHECK: b [[PAST_CP:.?LBB[0-9]+_[0-9]+]]
; CHECK: [[CPENTRY]]:
; CHECK-NEXT: 12345678
; CHECK: [[PAST_CP]]:
; CHECK: .zero 10000
%addr = inttoptr i32 12345678 to i32*
%val = load i32* %addr
call i32 @llvm.arm.space(i32 10000, i32 undef)
ret i32 %val
}
declare i32 @llvm.arm.space(i32, i32)