[llvm-dev] LLVM ERROR: Cannot select adde
Phil Tomson via llvm-dev
llvm-dev at lists.llvm.org
Tue Oct 25 13:23:26 PDT 2016
We're getting this error from one of the LLVM testcases in 3.9 (also had it
in 3.6) for our target:
LLVM ERROR: Cannot select: t36: i64,glue = adde t8, t4, t35:1
t8: i64,ch = CopyFromReg t0, Register:i64 %vreg3
t7: i64 = Register %vreg3
t4: i64,ch = CopyFromReg t0, Register:i64 %vreg1
t3: i64 = Register %vreg1
t35: i64,glue = addc t6, t2
t6: i64,ch = CopyFromReg t0, Register:i64 %vreg2
t5: i64 = Register %vreg2
t2: i64,ch = CopyFromReg t0, Register:i64 %vreg0
t1: i64 = Register %vreg0
In function: test_add
The testcase is test/CodeGen/Generic/i128-addsub.ll:
define void @test_add(i64 %AL, i64 %AH, i64 %BL, i64 %BH, i64* %RL, i64*
%RH) {
entry:
%tmp1 = zext i64 %AL to i128 ; <i128> [#uses=1]
%tmp23 = zext i64 %AH to i128 ; <i128> [#uses=1]
%tmp4 = shl i128 %tmp23, 64 ; <i128> [#uses=1]
%tmp5 = or i128 %tmp4, %tmp1 ; <i128> [#uses=1]
%tmp67 = zext i64 %BL to i128 ; <i128> [#uses=1]
%tmp89 = zext i64 %BH to i128 ; <i128> [#uses=1]
%tmp11 = shl i128 %tmp89, 64 ; <i128> [#uses=1]
%tmp12 = or i128 %tmp11, %tmp67 ; <i128> [#uses=1]
%tmp15 = add i128 %tmp12, %tmp5 ; <i128> [#uses=2]
%tmp1617 = trunc i128 %tmp15 to i64 ; <i64> [#uses=1]
store i64 %tmp1617, i64* %RL
%tmp21 = lshr i128 %tmp15, 64 ; <i128> [#uses=1]
%tmp2122 = trunc i128 %tmp21 to i64 ; <i64> [#uses=1]
store i64 %tmp2122, i64* %RH
ret void
}
I've added the following to our Target's TargetISelLowering constructor:
setOperationAction(ISD::ADDE, MVT::i32, Expand);
setOperationAction(ISD::ADDE, MVT::i64, Expand);
setOperationAction(ISD::ADDE, MVT::i16, Expand);
setOperationAction(ISD::ADDE, MVT::i8, Expand);
setOperationAction(ISD::ADDE, MVT::f32, Expand);
setOperationAction(ISD::ADDE, MVT::f64, Expand);
... but it still gives the same error. I'm not sure how the adde node si
getting in there - any ideas?
Phil
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20161025/df5b8494/attachment.html>
More information about the llvm-dev
mailing list