mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-04 05:17:07 +00:00 
			
		
		
		
	new VariantKind to the MCSymbolExpr seems like overkill, but I'm not sure there's a more straightforward way to get the printing difference captured. (i.e., x86 uses @PLT, ARM uses (PLT)). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@114613 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
//===-- ARMMCInstLower.h - Lower MachineInstr to MCInst -------------------===//
 | 
						|
//
 | 
						|
//                     The LLVM Compiler Infrastructure
 | 
						|
//
 | 
						|
// This file is distributed under the University of Illinois Open Source
 | 
						|
// License. See LICENSE.TXT for details.
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
 | 
						|
#ifndef ARM_MCINSTLOWER_H
 | 
						|
#define ARM_MCINSTLOWER_H
 | 
						|
 | 
						|
#include "llvm/Support/Compiler.h"
 | 
						|
 | 
						|
namespace llvm {
 | 
						|
  class AsmPrinter;
 | 
						|
  class GlobalValue;
 | 
						|
  class MCAsmInfo;
 | 
						|
  class MCContext;
 | 
						|
  class MCInst;
 | 
						|
  class MCOperand;
 | 
						|
  class MCSymbol;
 | 
						|
  class MCSymbolRefExpr;
 | 
						|
  class MachineInstr;
 | 
						|
  class MachineModuleInfoMachO;
 | 
						|
  class MachineOperand;
 | 
						|
  class Mangler;
 | 
						|
  //class ARMSubtarget;
 | 
						|
 | 
						|
/// ARMMCInstLower - This class is used to lower an MachineInstr into an MCInst.
 | 
						|
class LLVM_LIBRARY_VISIBILITY ARMMCInstLower {
 | 
						|
  MCContext &Ctx;
 | 
						|
  Mangler &Mang;
 | 
						|
  AsmPrinter &Printer;
 | 
						|
 | 
						|
  //const ARMSubtarget &getSubtarget() const;
 | 
						|
public:
 | 
						|
  ARMMCInstLower(MCContext &ctx, Mangler &mang, AsmPrinter &printer)
 | 
						|
    : Ctx(ctx), Mang(mang), Printer(printer) {}
 | 
						|
 | 
						|
  void Lower(const MachineInstr *MI, MCInst &OutMI) const;
 | 
						|
 | 
						|
  //MCSymbol *GetPICBaseSymbol() const;
 | 
						|
  MCSymbol *GetGlobalAddressSymbol(const GlobalValue *GV) const;
 | 
						|
  const MCSymbolRefExpr *GetSymbolRef(const MachineOperand &MO) const;
 | 
						|
  const MCSymbolRefExpr *GetExternalSymbolSymbol(const MachineOperand &MO)
 | 
						|
    const;
 | 
						|
  MCSymbol *GetJumpTableSymbol(const MachineOperand &MO) const;
 | 
						|
  MCSymbol *GetConstantPoolIndexSymbol(const MachineOperand &MO) const;
 | 
						|
  MCOperand LowerSymbolRefOperand(const MachineOperand &MO,
 | 
						|
                                  const MCSymbolRefExpr *Expr) const;
 | 
						|
  MCOperand LowerSymbolOperand(const MachineOperand &MO, MCSymbol *Sym) const;
 | 
						|
 | 
						|
/*
 | 
						|
private:
 | 
						|
  MachineModuleInfoMachO &getMachOMMI() const;
 | 
						|
 */
 | 
						|
};
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
#endif
 |