//=- LoongArchISelDAGToDAG.h - A dag to dag inst selector for LoongArch ---===// // // 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 // //===----------------------------------------------------------------------===// // // This file defines an instruction selector for the LoongArch target. // //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_TARGET_LOONGARCH_LOONGARCHISELDAGTODAG_H #define LLVM_LIB_TARGET_LOONGARCH_LOONGARCHISELDAGTODAG_H #include "LoongArch.h" #include "LoongArchTargetMachine.h" #include "llvm/CodeGen/SelectionDAGISel.h" // LoongArch-specific code to select LoongArch machine instructions for // SelectionDAG operations. namespace llvm { class LoongArchDAGToDAGISel : public SelectionDAGISel { const LoongArchSubtarget *Subtarget = nullptr; public: static char ID; LoongArchDAGToDAGISel() = delete; explicit LoongArchDAGToDAGISel(LoongArchTargetMachine &TM) : SelectionDAGISel(ID, TM) {} bool runOnMachineFunction(MachineFunction &MF) override { Subtarget = &MF.getSubtarget(); return SelectionDAGISel::runOnMachineFunction(MF); } void Select(SDNode *Node) override; bool SelectInlineAsmMemoryOperand(const SDValue &Op, InlineAsm::ConstraintCode ConstraintID, std::vector &OutOps) override; bool SelectBaseAddr(SDValue Addr, SDValue &Base); bool SelectAddrConstant(SDValue Addr, SDValue &Base, SDValue &Offset); bool selectNonFIBaseAddr(SDValue Addr, SDValue &Base); bool selectShiftMask(SDValue N, unsigned ShiftWidth, SDValue &ShAmt); bool selectShiftMaskGRLen(SDValue N, SDValue &ShAmt) { return selectShiftMask(N, Subtarget->getGRLen(), ShAmt); } bool selectShiftMask32(SDValue N, SDValue &ShAmt) { return selectShiftMask(N, 32, ShAmt); } bool selectSExti32(SDValue N, SDValue &Val); bool selectZExti32(SDValue N, SDValue &Val); bool selectVSplat(SDNode *N, APInt &Imm, unsigned MinSizeInBits) const; template bool selectVSplatImm(SDValue N, SDValue &SplatVal); bool selectVSplatUimmInvPow2(SDValue N, SDValue &SplatImm) const; bool selectVSplatUimmPow2(SDValue N, SDValue &SplatImm) const; // Include the pieces autogenerated from the target description. #include "LoongArchGenDAGISel.inc" }; } // end namespace llvm #endif // LLVM_LIB_TARGET_LOONGARCH_LOONGARCHISELDAGTODAG_H