123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- //===-- ARMMCTargetDesc.h - ARM Target Descriptions -------------*- 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 provides ARM specific target descriptions.
- //
- //===----------------------------------------------------------------------===//
- #ifndef LLVM_LIB_TARGET_ARM_MCTARGETDESC_ARMMCTARGETDESC_H
- #define LLVM_LIB_TARGET_ARM_MCTARGETDESC_ARMMCTARGETDESC_H
- #include "llvm/Support/DataTypes.h"
- #include "llvm/MC/MCInstrDesc.h"
- #include <memory>
- #include <string>
- namespace llvm {
- class formatted_raw_ostream;
- class MCAsmBackend;
- class MCCodeEmitter;
- class MCContext;
- class MCInstrInfo;
- class MCInstPrinter;
- class MCObjectTargetWriter;
- class MCObjectWriter;
- class MCRegisterInfo;
- class MCSubtargetInfo;
- class MCStreamer;
- class MCTargetOptions;
- class MCRelocationInfo;
- class MCTargetStreamer;
- class StringRef;
- class Target;
- class Triple;
- namespace ARM_MC {
- std::string ParseARMTriple(const Triple &TT, StringRef CPU);
- void initLLVMToCVRegMapping(MCRegisterInfo *MRI);
- bool isPredicated(const MCInst &MI, const MCInstrInfo *MCII);
- bool isCPSRDefined(const MCInst &MI, const MCInstrInfo *MCII);
- template<class Inst>
- bool isLDMBaseRegInList(const Inst &MI) {
- auto BaseReg = MI.getOperand(0).getReg();
- for (unsigned I = 1, E = MI.getNumOperands(); I < E; ++I) {
- const auto &Op = MI.getOperand(I);
- if (Op.isReg() && Op.getReg() == BaseReg)
- return true;
- }
- return false;
- }
- uint64_t evaluateBranchTarget(const MCInstrDesc &InstDesc, uint64_t Addr,
- int64_t Imm);
- /// Create a ARM MCSubtargetInfo instance. This is exposed so Asm parser, etc.
- /// do not need to go through TargetRegistry.
- MCSubtargetInfo *createARMMCSubtargetInfo(const Triple &TT, StringRef CPU,
- StringRef FS);
- }
- MCTargetStreamer *createARMNullTargetStreamer(MCStreamer &S);
- MCTargetStreamer *createARMTargetAsmStreamer(MCStreamer &S,
- formatted_raw_ostream &OS,
- MCInstPrinter *InstPrint,
- bool isVerboseAsm);
- MCTargetStreamer *createARMObjectTargetStreamer(MCStreamer &S,
- const MCSubtargetInfo &STI);
- MCCodeEmitter *createARMLEMCCodeEmitter(const MCInstrInfo &MCII,
- const MCRegisterInfo &MRI,
- MCContext &Ctx);
- MCCodeEmitter *createARMBEMCCodeEmitter(const MCInstrInfo &MCII,
- const MCRegisterInfo &MRI,
- MCContext &Ctx);
- MCAsmBackend *createARMLEAsmBackend(const Target &T, const MCSubtargetInfo &STI,
- const MCRegisterInfo &MRI,
- const MCTargetOptions &Options);
- MCAsmBackend *createARMBEAsmBackend(const Target &T, const MCSubtargetInfo &STI,
- const MCRegisterInfo &MRI,
- const MCTargetOptions &Options);
- // Construct a PE/COFF machine code streamer which will generate a PE/COFF
- // object file.
- MCStreamer *createARMWinCOFFStreamer(MCContext &Context,
- std::unique_ptr<MCAsmBackend> &&MAB,
- std::unique_ptr<MCObjectWriter> &&OW,
- std::unique_ptr<MCCodeEmitter> &&Emitter,
- bool RelaxAll,
- bool IncrementalLinkerCompatible);
- /// Construct an ELF Mach-O object writer.
- std::unique_ptr<MCObjectTargetWriter> createARMELFObjectWriter(uint8_t OSABI);
- /// Construct an ARM Mach-O object writer.
- std::unique_ptr<MCObjectTargetWriter>
- createARMMachObjectWriter(bool Is64Bit, uint32_t CPUType,
- uint32_t CPUSubtype);
- /// Construct an ARM PE/COFF object writer.
- std::unique_ptr<MCObjectTargetWriter>
- createARMWinCOFFObjectWriter();
- /// Construct ARM Mach-O relocation info.
- MCRelocationInfo *createARMMachORelocationInfo(MCContext &Ctx);
- namespace ARM {
- enum OperandType {
- OPERAND_VPRED_R = MCOI::OPERAND_FIRST_TARGET,
- OPERAND_VPRED_N,
- };
- inline bool isVpred(OperandType op) {
- return op == OPERAND_VPRED_R || op == OPERAND_VPRED_N;
- }
- inline bool isVpred(uint8_t op) {
- return isVpred(static_cast<OperandType>(op));
- }
- bool isCDECoproc(size_t Coproc, const MCSubtargetInfo &STI);
- } // end namespace ARM
- } // End llvm namespace
- // Defines symbolic names for ARM registers. This defines a mapping from
- // register name to register number.
- //
- #define GET_REGINFO_ENUM
- #include "ARMGenRegisterInfo.inc"
- // Defines symbolic names for the ARM instructions.
- //
- #define GET_INSTRINFO_ENUM
- #include "ARMGenInstrInfo.inc"
- #define GET_SUBTARGETINFO_ENUM
- #include "ARMGenSubtargetInfo.inc"
- #endif
|