[ARM] Cortex-M4 schedule additions
[llvm-complete.git] / test / CodeGen / X86 / fold-call.ll
bloba50b47481684d2200ec8254b0225d4600cff9375
1 ; RUN: llc < %s -mtriple=i686-- | FileCheck %s
2 ; RUN: llc < %s -mtriple=x86_64-- | FileCheck %s
4 ; CHECK: test1
5 ; CHECK-NOT: mov
7 declare void @bar()
8 define void @test1(i32 %i0, i32 %i1, i32 %i2, i32 %i3, i32 %i4, i32 %i5, void()* %arg) nounwind {
9         call void @bar()
10         call void %arg()
11         ret void
14 ; PR14739
15 ; CHECK: test2
16 ; CHECK: mov{{.*}} $0, ([[REGISTER:%[a-z]+]])
17 ; CHECK-NOT: jmp{{.*}} *([[REGISTER]])
19 %struct.X = type { void ()* }
20 define void @test2(%struct.X* nocapture %x) {
21 entry:
22   %f = getelementptr inbounds %struct.X, %struct.X* %x, i64 0, i32 0
23   %0 = load void ()*, void ()** %f
24   store void ()* null, void ()** %f
25   tail call void %0()
26   ret void