llvm-6502/test/Transforms/InstCombine/zext.ll
Dan Gohman f2f6ce65b7 Change tests from "opt %s" to "opt < %s" so that opt doesn't see the
input filename so that opt doesn't print the input filename in the
output so that grep lines in the tests don't unintentionally match
strings in the input filename.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@81537 91177308-0d34-0410-b5e6-96231b3b80d8
2009-09-11 18:01:28 +00:00

34 lines
1.2 KiB
LLVM

; Tests to make sure elimination of casts is working correctly
; RUN: opt < %s -instcombine -S | \
; RUN: notcast {} {%c1.*}
define i64 @test_sext_zext(i16 %A) {
%c1 = zext i16 %A to i32 ; <i32> [#uses=1]
%c2 = sext i32 %c1 to i64 ; <i64> [#uses=1]
ret i64 %c2
}
; PR3599
define i32 @test2(i64 %tmp) nounwind readnone {
entry:
%tmp5 = trunc i64 %tmp to i8 ; <i8> [#uses=1]
%tmp7 = lshr i64 %tmp, 8 ; <i64> [#uses=1]
%tmp8 = trunc i64 %tmp7 to i8 ; <i8> [#uses=1]
%tmp10 = lshr i64 %tmp, 16 ; <i64> [#uses=1]
%tmp11 = trunc i64 %tmp10 to i8 ; <i8> [#uses=1]
%tmp13 = lshr i64 %tmp, 24 ; <i64> [#uses=1]
%tmp14 = trunc i64 %tmp13 to i8 ; <i8> [#uses=1]
%tmp1 = zext i8 %tmp5 to i32 ; <i32> [#uses=1]
%tmp2 = zext i8 %tmp8 to i32 ; <i32> [#uses=1]
%tmp3 = shl i32 %tmp2, 8 ; <i32> [#uses=1]
%tmp4 = zext i8 %tmp11 to i32 ; <i32> [#uses=1]
%tmp6 = shl i32 %tmp4, 16 ; <i32> [#uses=1]
%tmp9 = zext i8 %tmp14 to i32 ; <i32> [#uses=1]
%tmp12 = shl i32 %tmp9, 24 ; <i32> [#uses=1]
%tmp15 = or i32 %tmp12, %tmp1 ; <i32> [#uses=1]
%tmp16 = or i32 %tmp15, %tmp6 ; <i32> [#uses=1]
%tmp17 = or i32 %tmp16, %tmp3 ; <i32> [#uses=1]
ret i32 %tmp17
}