Path: blob/main/contrib/llvm-project/llvm/lib/Target/PowerPC/MCTargetDesc/PPCInstPrinter.h
35294 views
//===- PPCInstPrinter.h - Convert PPC MCInst to assembly syntax -*- C++ -*-===//1//2// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.3// See https://llvm.org/LICENSE.txt for license information.4// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception5//6//===----------------------------------------------------------------------===//7//8// This class prints an PPC MCInst to a .s file.9//10//===----------------------------------------------------------------------===//1112#ifndef LLVM_LIB_TARGET_POWERPC_MCTARGETDESC_PPCINSTPRINTER_H13#define LLVM_LIB_TARGET_POWERPC_MCTARGETDESC_PPCINSTPRINTER_H1415#include "llvm/MC/MCInstPrinter.h"16#include "llvm/TargetParser/Triple.h"1718namespace llvm {1920class PPCInstPrinter : public MCInstPrinter {21Triple TT;22private:23bool showRegistersWithPercentPrefix(const char *RegName) const;24bool showRegistersWithPrefix() const;25const char *getVerboseConditionRegName(unsigned RegNum,26unsigned RegEncoding) const;2728public:29PPCInstPrinter(const MCAsmInfo &MAI, const MCInstrInfo &MII,30const MCRegisterInfo &MRI, Triple T)31: MCInstPrinter(MAI, MII, MRI), TT(T) {}3233void printRegName(raw_ostream &OS, MCRegister Reg) const override;34void printInst(const MCInst *MI, uint64_t Address, StringRef Annot,35const MCSubtargetInfo &STI, raw_ostream &O) override;3637// Autogenerated by tblgen.38std::pair<const char *, uint64_t> getMnemonic(const MCInst *MI) override;39void printInstruction(const MCInst *MI, uint64_t Address,40const MCSubtargetInfo &STI, raw_ostream &O);41static const char *getRegisterName(MCRegister Reg);4243bool printAliasInstr(const MCInst *MI, uint64_t Address,44const MCSubtargetInfo &STI, raw_ostream &OS);45void printCustomAliasOperand(const MCInst *MI, uint64_t Address,46unsigned OpIdx, unsigned PrintMethodIdx,47const MCSubtargetInfo &STI, raw_ostream &OS);4849void printOperand(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,50raw_ostream &O);51void printPredicateOperand(const MCInst *MI, unsigned OpNo,52const MCSubtargetInfo &STI, raw_ostream &O,53const char *Modifier = nullptr);54void printATBitsAsHint(const MCInst *MI, unsigned OpNo,55const MCSubtargetInfo &STI, raw_ostream &O);5657void printU1ImmOperand(const MCInst *MI, unsigned OpNo,58const MCSubtargetInfo &STI, raw_ostream &O);59void printU2ImmOperand(const MCInst *MI, unsigned OpNo,60const MCSubtargetInfo &STI, raw_ostream &O);61void printU3ImmOperand(const MCInst *MI, unsigned OpNo,62const MCSubtargetInfo &STI, raw_ostream &O);63void printU4ImmOperand(const MCInst *MI, unsigned OpNo,64const MCSubtargetInfo &STI, raw_ostream &O);65void printS5ImmOperand(const MCInst *MI, unsigned OpNo,66const MCSubtargetInfo &STI, raw_ostream &O);67void printU5ImmOperand(const MCInst *MI, unsigned OpNo,68const MCSubtargetInfo &STI, raw_ostream &O);69void printU6ImmOperand(const MCInst *MI, unsigned OpNo,70const MCSubtargetInfo &STI, raw_ostream &O);71void printU7ImmOperand(const MCInst *MI, unsigned OpNo,72const MCSubtargetInfo &STI, raw_ostream &O);73void printU8ImmOperand(const MCInst *MI, unsigned OpNo,74const MCSubtargetInfo &STI, raw_ostream &O);75void printU10ImmOperand(const MCInst *MI, unsigned OpNo,76const MCSubtargetInfo &STI, raw_ostream &O);77void printU12ImmOperand(const MCInst *MI, unsigned OpNo,78const MCSubtargetInfo &STI, raw_ostream &O);79void printS16ImmOperand(const MCInst *MI, unsigned OpNo,80const MCSubtargetInfo &STI, raw_ostream &O);81void printS34ImmOperand(const MCInst *MI, unsigned OpNo,82const MCSubtargetInfo &STI, raw_ostream &O);83void printU16ImmOperand(const MCInst *MI, unsigned OpNo,84const MCSubtargetInfo &STI, raw_ostream &O);85void printImmZeroOperand(const MCInst *MI, unsigned OpNo,86const MCSubtargetInfo &STI, raw_ostream &O);87void printBranchOperand(const MCInst *MI, uint64_t Address, unsigned OpNo,88const MCSubtargetInfo &STI, raw_ostream &O);89void printAbsBranchOperand(const MCInst *MI, unsigned OpNo,90const MCSubtargetInfo &STI, raw_ostream &O);91void printTLSCall(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,92raw_ostream &O);9394void printcrbitm(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,95raw_ostream &O);9697void printMemRegImm(const MCInst *MI, unsigned OpNo,98const MCSubtargetInfo &STI, raw_ostream &O);99void printMemRegImmHash(const MCInst *MI, unsigned OpNo,100const MCSubtargetInfo &STI, raw_ostream &O);101void printMemRegImm34PCRel(const MCInst *MI, unsigned OpNo,102const MCSubtargetInfo &STI, raw_ostream &O);103void printMemRegImm34(const MCInst *MI, unsigned OpNo,104const MCSubtargetInfo &STI, raw_ostream &O);105void printMemRegReg(const MCInst *MI, unsigned OpNo,106const MCSubtargetInfo &STI, raw_ostream &O);107};108} // end namespace llvm109110#endif111112113