The current Intel Atom microarchitecture has a feature whereby when a function
[oota-llvm.git] / test / CodeGen / X86 / atom-pad-short-functions.ll
1 ; RUN: llc < %s -mcpu=atom -mtriple=i686-linux  | FileCheck %s
2
3 declare void @external_function(...)
4
5 define i32 @test_return_val(i32 %a) nounwind {
6 ; CHECK: test_return_val
7 ; CHECK: movl
8 ; CHECK: nop
9 ; CHECK: nop
10 ; CHECK: nop
11 ; CHECK: nop
12 ; CHECK: nop
13 ; CHECK: nop
14 ; CHECK: ret
15   ret i32 %a
16 }
17
18 define i32 @test_add(i32 %a, i32 %b) nounwind {
19 ; CHECK: test_add
20 ; CHECK: addl
21 ; CHECK: nop
22 ; CHECK: nop
23 ; CHECK: nop
24 ; CHECK: nop
25 ; CHECK: ret
26   %result = add i32 %a, %b
27   ret i32 %result
28 }
29
30 define i32 @test_multiple_ret(i32 %a, i32 %b, i1 %c) nounwind {
31 ; CHECK: @test_multiple_ret
32 ; CHECK: je
33
34 ; CHECK: nop
35 ; CHECK: nop
36 ; CHECK: ret
37
38 ; CHECK: nop
39 ; CHECK: nop
40 ; CHECK: ret
41
42   br i1 %c, label %bb1, label %bb2
43
44 bb1:
45   ret i32 %a
46
47 bb2:
48   ret i32 %b
49 }
50
51 define void @test_call_others(i32 %x) nounwind
52 {
53 ; CHECK: test_call_others
54 ; CHECK: je
55   %tobool = icmp eq i32 %x, 0
56   br i1 %tobool, label %if.end, label %true.case
57
58 ; CHECK: jmp external_function
59 true.case:
60   tail call void bitcast (void (...)* @external_function to void ()*)() nounwind
61   br label %if.end
62
63 ; CHECK: nop
64 ; CHECK: nop
65 ; CHECK: nop
66 ; CHECK: nop
67 ; CHECK: ret
68 if.end:
69   ret void
70
71 }