llvm-project/llvm/test/Transforms/InstCombine/2006-02-07-SextZextCrash.ll

22 lines
1.1 KiB
LLVM

; RUN: llvm-as < %s | opt -instcombine -disable-output
%struct.rtx_const = type { i32, { %union.real_extract } }
%struct.rtx_def = type { i32, [1 x %union.rtunion_def] }
%union.real_extract = type { double }
%union.rtunion_def = type { i32 }
define fastcc void @decode_rtx_const(%struct.rtx_def* %x, %struct.rtx_const* %value) {
%tmp.54 = getelementptr %struct.rtx_const* %value, i32 0, i32 0 ; <i32*> [#uses=1]
%tmp.56 = getelementptr %struct.rtx_def* %x, i32 0, i32 0 ; <i32*> [#uses=1]
%tmp.57 = load i32* %tmp.56 ; <i32> [#uses=1]
%tmp.58 = shl i32 %tmp.57, 8 ; <i32> [#uses=1]
%tmp.59 = ashr i32 %tmp.58, 24 ; <i32> [#uses=1]
%tmp.60 = trunc i32 %tmp.59 to i16 ; <i16> [#uses=1]
%tmp.61 = zext i16 %tmp.60 to i32 ; <i32> [#uses=1]
%tmp.62 = shl i32 %tmp.61, 16 ; <i32> [#uses=1]
%tmp.65 = or i32 0, %tmp.62 ; <i32> [#uses=1]
store i32 %tmp.65, i32* %tmp.54
ret void
}