xref: /aosp_15_r20/external/llvm/test/Transforms/InstCombine/dce-iterate.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -instcombine -S | grep "ret double .sy"
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Workerdefine internal double @ScaleObjectAdd(double %sx, double %sy, double %sz) nounwind {
4*9880d681SAndroid Build Coastguard Workerentry:
5*9880d681SAndroid Build Coastguard Worker        %sx34 = bitcast double %sx to i64               ; <i64> [#uses=1]
6*9880d681SAndroid Build Coastguard Worker        %sx3435 = zext i64 %sx34 to i960                ; <i960> [#uses=1]
7*9880d681SAndroid Build Coastguard Worker        %sy22 = bitcast double %sy to i64               ; <i64> [#uses=1]
8*9880d681SAndroid Build Coastguard Worker        %sy2223 = zext i64 %sy22 to i960                ; <i960> [#uses=1]
9*9880d681SAndroid Build Coastguard Worker        %sy222324 = shl i960 %sy2223, 320               ; <i960> [#uses=1]
10*9880d681SAndroid Build Coastguard Worker        %sy222324.ins = or i960 %sx3435, %sy222324              ; <i960> [#uses=1]
11*9880d681SAndroid Build Coastguard Worker        %sz10 = bitcast double %sz to i64               ; <i64> [#uses=1]
12*9880d681SAndroid Build Coastguard Worker        %sz1011 = zext i64 %sz10 to i960                ; <i960> [#uses=1]
13*9880d681SAndroid Build Coastguard Worker        %sz101112 = shl i960 %sz1011, 640               ; <i960> [#uses=1]
14*9880d681SAndroid Build Coastguard Worker        %sz101112.ins = or i960 %sy222324.ins, %sz101112
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Worker        %a = trunc i960 %sz101112.ins to i64            ; <i64> [#uses=1]
17*9880d681SAndroid Build Coastguard Worker        %b = bitcast i64 %a to double           ; <double> [#uses=1]
18*9880d681SAndroid Build Coastguard Worker        %c = lshr i960 %sz101112.ins, 320               ; <i960> [#uses=1]
19*9880d681SAndroid Build Coastguard Worker        %d = trunc i960 %c to i64               ; <i64> [#uses=1]
20*9880d681SAndroid Build Coastguard Worker        %e = bitcast i64 %d to double           ; <double> [#uses=1]
21*9880d681SAndroid Build Coastguard Worker        %f = fadd double %b, %e
22*9880d681SAndroid Build Coastguard Worker
23*9880d681SAndroid Build Coastguard Worker        ret double %e
24*9880d681SAndroid Build Coastguard Worker}
25