diff --git a/llvm/lib/Target/RISCV/RISCVInstrInfoD.td b/llvm/lib/Target/RISCV/RISCVInstrInfoD.td --- a/llvm/lib/Target/RISCV/RISCVInstrInfoD.td +++ b/llvm/lib/Target/RISCV/RISCVInstrInfoD.td @@ -113,7 +113,7 @@ defm : FPFMADynFrmAlias_m; defm : FPFMADynFrmAlias_m; -let SchedRW = [WriteFALU64, ReadFALU64, ReadFALU64] in { +let SchedRW = [WriteFAdd64, ReadFAdd64, ReadFAdd64] in { defm FADD_D : FPALU_rr_frm_m<0b0000001, "fadd.d", DINX, /*Commutable*/1>; defm FSUB_D : FPALU_rr_frm_m<0b0000101, "fsub.d", DINX>; } diff --git a/llvm/lib/Target/RISCV/RISCVInstrInfoF.td b/llvm/lib/Target/RISCV/RISCVInstrInfoF.td --- a/llvm/lib/Target/RISCV/RISCVInstrInfoF.td +++ b/llvm/lib/Target/RISCV/RISCVInstrInfoF.td @@ -314,7 +314,7 @@ defm : FPFMADynFrmAlias_m; defm : FPFMADynFrmAlias_m; -let SchedRW = [WriteFALU32, ReadFALU32, ReadFALU32] in { +let SchedRW = [WriteFAdd32, ReadFAdd32, ReadFAdd32] in { defm FADD_S : FPALU_rr_frm_m<0b0000000, "fadd.s", FINX, /*Commutable*/1>; defm FSUB_S : FPALU_rr_frm_m<0b0000100, "fsub.s", FINX>; } diff --git a/llvm/lib/Target/RISCV/RISCVInstrInfoZfh.td b/llvm/lib/Target/RISCV/RISCVInstrInfoZfh.td --- a/llvm/lib/Target/RISCV/RISCVInstrInfoZfh.td +++ b/llvm/lib/Target/RISCV/RISCVInstrInfoZfh.td @@ -108,7 +108,7 @@ defm : FPFMADynFrmAlias_m; defm : FPFMADynFrmAlias_m; -let SchedRW = [WriteFALU16, ReadFALU16, ReadFALU16] in { +let SchedRW = [WriteFAdd16, ReadFAdd16, ReadFAdd16] in { defm FADD_H : FPALU_rr_frm_m<0b0000010, "fadd.h", HINX, /*Commutable*/1>; defm FSUB_H : FPALU_rr_frm_m<0b0000110, "fsub.h", HINX>; } diff --git a/llvm/lib/Target/RISCV/RISCVSchedRocket.td b/llvm/lib/Target/RISCV/RISCVSchedRocket.td --- a/llvm/lib/Target/RISCV/RISCVSchedRocket.td +++ b/llvm/lib/Target/RISCV/RISCVSchedRocket.td @@ -111,14 +111,14 @@ // Single precision. let Latency = 4 in { -def : WriteRes; +def : WriteRes; def : WriteRes; def : WriteRes; } // Double precision let Latency = 6 in { -def : WriteRes; +def : WriteRes; def : WriteRes; def : WriteRes; } @@ -203,11 +203,11 @@ def : ReadAdvance; def : ReadAdvance; def : ReadAdvance; -def : ReadAdvance; -def : ReadAdvance; +def : ReadAdvance; +def : ReadAdvance; def : ReadAdvance; -def : ReadAdvance; def : ReadAdvance; +def : ReadAdvance; def : ReadAdvance; def : ReadAdvance; def : ReadAdvance; diff --git a/llvm/lib/Target/RISCV/RISCVSchedSiFive7.td b/llvm/lib/Target/RISCV/RISCVSchedSiFive7.td --- a/llvm/lib/Target/RISCV/RISCVSchedSiFive7.td +++ b/llvm/lib/Target/RISCV/RISCVSchedSiFive7.td @@ -104,7 +104,7 @@ // Single precision. let Latency = 5 in { -def : WriteRes; +def : WriteRes; def : WriteRes; def : WriteRes; } @@ -120,7 +120,7 @@ // Double precision let Latency = 7 in { -def : WriteRes; +def : WriteRes; def : WriteRes; def : WriteRes; } @@ -190,11 +190,11 @@ def : ReadAdvance; def : ReadAdvance; def : ReadAdvance; -def : ReadAdvance; -def : ReadAdvance; +def : ReadAdvance; +def : ReadAdvance; def : ReadAdvance; -def : ReadAdvance; def : ReadAdvance; +def : ReadAdvance; def : ReadAdvance; def : ReadAdvance; def : ReadAdvance; diff --git a/llvm/lib/Target/RISCV/RISCVSchedule.td b/llvm/lib/Target/RISCV/RISCVSchedule.td --- a/llvm/lib/Target/RISCV/RISCVSchedule.td +++ b/llvm/lib/Target/RISCV/RISCVSchedule.td @@ -38,13 +38,13 @@ def WriteAtomicLDD : SchedWrite; // Atomic load double word def WriteAtomicSTW : SchedWrite; // Atomic store word def WriteAtomicSTD : SchedWrite; // Atomic store double word -def WriteFALU16 : SchedWrite; // FP 16-bit computation -def WriteFALU32 : SchedWrite; // FP 32-bit computation -def WriteFALU64 : SchedWrite; // FP 64-bit computation +def WriteFAdd16 : SchedWrite; // 16-bit floating point addition/subtraction def WriteFMul16 : SchedWrite; // 16-bit floating point multiply def WriteFMA16 : SchedWrite; // 16-bit floating point fused multiply-add +def WriteFAdd32 : SchedWrite; // 32-bit floating point addition/subtraction def WriteFMul32 : SchedWrite; // 32-bit floating point multiply def WriteFMA32 : SchedWrite; // 32-bit floating point fused multiply-add +def WriteFAdd64 : SchedWrite; // 64-bit floating point addition/subtraction def WriteFMul64 : SchedWrite; // 64-bit floating point multiply def WriteFMA64 : SchedWrite; // 64-bit floating point fused multiply-add def WriteFDiv16 : SchedWrite; // 16-bit floating point divide @@ -131,13 +131,13 @@ def ReadAtomicLDD : SchedRead; // Atomic load double word def ReadAtomicSTW : SchedRead; // Atomic store word def ReadAtomicSTD : SchedRead; // Atomic store double word -def ReadFALU16 : SchedRead; // FP 16-bit computation -def ReadFALU32 : SchedRead; // FP 32-bit computation -def ReadFALU64 : SchedRead; // FP 64-bit computation +def ReadFAdd16 : SchedRead; // 16-bit floating point addition/subtraction def ReadFMul16 : SchedRead; // 16-bit floating point multiply def ReadFMA16 : SchedRead; // 16-bit floating point fused multiply-add +def ReadFAdd32 : SchedRead; // 32-bit floating point addition/subtraction def ReadFMul32 : SchedRead; // 32-bit floating point multiply def ReadFMA32 : SchedRead; // 32-bit floating point fused multiply-add +def ReadFAdd64 : SchedRead; // 64-bit floating point addition/subtraction def ReadFMul64 : SchedRead; // 64-bit floating point multiply def ReadFMA64 : SchedRead; // 64-bit floating point fused multiply-add def ReadFDiv16 : SchedRead; // 16-bit floating point divide @@ -185,7 +185,7 @@ multiclass UnsupportedSchedZfh { let Unsupported = true in { -def : WriteRes; +def : WriteRes; def : WriteRes; def : WriteRes; def : WriteRes; @@ -207,7 +207,7 @@ def : WriteRes; def : WriteRes; -def : ReadAdvance; +def : ReadAdvance; def : ReadAdvance; def : ReadAdvance; def : ReadAdvance;