Pad Short Functions for Intel Atom
[oota-llvm.git] / test / CodeGen / X86 / atom-pad-short-functions.ll
1 ; RUN: llc < %s -O1 -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_optsize(i32 %a) nounwind optsize {
19 ; CHECK: test_optsize
20 ; CHECK: movl
21 ; CHECK-NEXT: ret
22   ret i32 %a
23 }
24
25 define i32 @test_add(i32 %a, i32 %b) nounwind {
26 ; CHECK: test_add
27 ; CHECK: addl
28 ; CHECK: nop
29 ; CHECK: nop
30 ; CHECK: nop
31 ; CHECK: nop
32 ; CHECK: ret
33   %result = add i32 %a, %b
34   ret i32 %result
35 }
36
37 define i32 @test_multiple_ret(i32 %a, i32 %b, i1 %c) nounwind {
38 ; CHECK: @test_multiple_ret
39 ; CHECK: je
40
41 ; CHECK: nop
42 ; CHECK: nop
43 ; CHECK: ret
44
45 ; CHECK: nop
46 ; CHECK: nop
47 ; CHECK: ret
48
49   br i1 %c, label %bb1, label %bb2
50
51 bb1:
52   ret i32 %a
53
54 bb2:
55   ret i32 %b
56 }
57
58 define void @test_call_others(i32 %x) nounwind
59 {
60 ; CHECK: test_call_others
61 ; CHECK: je
62   %tobool = icmp eq i32 %x, 0
63   br i1 %tobool, label %if.end, label %true.case
64
65 ; CHECK: jmp external_function
66 true.case:
67   tail call void bitcast (void (...)* @external_function to void ()*)() nounwind
68   br label %if.end
69
70 ; CHECK: nop
71 ; CHECK: nop
72 ; CHECK: nop
73 ; CHECK: nop
74 ; CHECK: ret
75 if.end:
76   ret void
77
78 }