123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- //==-- AArch64Schedule.td - AArch64 Scheduling Definitions -*- tablegen -*-===//
- //
- // 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 TII for use in SchedVariant Predicates.
- // const MachineInstr *MI and const TargetSchedModel *SchedModel
- // are defined by default.
- def : PredicateProlog<[{
- const AArch64InstrInfo *TII =
- static_cast<const AArch64InstrInfo*>(SchedModel->getInstrInfo());
- (void)TII;
- }]>;
- // AArch64 Scheduler Definitions
- def WriteImm : SchedWrite; // MOVN, MOVZ
- // TODO: Provide variants for MOV32/64imm Pseudos that dynamically
- // select the correct sequence of WriteImms.
- def WriteI : SchedWrite; // ALU
- def WriteISReg : SchedWrite; // ALU of Shifted-Reg
- def WriteIEReg : SchedWrite; // ALU of Extended-Reg
- def ReadI : SchedRead; // ALU
- def ReadISReg : SchedRead; // ALU of Shifted-Reg
- def ReadIEReg : SchedRead; // ALU of Extended-Reg
- def WriteExtr : SchedWrite; // EXTR shifts a reg pair
- def ReadExtrHi : SchedRead; // Read the high reg of the EXTR pair
- def WriteIS : SchedWrite; // Shift/Scale
- def WriteID32 : SchedWrite; // 32-bit Divide
- def WriteID64 : SchedWrite; // 64-bit Divide
- def ReadID : SchedRead; // 32/64-bit Divide
- def WriteIM32 : SchedWrite; // 32-bit Multiply
- def WriteIM64 : SchedWrite; // 64-bit Multiply
- def ReadIM : SchedRead; // 32/64-bit Multiply
- def ReadIMA : SchedRead; // 32/64-bit Multiply Accumulate
- def WriteBr : SchedWrite; // Branch
- def WriteBrReg : SchedWrite; // Indirect Branch
- def WriteLD : SchedWrite; // Load from base addr plus immediate offset
- def WriteST : SchedWrite; // Store to base addr plus immediate offset
- def WriteSTP : SchedWrite; // Store a register pair.
- def WriteAdr : SchedWrite; // Address pre/post increment.
- def WriteLDIdx : SchedWrite; // Load from a register index (maybe scaled).
- def WriteSTIdx : SchedWrite; // Store to a register index (maybe scaled).
- def ReadST : SchedRead; // Read the stored value.
- def ReadAdrBase : SchedRead; // Read the base resister of a reg-offset LD/ST.
- // Serialized two-level address load.
- // EXAMPLE: LOADGot
- def WriteLDAdr : WriteSequence<[WriteAdr, WriteLD]>;
- // Serialized two-level address lookup.
- // EXAMPLE: MOVaddr...
- def WriteAdrAdr : WriteSequence<[WriteAdr, WriteAdr]>;
- // The second register of a load-pair.
- // LDP,LDPSW,LDNP,LDXP,LDAXP
- def WriteLDHi : SchedWrite;
- // Store-exclusive is a store followed by a dependent load.
- def WriteSTX : WriteSequence<[WriteST, WriteLD]>;
- def WriteSys : SchedWrite; // Long, variable latency system ops.
- def WriteBarrier : SchedWrite; // Memory barrier.
- def WriteHint : SchedWrite; // Hint instruction.
- def WriteF : SchedWrite; // General floating-point ops.
- def WriteFCmp : SchedWrite; // Floating-point compare.
- def WriteFCvt : SchedWrite; // Float conversion.
- def WriteFCopy : SchedWrite; // Float-int register copy.
- def WriteFImm : SchedWrite; // Floating-point immediate.
- def WriteFMul : SchedWrite; // Floating-point multiply.
- def WriteFDiv : SchedWrite; // Floating-point division.
- def WriteVd : SchedWrite; // 64bit Vector D ops.
- def WriteVq : SchedWrite; // 128bit Vector Q ops.
- def WriteVLD : SchedWrite; // Vector loads.
- def WriteVST : SchedWrite; // Vector stores.
- def WriteAtomic : SchedWrite; // Atomic memory operations (CAS, Swap, LDOP)
- // Read the unwritten lanes of the VLD's destination registers.
- def ReadVLD : SchedRead;
- // Sequential vector load and shuffle.
- def WriteVLDShuffle : WriteSequence<[WriteVLD, WriteVq]>;
- def WriteVLDPairShuffle : WriteSequence<[WriteVLD, WriteVq, WriteVq]>;
- // Store a shuffled vector.
- def WriteVSTShuffle : WriteSequence<[WriteVq, WriteVST]>;
- def WriteVSTPairShuffle : WriteSequence<[WriteVq, WriteVq, WriteVST]>;
|