]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - test/CodeGen/Mips/helloworld.ll
Vendor import of llvm release_32 branch r168974 (effectively, 3.2 RC2):
[FreeBSD/FreeBSD.git] / test / CodeGen / Mips / helloworld.ll
1 ; RUN: llc  -march=mipsel -mcpu=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=C1
2 ; RUN: llc  -march=mipsel -mcpu=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=C2
3 ; RUN: llc  -march=mipsel -mcpu=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=PE
4 ;
5 ; re-enable this when mips16's jalr is fixed.
6 ; DISABLED: llc  -march=mipsel -mcpu=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=SR
7
8
9 @.str = private unnamed_addr constant [13 x i8] c"hello world\0A\00", align 1
10
11 define i32 @main() nounwind {
12 entry:
13   %call = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([13 x i8]* @.str, i32 0, i32 0))
14   ret i32 0
15
16 ; SR:   .set    mips16                  # @main
17
18 ; SR:   save    $ra, [[FS:[0-9]+]]
19 ; PE:   li      $[[T1:[0-9]+]], %hi(_gp_disp)
20 ; PE:   addiu   $[[T2:[0-9]+]], $pc, %lo(_gp_disp)
21 ; PE:   sll     $[[T3:[0-9]+]], $[[T1]], 16
22 ; C1:   lw      ${{[0-9]+}}, %got($.str)(${{[0-9]+}})
23 ; C2:   lw      ${{[0-9]+}}, %call16(printf)(${{[0-9]+}})
24 ; C1:   addiu   ${{[0-9]+}}, %lo($.str)
25 ; C2:   move    $25, ${{[0-9]+}}
26 ; C1:   move    $gp, ${{[0-9]+}}
27 ; C1:   jalrc   ${{[0-9]+}}
28 ; SR:   restore         $ra, [[FS]]
29 ; PE:   li      $2, 0
30 ; PE:   jrc     $ra
31
32 }
33
34 declare i32 @printf(i8*, ...)