1; RUN: llc < %s | grep {sthy.%} | count 2 2; RUN: llc < %s | grep {lhy.%} | count 2 3; RUN: llc < %s | grep {lh.%} | count 6 4; RUN: llc < %s | grep {sth.%} | count 2 5 6target datalayout = "E-p:64:64:64-i8:8:16-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-f128:128:128-a0:16:16" 7target triple = "s390x-ibm-linux" 8 9define void @foo1(i16* nocapture %foo, i16* nocapture %bar) nounwind { 10entry: 11 %tmp1 = load i16* %foo ; <i16> [#uses=1] 12 store i16 %tmp1, i16* %bar 13 ret void 14} 15 16define void @foo2(i16* nocapture %foo, i16* nocapture %bar, i64 %idx) nounwind { 17entry: 18 %add.ptr = getelementptr i16* %foo, i64 1 ; <i16*> [#uses=1] 19 %tmp1 = load i16* %add.ptr ; <i16> [#uses=1] 20 %add.ptr3.sum = add i64 %idx, 1 ; <i64> [#uses=1] 21 %add.ptr5 = getelementptr i16* %bar, i64 %add.ptr3.sum ; <i16*> [#uses=1] 22 store i16 %tmp1, i16* %add.ptr5 23 ret void 24} 25 26define void @foo3(i16* nocapture %foo, i16* nocapture %bar, i64 %idx) nounwind { 27entry: 28 %sub.ptr = getelementptr i16* %foo, i64 -1 ; <i16*> [#uses=1] 29 %tmp1 = load i16* %sub.ptr ; <i16> [#uses=1] 30 %sub.ptr3.sum = add i64 %idx, -1 ; <i64> [#uses=1] 31 %add.ptr = getelementptr i16* %bar, i64 %sub.ptr3.sum ; <i16*> [#uses=1] 32 store i16 %tmp1, i16* %add.ptr 33 ret void 34} 35 36define void @foo4(i16* nocapture %foo, i16* nocapture %bar, i64 %idx) nounwind { 37entry: 38 %add.ptr = getelementptr i16* %foo, i64 8192 ; <i16*> [#uses=1] 39 %tmp1 = load i16* %add.ptr ; <i16> [#uses=1] 40 %add.ptr3.sum = add i64 %idx, 8192 ; <i64> [#uses=1] 41 %add.ptr5 = getelementptr i16* %bar, i64 %add.ptr3.sum ; <i16*> [#uses=1] 42 store i16 %tmp1, i16* %add.ptr5 43 ret void 44} 45 46define void @foo5(i16* nocapture %foo, i32* nocapture %bar) nounwind { 47entry: 48 %tmp1 = load i16* %foo ; <i16> [#uses=1] 49 %conv = sext i16 %tmp1 to i32 ; <i32> [#uses=1] 50 store i32 %conv, i32* %bar 51 ret void 52} 53 54define void @foo6(i16* nocapture %foo, i32* nocapture %bar, i64 %idx) nounwind { 55entry: 56 %add.ptr = getelementptr i16* %foo, i64 1 ; <i16*> [#uses=1] 57 %tmp1 = load i16* %add.ptr ; <i16> [#uses=1] 58 %conv = sext i16 %tmp1 to i32 ; <i32> [#uses=1] 59 %add.ptr3.sum = add i64 %idx, 1 ; <i64> [#uses=1] 60 %add.ptr5 = getelementptr i32* %bar, i64 %add.ptr3.sum ; <i32*> [#uses=1] 61 store i32 %conv, i32* %add.ptr5 62 ret void 63} 64 65define void @foo7(i16* nocapture %foo, i32* nocapture %bar, i64 %idx) nounwind { 66entry: 67 %sub.ptr = getelementptr i16* %foo, i64 -1 ; <i16*> [#uses=1] 68 %tmp1 = load i16* %sub.ptr ; <i16> [#uses=1] 69 %conv = sext i16 %tmp1 to i32 ; <i32> [#uses=1] 70 %sub.ptr3.sum = add i64 %idx, -1 ; <i64> [#uses=1] 71 %add.ptr = getelementptr i32* %bar, i64 %sub.ptr3.sum ; <i32*> [#uses=1] 72 store i32 %conv, i32* %add.ptr 73 ret void 74} 75 76define void @foo8(i16* nocapture %foo, i32* nocapture %bar, i64 %idx) nounwind { 77entry: 78 %add.ptr = getelementptr i16* %foo, i64 8192 ; <i16*> [#uses=1] 79 %tmp1 = load i16* %add.ptr ; <i16> [#uses=1] 80 %conv = sext i16 %tmp1 to i32 ; <i32> [#uses=1] 81 %add.ptr3.sum = add i64 %idx, 8192 ; <i64> [#uses=1] 82 %add.ptr5 = getelementptr i32* %bar, i64 %add.ptr3.sum ; <i32*> [#uses=1] 83 store i32 %conv, i32* %add.ptr5 84 ret void 85} 86