diff options
Diffstat (limited to 'test/CodeGen/PowerPC/ppc64-calls.ll')
-rw-r--r-- | test/CodeGen/PowerPC/ppc64-calls.ll | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/test/CodeGen/PowerPC/ppc64-calls.ll b/test/CodeGen/PowerPC/ppc64-calls.ll index 31794be..707ba95 100644 --- a/test/CodeGen/PowerPC/ppc64-calls.ll +++ b/test/CodeGen/PowerPC/ppc64-calls.ll @@ -1,4 +1,4 @@ -; RUN: llc < %s -march=ppc64 | FileCheck %s +; RUN: llc < %s -march=ppc64 -mcpu=pwr7 | FileCheck %s target datalayout = "E-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v128:128:128-n32:64" target triple = "powerpc64-unknown-linux-gnu" @@ -67,3 +67,20 @@ define double @test_external(double %x) nounwind { ; CHECK-NEXT: nop ret double %call } + +; The 'ld 2, 40(1)' really must always come directly after the bctrl to make +; the unwinding code in libgcc happy. +@g = external global void ()* +declare void @h(i64) +define void @test_indir_toc_reload(i64 %x) { + %1 = load void ()** @g + call void %1() + call void @h(i64 %x) + ret void + +; CHECK-LABEL: @test_indir_toc_reload +; CHECK: bctrl +; CHECK-NEXT: ld 2, 40(1) +; CHECK: blr +} + |