blob: a6021be8e808e7442a73af70c85af1d96c11c74f [file] [log] [blame]
Daniel Sanders8008de52015-10-15 14:34:23 +00001; 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
Reed Kotler3589dd72012-10-28 06:02:37 +00003
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
Reed Kotler3589dd72012-10-28 06:02:37 +00008declare i32 @printf(i8* nocapture, ...) nounwind
9
Reed Kotler3589dd72012-10-28 06:02:37 +000010define void @test() nounwind {
11entry:
12 %s = alloca i16, align 4
13 %c = alloca i8, align 4
14 store i16 16, i16* %s, align 4
15 store i8 99, i8* %c, align 4
16 store i16* %s, i16** @sp, align 4
17 store i8* %c, i8** @cp, align 4
David Blaikie23af6482015-04-16 23:24:18 +000018 %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
David Blaikiea79ac142015-02-27 21:17:42 +000019 %0 = load i16*, i16** @sp, align 4
Reed Kotler3589dd72012-10-28 06:02:37 +000020 store i16 32, i16* %0, align 2
David Blaikiea79ac142015-02-27 21:17:42 +000021 %1 = load i8*, i8** @cp, align 4
Reed Kotler3589dd72012-10-28 06:02:37 +000022 store i8 97, i8* %1, align 1
David Blaikiea79ac142015-02-27 21:17:42 +000023 %2 = load i16, i16* %s, align 4
24 %3 = load i8, i8* %c, align 4
Reed Kotler3589dd72012-10-28 06:02:37 +000025 %conv.i = sext i16 %2 to i32
26 %conv1.i = sext i8 %3 to i32
David Blaikie23af6482015-04-16 23:24:18 +000027 %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
Reed Kotler3589dd72012-10-28 06:02:37 +000028 ret void
Stephen Lind24ab202013-07-14 06:24:09 +000029; 16_b-LABEL: test:
30; 16_h-LABEL: test:
Reed Kotler3589dd72012-10-28 06:02:37 +000031; 16_b: sb ${{[0-9]+}}, [[offset1:[0-9]+]](${{[0-9]+}})
32; 16_b: lb ${{[0-9]+}}, [[offset1]](${{[0-9]+}})
33; 16_h: sh ${{[0-9]+}}, [[offset2:[0-9]+]](${{[0-9]+}})
34; 16_h: lh ${{[0-9]+}}, [[offset2]](${{[0-9]+}})
35}
36
Matt Arsenaultf10061e2017-04-10 20:18:21 +000037declare void @llvm.lifetime.start.p0i8(i64, i8* nocapture) nounwind
Reed Kotler3589dd72012-10-28 06:02:37 +000038
Matt Arsenaultf10061e2017-04-10 20:18:21 +000039declare void @llvm.lifetime.end.p0i8(i64, i8* nocapture) nounwind
Reed Kotler3589dd72012-10-28 06:02:37 +000040