diff options
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp b/llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp index 51480d09d73..6488b9aee0a 100644 --- a/llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp +++ b/llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp @@ -442,7 +442,8 @@ HexagonTargetLowering::LowerHvxMul(SDValue Op, SelectionDAG &DAG) const { ShuffMask.push_back(I+VecLen); // Pick odd element. } VectorPair P = opSplit(opCastElem(M, ElemTy, DAG), dl, DAG); - return getByteShuffle(dl, P.first, P.second, ShuffMask, DAG); + SDValue BS = getByteShuffle(dl, P.first, P.second, ShuffMask, DAG); + return DAG.getBitcast(ResTy, BS); } case MVT::i32: { // Use the following sequence for signed word multiply: |

