45 lines
1.6 KiB
C++
45 lines
1.6 KiB
C++
//===-- LoongArch.h - Top-level interface for LoongArch ---------*- C++ -*-===//
|
|
//
|
|
// 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 contains the entry points for global functions defined in the LLVM
|
|
// LoongArch back-end.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_LIB_TARGET_LOONGARCH_LOONGARCH_H
|
|
#define LLVM_LIB_TARGET_LOONGARCH_LOONGARCH_H
|
|
|
|
#include "MCTargetDesc/LoongArchBaseInfo.h"
|
|
#include "llvm/Target/TargetMachine.h"
|
|
|
|
namespace llvm {
|
|
class LoongArchTargetMachine;
|
|
class AsmPrinter;
|
|
class FunctionPass;
|
|
class MCInst;
|
|
class MCOperand;
|
|
class MachineInstr;
|
|
class MachineOperand;
|
|
class PassRegistry;
|
|
|
|
bool lowerLoongArchMachineInstrToMCInst(const MachineInstr *MI, MCInst &OutMI,
|
|
AsmPrinter &AP);
|
|
bool lowerLoongArchMachineOperandToMCOperand(const MachineOperand &MO,
|
|
MCOperand &MCOp,
|
|
const AsmPrinter &AP);
|
|
|
|
FunctionPass *createLoongArchISelDag(LoongArchTargetMachine &TM);
|
|
FunctionPass *createLoongArchExpandAtomicPseudoPass();
|
|
void initializeLoongArchExpandAtomicPseudoPass(PassRegistry &);
|
|
|
|
FunctionPass *createLoongArchPreRAExpandPseudoPass();
|
|
void initializeLoongArchPreRAExpandPseudoPass(PassRegistry &);
|
|
} // end namespace llvm
|
|
|
|
#endif // LLVM_LIB_TARGET_LOONGARCH_LOONGARCH_H
|