; 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
}