diff options
author | Duncan Sands <baldrick@free.fr> | 2008-10-30 19:24:28 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2008-10-30 19:24:28 +0000 |
commit | 7aef60d26e8c4c5e4442c37a479a6a14da837ed5 (patch) | |
tree | 289a8ca145b3d07e869d64a2e99a6d1904d5076e /lib | |
parent | 42ac14ede1e1d08976ce1ad7d3270e8ab8222f55 (diff) | |
download | external_llvm-7aef60d26e8c4c5e4442c37a479a6a14da837ed5.zip external_llvm-7aef60d26e8c4c5e4442c37a479a6a14da837ed5.tar.gz external_llvm-7aef60d26e8c4c5e4442c37a479a6a14da837ed5.tar.bz2 |
Shift amounts should have the type given by
getShiftAmountTy (i32 in the case of CellSPU).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@58449 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Target/CellSPU/SPUISelLowering.cpp | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/lib/Target/CellSPU/SPUISelLowering.cpp b/lib/Target/CellSPU/SPUISelLowering.cpp index 8c5b919..5671d9d 100644 --- a/lib/Target/CellSPU/SPUISelLowering.cpp +++ b/lib/Target/CellSPU/SPUISelLowering.cpp @@ -2175,17 +2175,17 @@ static SDValue LowerI8Math(SDValue Op, SelectionDAG &DAG, unsigned Opc) ? DAG.getNode(ISD::ZERO_EXTEND, MVT::i16, N0) : DAG.getConstant(cast<ConstantSDNode>(N0)->getZExtValue(), MVT::i16)); - N1Opc = N1.getValueType().bitsLT(MVT::i16) + N1Opc = N1.getValueType().bitsLT(MVT::i32) ? ISD::ZERO_EXTEND : ISD::TRUNCATE; N1 = (N1.getOpcode() != ISD::Constant - ? DAG.getNode(N1Opc, MVT::i16, N1) + ? DAG.getNode(N1Opc, MVT::i32, N1) : DAG.getConstant(cast<ConstantSDNode>(N1)->getZExtValue(), - MVT::i16)); + MVT::i32)); SDValue ExpandArg = DAG.getNode(ISD::OR, MVT::i16, N0, DAG.getNode(ISD::SHL, MVT::i16, - N0, DAG.getConstant(8, MVT::i16))); + N0, DAG.getConstant(8, MVT::i32))); return DAG.getNode(ISD::TRUNCATE, MVT::i8, DAG.getNode(Opc, MVT::i16, ExpandArg, N1)); } @@ -2526,7 +2526,7 @@ static SDValue LowerCTPOP(SDValue Op, SelectionDAG &DAG) { SDValue N = Op.getOperand(0); SDValue Elt0 = DAG.getConstant(0, MVT::i16); SDValue Mask0 = DAG.getConstant(0x0f, MVT::i16); - SDValue Shift1 = DAG.getConstant(8, MVT::i16); + SDValue Shift1 = DAG.getConstant(8, MVT::i32); SDValue Promote = DAG.getNode(SPUISD::PROMOTE_SCALAR, vecVT, N, N); SDValue CNTB = DAG.getNode(SPUISD::CNTB, vecVT, Promote); |