forked from OSchip/llvm-project
25 lines
1.2 KiB
LLVM
25 lines
1.2 KiB
LLVM
; RUN: opt < %s -instcombine -S | grep {fadd double .sx, .sy}
|
|
; The 'or' has multiple uses, make sure that this doesn't prevent instcombine
|
|
; from propagating the extends to the truncs.
|
|
|
|
define double @ScaleObjectAdd(double %sx, double %sy, double %sz) nounwind {
|
|
entry:
|
|
%sx34 = bitcast double %sx to i64 ; <i64> [#uses=1]
|
|
%sx3435 = zext i64 %sx34 to i192 ; <i192> [#uses=1]
|
|
%sy22 = bitcast double %sy to i64 ; <i64> [#uses=1]
|
|
%sy2223 = zext i64 %sy22 to i192 ; <i192> [#uses=1]
|
|
%sy222324 = shl i192 %sy2223, 128 ; <i192> [#uses=1]
|
|
%sy222324.ins = or i192 %sx3435, %sy222324 ; <i192> [#uses=1]
|
|
|
|
|
|
%a = trunc i192 %sy222324.ins to i64 ; <i64> [#uses=1]
|
|
%b = bitcast i64 %a to double ; <double> [#uses=1]
|
|
%c = lshr i192 %sy222324.ins, 128 ; <i192> [#uses=1]
|
|
%d = trunc i192 %c to i64 ; <i64> [#uses=1]
|
|
%e = bitcast i64 %d to double ; <double> [#uses=1]
|
|
%f = fadd double %b, %e
|
|
|
|
; ret double %e
|
|
ret double %f
|
|
}
|