view test/Transforms/InstCombine/2006-04-28-ShiftShiftLongLong.ll @ 0:95c75e76d11b LLVM3.4

LLVM 3.4
author Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
date Thu, 12 Dec 2013 13:56:28 +0900
parents
children
line wrap: on
line source

; RUN: opt < %s -instcombine -S | FileCheck %s

; This cannot be turned into a sign extending cast!

define i64 @test(i64 %X) {
        %Y = shl i64 %X, 16             ; <i64> [#uses=1]
; CHECK: %Y = shl i64 %X, 16
        %Z = ashr i64 %Y, 16            ; <i64> [#uses=1]
; CHECK: %Z = ashr exact i64 %Y, 16
        ret i64 %Z
; CHECK: ret i64 %Z
}