@@ -1438,8 +1438,9 @@ RISCVTargetLowering::RISCVTargetLowering(const TargetMachine &TM,
14381438 }
14391439
14401440 // Custom-legalize bitcasts from fixed-length vectors to scalar types.
1441- setOperationAction(ISD::BITCAST, {MVT::i8, MVT::i16, MVT::i32, MVT::i64},
1442- Custom);
1441+ setOperationAction(ISD::BITCAST, {MVT::i8, MVT::i16, MVT::i32}, Custom);
1442+ if (Subtarget.is64Bit())
1443+ setOperationAction(ISD::BITCAST, MVT::i64, Custom);
14431444 if (Subtarget.hasStdExtZfhminOrZhinxmin())
14441445 setOperationAction(ISD::BITCAST, MVT::f16, Custom);
14451446 if (Subtarget.hasStdExtZfbfmin())
@@ -6422,7 +6423,8 @@ SDValue RISCVTargetLowering::LowerOperation(SDValue Op,
64226423 SDValue NewOp0 = DAG.getNode(ISD::ANY_EXTEND, DL, MVT::i64, Op0);
64236424 return DAG.getNode(RISCVISD::FMV_W_X_RV64, DL, MVT::f32, NewOp0);
64246425 }
6425- if (VT == MVT::f64 && Op0VT == MVT::i64 && XLenVT == MVT::i32) {
6426+ if (VT == MVT::f64 && Op0VT == MVT::i64 && !Subtarget.is64Bit() &&
6427+ Subtarget.hasStdExtDOrZdinx()) {
64266428 SDValue Lo, Hi;
64276429 std::tie(Lo, Hi) = DAG.SplitScalar(Op0, DL, MVT::i32, MVT::i32);
64286430 return DAG.getNode(RISCVISD::BuildPairF64, DL, MVT::f64, Lo, Hi);
@@ -12940,7 +12942,8 @@ void RISCVTargetLowering::ReplaceNodeResults(SDNode *N,
1294012942 SDValue FPConv =
1294112943 DAG.getNode(RISCVISD::FMV_X_ANYEXTW_RV64, DL, MVT::i64, Op0);
1294212944 Results.push_back(DAG.getNode(ISD::TRUNCATE, DL, MVT::i32, FPConv));
12943- } else if (VT == MVT::i64 && Op0VT == MVT::f64 && XLenVT == MVT::i32) {
12945+ } else if (VT == MVT::i64 && Op0VT == MVT::f64 && !Subtarget.is64Bit() &&
12946+ Subtarget.hasStdExtDOrZdinx()) {
1294412947 SDValue NewReg = DAG.getNode(RISCVISD::SplitF64, DL,
1294512948 DAG.getVTList(MVT::i32, MVT::i32), Op0);
1294612949 SDValue RetReg = DAG.getNode(ISD::BUILD_PAIR, DL, MVT::i64,
0 commit comments