Home | History | Annotate | Download | only in Mips
      1 ; RUN: llc  -march=mipsel -mattr=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=16_h
      2 ; RUN: llc  -march=mipsel -mattr=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=16_b
      3 
      4 @.str = private unnamed_addr constant [9 x i8] c"%hd %c \0A\00", align 1
      5 @sp = common global i16* null, align 4
      6 @cp = common global i8* null, align 4
      7 
      8 define void @p1(i16 signext %s, i8 signext %c) nounwind {
      9 entry:
     10   %conv = sext i16 %s to i32
     11   %conv1 = sext i8 %c to i32
     12   %call = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([9 x i8], [9 x i8]* @.str, i32 0, i32 0), i32 %conv, i32 %conv1) nounwind
     13   ret void
     14 }
     15 
     16 declare i32 @printf(i8* nocapture, ...) nounwind
     17 
     18 define void @p2() nounwind {
     19 entry:
     20   %0 = load i16*, i16** @sp, align 4
     21   %1 = load i16, i16* %0, align 2
     22   %2 = load i8*, i8** @cp, align 4
     23   %3 = load i8, i8* %2, align 1
     24   %conv.i = sext i16 %1 to i32
     25   %conv1.i = sext i8 %3 to i32
     26   %call.i = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([9 x i8], [9 x i8]* @.str, i32 0, i32 0), i32 %conv.i, i32 %conv1.i) nounwind
     27   %4 = load i16*, i16** @sp, align 4
     28   store i16 32, i16* %4, align 2
     29   %5 = load i8*, i8** @cp, align 4
     30   store i8 97, i8* %5, align 1
     31   ret void
     32 }
     33 
     34 define void @test() nounwind {
     35 entry:
     36   %s = alloca i16, align 4
     37   %c = alloca i8, align 4
     38   store i16 16, i16* %s, align 4
     39   store i8 99, i8* %c, align 4
     40   store i16* %s, i16** @sp, align 4
     41   store i8* %c, i8** @cp, align 4
     42   %call.i.i = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([9 x i8], [9 x i8]* @.str, i32 0, i32 0), i32 16, i32 99) nounwind
     43   %0 = load i16*, i16** @sp, align 4
     44   store i16 32, i16* %0, align 2
     45   %1 = load i8*, i8** @cp, align 4
     46   store i8 97, i8* %1, align 1
     47   %2 = load i16, i16* %s, align 4
     48   %3 = load i8, i8* %c, align 4
     49   %conv.i = sext i16 %2 to i32
     50   %conv1.i = sext i8 %3 to i32
     51   %call.i = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([9 x i8], [9 x i8]* @.str, i32 0, i32 0), i32 %conv.i, i32 %conv1.i) nounwind
     52   ret void
     53 ; 16_b-LABEL: test:
     54 ; 16_h-LABEL: test:
     55 ; 16_b:	sb	${{[0-9]+}}, [[offset1:[0-9]+]](${{[0-9]+}})
     56 ; 16_b: lb      ${{[0-9]+}}, [[offset1]](${{[0-9]+}})
     57 ; 16_h:	sh	${{[0-9]+}}, [[offset2:[0-9]+]](${{[0-9]+}})
     58 ; 16_h: lh      ${{[0-9]+}}, [[offset2]](${{[0-9]+}})
     59 }
     60 
     61 define i32 @main() nounwind {
     62 entry:
     63   %s.i = alloca i16, align 4
     64   %c.i = alloca i8, align 4
     65   %0 = bitcast i16* %s.i to i8*
     66   call void @llvm.lifetime.start(i64 -1, i8* %0) nounwind
     67   call void @llvm.lifetime.start(i64 -1, i8* %c.i) nounwind
     68   store i16 16, i16* %s.i, align 4
     69   store i8 99, i8* %c.i, align 4
     70   store i16* %s.i, i16** @sp, align 4
     71   store i8* %c.i, i8** @cp, align 4
     72   %call.i.i.i = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([9 x i8], [9 x i8]* @.str, i32 0, i32 0), i32 16, i32 99) nounwind
     73   %1 = load i16*, i16** @sp, align 4
     74   store i16 32, i16* %1, align 2
     75   %2 = load i8*, i8** @cp, align 4
     76   store i8 97, i8* %2, align 1
     77   %3 = load i16, i16* %s.i, align 4
     78   %4 = load i8, i8* %c.i, align 4
     79   %conv.i.i = sext i16 %3 to i32
     80   %conv1.i.i = sext i8 %4 to i32
     81   %call.i.i = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([9 x i8], [9 x i8]* @.str, i32 0, i32 0), i32 %conv.i.i, i32 %conv1.i.i) nounwind
     82   call void @llvm.lifetime.end(i64 -1, i8* %0) nounwind
     83   call void @llvm.lifetime.end(i64 -1, i8* %c.i) nounwind
     84   ret i32 0
     85 }
     86 
     87 declare void @llvm.lifetime.start(i64, i8* nocapture) nounwind
     88 
     89 declare void @llvm.lifetime.end(i64, i8* nocapture) nounwind
     90 
     91