2020-09-26 04:44:44 +08:00
|
|
|
//===-- RISCVSchedule.td - RISCV Scheduling Definitions ----*- tablegen -*-===//
|
2020-01-24 04:51:04 +08:00
|
|
|
//
|
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
/// Define scheduler resources associated with def operands.
|
|
|
|
def WriteIALU : SchedWrite; // 32 or 64-bit integer ALU operations
|
|
|
|
def WriteIALU32 : SchedWrite; // 32-bit integer ALU operations on RV64I
|
2021-03-20 11:39:48 +08:00
|
|
|
def WriteShiftImm : SchedWrite; // 32 or 64-bit shift by immediate operations
|
|
|
|
def WriteShiftImm32 : SchedWrite; // 32-bit shift by immediate operations on RV64Ix
|
|
|
|
def WriteShiftReg : SchedWrite; // 32 or 64-bit shift by immediate operations
|
|
|
|
def WriteShiftReg32 : SchedWrite; // 32-bit shift by immediate operations on RV64Ix
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteIDiv : SchedWrite; // 32-bit or 64-bit divide and remainder
|
|
|
|
def WriteIDiv32 : SchedWrite; // 32-bit divide and remainder on RV64I
|
|
|
|
def WriteIMul : SchedWrite; // 32-bit or 64-bit multiply
|
|
|
|
def WriteIMul32 : SchedWrite; // 32-bit multiply on RV64I
|
|
|
|
def WriteJmp : SchedWrite; // Jump
|
|
|
|
def WriteJal : SchedWrite; // Jump and link
|
|
|
|
def WriteJalr : SchedWrite; // Jump and link register
|
|
|
|
def WriteJmpReg : SchedWrite; // Jump register
|
|
|
|
def WriteNop : SchedWrite;
|
|
|
|
def WriteLDB : SchedWrite; // Load byte
|
|
|
|
def WriteLDH : SchedWrite; // Load half-word
|
|
|
|
def WriteLDW : SchedWrite; // Load word
|
|
|
|
def WriteLDWU : SchedWrite; // Load word unsigned
|
|
|
|
def WriteLDD : SchedWrite; // Load double-word
|
|
|
|
def WriteCSR : SchedWrite; // CSR instructions
|
|
|
|
def WriteSTB : SchedWrite; // Store byte
|
|
|
|
def WriteSTH : SchedWrite; // Store half-word
|
|
|
|
def WriteSTW : SchedWrite; // Store word
|
|
|
|
def WriteSTD : SchedWrite; // Store double-word
|
|
|
|
def WriteAtomicW : SchedWrite; //Atomic memory operation word size
|
|
|
|
def WriteAtomicD : SchedWrite; //Atomic memory operation double word size
|
|
|
|
def WriteAtomicLDW : SchedWrite; // Atomic load word
|
|
|
|
def WriteAtomicLDD : SchedWrite; // Atomic load double word
|
|
|
|
def WriteAtomicSTW : SchedWrite; // Atomic store word
|
|
|
|
def WriteAtomicSTD : SchedWrite; // Atomic store double word
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFALU16 : SchedWrite; // FP 16-bit computation
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFALU32 : SchedWrite; // FP 32-bit computation
|
|
|
|
def WriteFALU64 : SchedWrite; // FP 64-bit computation
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFMul16 : SchedWrite; // 16-bit floating point multiply
|
2021-03-27 07:37:15 +08:00
|
|
|
def WriteFMA16 : SchedWrite; // 16-bit floating point fused multiply-add
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFMul32 : SchedWrite; // 32-bit floating point multiply
|
2021-03-27 07:37:15 +08:00
|
|
|
def WriteFMA32 : SchedWrite; // 32-bit floating point fused multiply-add
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFMul64 : SchedWrite; // 64-bit floating point multiply
|
2021-03-27 07:37:15 +08:00
|
|
|
def WriteFMA64 : SchedWrite; // 64-bit floating point fused multiply-add
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFDiv16 : SchedWrite; // 16-bit floating point divide
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFDiv32 : SchedWrite; // 32-bit floating point divide
|
|
|
|
def WriteFDiv64 : SchedWrite; // 64-bit floating point divide
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFSqrt16 : SchedWrite; // 16-bit floating point sqrt
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFSqrt32 : SchedWrite; // 32-bit floating point sqrt
|
|
|
|
def WriteFSqrt64 : SchedWrite; // 64-bit floating point sqrt
|
|
|
|
|
|
|
|
// Integer to float conversions
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFCvtI32ToF16 : SchedWrite;
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFCvtI32ToF32 : SchedWrite;
|
|
|
|
def WriteFCvtI32ToF64 : SchedWrite;
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFCvtI64ToF16 : SchedWrite; // RV64I only
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFCvtI64ToF32 : SchedWrite; // RV64I only
|
|
|
|
def WriteFCvtI64ToF64 : SchedWrite; // RV64I only
|
|
|
|
|
|
|
|
//Float to integer conversions
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFCvtF16ToI32 : SchedWrite;
|
|
|
|
def WriteFCvtF16ToI64 : SchedWrite; // RV64I only
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFCvtF32ToI32 : SchedWrite;
|
|
|
|
def WriteFCvtF32ToI64 : SchedWrite; // RV64I only
|
|
|
|
def WriteFCvtF64ToI32 : SchedWrite;
|
|
|
|
def WriteFCvtF64ToI64 : SchedWrite; // RV64I only
|
|
|
|
|
|
|
|
// Float to float conversions
|
|
|
|
def WriteFCvtF32ToF64 : SchedWrite;
|
|
|
|
def WriteFCvtF64ToF32 : SchedWrite;
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFCvtF16ToF32 : SchedWrite;
|
|
|
|
def WriteFCvtF32ToF16 : SchedWrite;
|
|
|
|
def WriteFCvtF16ToF64 : SchedWrite;
|
|
|
|
def WriteFCvtF64ToF16 : SchedWrite;
|
2020-01-24 04:51:04 +08:00
|
|
|
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFClass16 : SchedWrite; // 16-bit floating point classify
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFClass32 : SchedWrite; // 32-bit floating point classify
|
|
|
|
def WriteFClass64 : SchedWrite; // 64-bit floating point classify
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFCmp16 : SchedWrite; // 16-bit floating point compare
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFCmp32 : SchedWrite; // 32-bit floating point compare
|
|
|
|
def WriteFCmp64 : SchedWrite; // 64-bit floating point compare
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFSGNJ16 : SchedWrite; // 16-bit floating point sign-injection
|
2020-02-24 14:21:26 +08:00
|
|
|
def WriteFSGNJ32 : SchedWrite; // 32-bit floating point sign-injection
|
|
|
|
def WriteFSGNJ64 : SchedWrite; // 64-bit floating point sign-injection
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFMinMax16 : SchedWrite; // 16-bit floating point min or max
|
2020-02-24 14:21:26 +08:00
|
|
|
def WriteFMinMax32 : SchedWrite; // 32-bit floating point min or max
|
|
|
|
def WriteFMinMax64 : SchedWrite; // 64-bit floating point min or max
|
2020-01-24 04:51:04 +08:00
|
|
|
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFMovF16ToI16 : SchedWrite;
|
|
|
|
def WriteFMovI16ToF16 : SchedWrite;
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFMovF32ToI32 : SchedWrite;
|
|
|
|
def WriteFMovI32ToF32 : SchedWrite;
|
|
|
|
def WriteFMovF64ToI64 : SchedWrite; // RV64I only
|
|
|
|
def WriteFMovI64ToF64 : SchedWrite; // RV64I only
|
|
|
|
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFLD16 : SchedWrite; // Floating point sp load
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFLD32 : SchedWrite; // Floating point sp load
|
|
|
|
def WriteFLD64 : SchedWrite; // Floating point dp load
|
2021-03-23 11:30:06 +08:00
|
|
|
def WriteFST16 : SchedWrite; // Floating point sp store
|
2020-01-24 04:51:04 +08:00
|
|
|
def WriteFST32 : SchedWrite; // Floating point sp store
|
|
|
|
def WriteFST64 : SchedWrite; // Floating point dp store
|
|
|
|
|
|
|
|
/// Define scheduler resources associated with use operands.
|
|
|
|
def ReadJmp : SchedRead;
|
|
|
|
def ReadJalr : SchedRead;
|
|
|
|
def ReadCSR : SchedRead;
|
|
|
|
def ReadMemBase : SchedRead;
|
2020-02-24 14:21:26 +08:00
|
|
|
def ReadFMemBase : SchedRead;
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadStoreData : SchedRead;
|
|
|
|
def ReadIALU : SchedRead;
|
|
|
|
def ReadIALU32 : SchedRead; // 32-bit integer ALU operations on RV64I
|
2021-03-20 11:39:48 +08:00
|
|
|
def ReadShiftImm : SchedRead;
|
|
|
|
def ReadShiftImm32 : SchedRead; // 32-bit shift by immediate operations on RV64Ix
|
|
|
|
def ReadShiftReg : SchedRead;
|
|
|
|
def ReadShiftReg32 : SchedRead; // 32-bit shift by register operations on RV64Ix
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadIDiv : SchedRead;
|
|
|
|
def ReadIDiv32 : SchedRead;
|
|
|
|
def ReadIMul : SchedRead;
|
|
|
|
def ReadIMul32 : SchedRead;
|
|
|
|
def ReadAtomicWA : SchedRead;
|
|
|
|
def ReadAtomicWD : SchedRead;
|
|
|
|
def ReadAtomicDA : SchedRead;
|
|
|
|
def ReadAtomicDD : SchedRead;
|
|
|
|
def ReadAtomicLDW : SchedRead; // Atomic load word
|
|
|
|
def ReadAtomicLDD : SchedRead; // Atomic load double word
|
|
|
|
def ReadAtomicSTW : SchedRead; // Atomic store word
|
|
|
|
def ReadAtomicSTD : SchedRead; // Atomic store double word
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFALU16 : SchedRead; // FP 16-bit computation
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFALU32 : SchedRead; // FP 32-bit computation
|
|
|
|
def ReadFALU64 : SchedRead; // FP 64-bit computation
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFMul16 : SchedRead; // 16-bit floating point multiply
|
2021-03-27 07:37:15 +08:00
|
|
|
def ReadFMA16 : SchedRead; // 16-bit floating point fused multiply-add
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFMul32 : SchedRead; // 32-bit floating point multiply
|
2021-03-27 07:37:15 +08:00
|
|
|
def ReadFMA32 : SchedRead; // 32-bit floating point fused multiply-add
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFMul64 : SchedRead; // 64-bit floating point multiply
|
2021-03-27 07:37:15 +08:00
|
|
|
def ReadFMA64 : SchedRead; // 64-bit floating point fused multiply-add
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFDiv16 : SchedRead; // 16-bit floating point divide
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFDiv32 : SchedRead; // 32-bit floating point divide
|
|
|
|
def ReadFDiv64 : SchedRead; // 64-bit floating point divide
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFSqrt16 : SchedRead; // 16-bit floating point sqrt
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFSqrt32 : SchedRead; // 32-bit floating point sqrt
|
|
|
|
def ReadFSqrt64 : SchedRead; // 64-bit floating point sqrt
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFCmp16 : SchedRead;
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFCmp32 : SchedRead;
|
|
|
|
def ReadFCmp64 : SchedRead;
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFSGNJ16 : SchedRead;
|
2020-02-24 14:21:26 +08:00
|
|
|
def ReadFSGNJ32 : SchedRead;
|
|
|
|
def ReadFSGNJ64 : SchedRead;
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFMinMax16 : SchedRead;
|
2020-02-24 14:21:26 +08:00
|
|
|
def ReadFMinMax32 : SchedRead;
|
|
|
|
def ReadFMinMax64 : SchedRead;
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFCvtF16ToI32 : SchedRead;
|
|
|
|
def ReadFCvtF16ToI64 : SchedRead;
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFCvtF32ToI32 : SchedRead;
|
|
|
|
def ReadFCvtF32ToI64 : SchedRead;
|
|
|
|
def ReadFCvtF64ToI32 : SchedRead;
|
|
|
|
def ReadFCvtF64ToI64 : SchedRead;
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFCvtI32ToF16 : SchedRead;
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFCvtI32ToF32 : SchedRead;
|
|
|
|
def ReadFCvtI32ToF64 : SchedRead;
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFCvtI64ToF16 : SchedRead;
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFCvtI64ToF32 : SchedRead;
|
|
|
|
def ReadFCvtI64ToF64 : SchedRead;
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFMovF16ToI16 : SchedRead;
|
|
|
|
def ReadFMovI16ToF16 : SchedRead;
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFMovF32ToI32 : SchedRead;
|
|
|
|
def ReadFMovI32ToF32 : SchedRead;
|
|
|
|
def ReadFMovF64ToI64 : SchedRead;
|
|
|
|
def ReadFMovI64ToF64 : SchedRead;
|
|
|
|
def ReadFCvtF32ToF64 : SchedRead;
|
|
|
|
def ReadFCvtF64ToF32 : SchedRead;
|
2021-03-23 11:30:06 +08:00
|
|
|
def ReadFCvtF16ToF32 : SchedRead;
|
|
|
|
def ReadFCvtF32ToF16 : SchedRead;
|
|
|
|
def ReadFCvtF16ToF64 : SchedRead;
|
|
|
|
def ReadFCvtF64ToF16 : SchedRead;
|
|
|
|
def ReadFClass16 : SchedRead;
|
2020-01-24 04:51:04 +08:00
|
|
|
def ReadFClass32 : SchedRead;
|
|
|
|
def ReadFClass64 : SchedRead;
|
2021-03-27 05:15:27 +08:00
|
|
|
|
2021-04-01 06:06:07 +08:00
|
|
|
multiclass UnsupportedSchedZfh {
|
|
|
|
let Unsupported = true in {
|
|
|
|
def : WriteRes<WriteFALU16, []>;
|
|
|
|
def : WriteRes<WriteFClass16, []>;
|
|
|
|
def : WriteRes<WriteFCvtF16ToF64, []>;
|
|
|
|
def : WriteRes<WriteFCvtF64ToF16, []>;
|
|
|
|
def : WriteRes<WriteFCvtI64ToF16, []>;
|
|
|
|
def : WriteRes<WriteFCvtF32ToF16, []>;
|
|
|
|
def : WriteRes<WriteFCvtI32ToF16, []>;
|
|
|
|
def : WriteRes<WriteFCvtF16ToI64, []>;
|
|
|
|
def : WriteRes<WriteFCvtF16ToF32, []>;
|
|
|
|
def : WriteRes<WriteFCvtF16ToI32, []>;
|
|
|
|
def : WriteRes<WriteFDiv16, []>;
|
|
|
|
def : WriteRes<WriteFCmp16, []>;
|
|
|
|
def : WriteRes<WriteFLD16, []>;
|
|
|
|
def : WriteRes<WriteFMA16, []>;
|
|
|
|
def : WriteRes<WriteFMinMax16, []>;
|
|
|
|
def : WriteRes<WriteFMul16, []>;
|
|
|
|
def : WriteRes<WriteFMovI16ToF16, []>;
|
|
|
|
def : WriteRes<WriteFMovF16ToI16, []>;
|
|
|
|
def : WriteRes<WriteFSGNJ16, []>;
|
|
|
|
def : WriteRes<WriteFST16, []>;
|
|
|
|
def : WriteRes<WriteFSqrt16, []>;
|
|
|
|
|
|
|
|
def : ReadAdvance<ReadFALU16, 0>;
|
|
|
|
def : ReadAdvance<ReadFClass16, 0>;
|
|
|
|
def : ReadAdvance<ReadFCvtF16ToF64, 0>;
|
|
|
|
def : ReadAdvance<ReadFCvtF64ToF16, 0>;
|
|
|
|
def : ReadAdvance<ReadFCvtI64ToF16, 0>;
|
|
|
|
def : ReadAdvance<ReadFCvtF32ToF16, 0>;
|
|
|
|
def : ReadAdvance<ReadFCvtI32ToF16, 0>;
|
|
|
|
def : ReadAdvance<ReadFCvtF16ToI64, 0>;
|
|
|
|
def : ReadAdvance<ReadFCvtF16ToF32, 0>;
|
|
|
|
def : ReadAdvance<ReadFCvtF16ToI32, 0>;
|
|
|
|
def : ReadAdvance<ReadFDiv16, 0>;
|
|
|
|
def : ReadAdvance<ReadFCmp16, 0>;
|
|
|
|
def : ReadAdvance<ReadFMA16, 0>;
|
|
|
|
def : ReadAdvance<ReadFMinMax16, 0>;
|
|
|
|
def : ReadAdvance<ReadFMul16, 0>;
|
|
|
|
def : ReadAdvance<ReadFMovI16ToF16, 0>;
|
|
|
|
def : ReadAdvance<ReadFMovF16ToI16, 0>;
|
|
|
|
def : ReadAdvance<ReadFSGNJ16, 0>;
|
|
|
|
def : ReadAdvance<ReadFSqrt16, 0>;
|
|
|
|
} // Unsupported = true
|
|
|
|
}
|
|
|
|
|
2021-03-30 09:02:05 +08:00
|
|
|
// Include the scheduler resources for other instruction extensions.
|
|
|
|
include "RISCVScheduleB.td"
|