mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-25 13:24:46 +00:00
switch GC_LABEL to use an MCSymbol operand instead of a label ID operand.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@98474 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -38,12 +38,10 @@
|
||||
#include "llvm/ADT/StringMap.h"
|
||||
|
||||
namespace llvm {
|
||||
|
||||
class AsmPrinter;
|
||||
class GCStrategy;
|
||||
class Constant;
|
||||
class MCAsmInfo;
|
||||
|
||||
class MCSymbol;
|
||||
|
||||
namespace GC {
|
||||
/// PointKind - The type of a collector-safe point.
|
||||
@@ -60,9 +58,9 @@ namespace llvm {
|
||||
///
|
||||
struct GCPoint {
|
||||
GC::PointKind Kind; //< The kind of the safe point.
|
||||
unsigned Num; //< Usually a label.
|
||||
MCSymbol *Label; //< A label.
|
||||
|
||||
GCPoint(GC::PointKind K, unsigned N) : Kind(K), Num(N) {}
|
||||
GCPoint(GC::PointKind K, MCSymbol *L) : Kind(K), Label(L) {}
|
||||
};
|
||||
|
||||
/// GCRoot - Metadata for a pointer to an object managed by the garbage
|
||||
@@ -123,8 +121,8 @@ namespace llvm {
|
||||
/// addSafePoint - Notes the existence of a safe point. Num is the ID of the
|
||||
/// label just prior to the safe point (if the code generator is using
|
||||
/// MachineModuleInfo).
|
||||
void addSafePoint(GC::PointKind Kind, unsigned Num) {
|
||||
SafePoints.push_back(GCPoint(Kind, Num));
|
||||
void addSafePoint(GC::PointKind Kind, MCSymbol *Label) {
|
||||
SafePoints.push_back(GCPoint(Kind, Label));
|
||||
}
|
||||
|
||||
/// getFrameSize/setFrameSize - Records the function's frame size.
|
||||
|
@@ -28,6 +28,7 @@ namespace llvm {
|
||||
|
||||
class GCMetadataPrinter;
|
||||
class raw_ostream;
|
||||
class MCAsmInfo;
|
||||
|
||||
/// GCMetadataPrinterRegistry - The GC assembly printer registry uses all the
|
||||
/// defaults from Registry.
|
||||
|
@@ -1558,9 +1558,7 @@ void AsmPrinter::printLabelInst(const MachineInstr *MI) const {
|
||||
if (MI->getOperand(0).isMCSymbol())
|
||||
Sym = MI->getOperand(0).getMCSymbol();
|
||||
else
|
||||
Sym =
|
||||
OutContext.GetOrCreateTemporarySymbol(Twine(MAI->getPrivateGlobalPrefix()) +
|
||||
"label" + Twine(MI->getOperand(0).getImm()));
|
||||
Sym = MMI->getLabelSym(MI->getOperand(0).getImm());
|
||||
OutStreamer.EmitLabel(Sym);
|
||||
}
|
||||
|
||||
|
@@ -17,6 +17,7 @@
|
||||
#include "llvm/Pass.h"
|
||||
#include "llvm/CodeGen/Passes.h"
|
||||
#include "llvm/Function.h"
|
||||
#include "llvm/MC/MCSymbol.h"
|
||||
#include "llvm/Support/Debug.h"
|
||||
#include "llvm/Support/ErrorHandling.h"
|
||||
#include "llvm/Support/raw_ostream.h"
|
||||
@@ -150,30 +151,31 @@ static const char *DescKind(GC::PointKind Kind) {
|
||||
}
|
||||
|
||||
bool Printer::runOnFunction(Function &F) {
|
||||
if (!F.hasGC()) {
|
||||
GCFunctionInfo *FD = &getAnalysis<GCModuleInfo>().getFunctionInfo(F);
|
||||
if (F.hasGC()) return false;
|
||||
|
||||
GCFunctionInfo *FD = &getAnalysis<GCModuleInfo>().getFunctionInfo(F);
|
||||
|
||||
OS << "GC roots for " << FD->getFunction().getNameStr() << ":\n";
|
||||
for (GCFunctionInfo::roots_iterator RI = FD->roots_begin(),
|
||||
RE = FD->roots_end(); RI != RE; ++RI)
|
||||
OS << "\t" << RI->Num << "\t" << RI->StackOffset << "[sp]\n";
|
||||
|
||||
OS << "GC safe points for " << FD->getFunction().getNameStr() << ":\n";
|
||||
for (GCFunctionInfo::iterator PI = FD->begin(),
|
||||
PE = FD->end(); PI != PE; ++PI) {
|
||||
|
||||
OS << "GC roots for " << FD->getFunction().getNameStr() << ":\n";
|
||||
for (GCFunctionInfo::roots_iterator RI = FD->roots_begin(),
|
||||
RE = FD->roots_end(); RI != RE; ++RI)
|
||||
OS << "\t" << RI->Num << "\t" << RI->StackOffset << "[sp]\n";
|
||||
OS << "\t" << PI->Label->getName() << ": "
|
||||
<< DescKind(PI->Kind) << ", live = {";
|
||||
|
||||
OS << "GC safe points for " << FD->getFunction().getNameStr() << ":\n";
|
||||
for (GCFunctionInfo::iterator PI = FD->begin(),
|
||||
PE = FD->end(); PI != PE; ++PI) {
|
||||
|
||||
OS << "\tlabel " << PI->Num << ": " << DescKind(PI->Kind) << ", live = {";
|
||||
|
||||
for (GCFunctionInfo::live_iterator RI = FD->live_begin(PI),
|
||||
RE = FD->live_end(PI);;) {
|
||||
OS << " " << RI->Num;
|
||||
if (++RI == RE)
|
||||
break;
|
||||
OS << ",";
|
||||
}
|
||||
|
||||
OS << " }\n";
|
||||
for (GCFunctionInfo::live_iterator RI = FD->live_begin(PI),
|
||||
RE = FD->live_end(PI);;) {
|
||||
OS << " " << RI->Num;
|
||||
if (++RI == RE)
|
||||
break;
|
||||
OS << ",";
|
||||
}
|
||||
|
||||
OS << " }\n";
|
||||
}
|
||||
|
||||
return false;
|
||||
|
@@ -12,7 +12,7 @@
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "llvm/CodeGen/GCMetadataPrinter.h"
|
||||
|
||||
class MCAsmInfo;
|
||||
using namespace llvm;
|
||||
|
||||
GCMetadataPrinter::GCMetadataPrinter() { }
|
||||
|
@@ -71,9 +71,9 @@ namespace {
|
||||
|
||||
void FindSafePoints(MachineFunction &MF);
|
||||
void VisitCallPoint(MachineBasicBlock::iterator MI);
|
||||
unsigned InsertLabel(MachineBasicBlock &MBB,
|
||||
MachineBasicBlock::iterator MI,
|
||||
DebugLoc DL) const;
|
||||
MCSymbol *InsertLabel(MachineBasicBlock &MBB,
|
||||
MachineBasicBlock::iterator MI,
|
||||
DebugLoc DL) const;
|
||||
|
||||
void FindStackOffsets(MachineFunction &MF);
|
||||
|
||||
@@ -329,14 +329,11 @@ void MachineCodeAnalysis::getAnalysisUsage(AnalysisUsage &AU) const {
|
||||
AU.addRequired<GCModuleInfo>();
|
||||
}
|
||||
|
||||
unsigned MachineCodeAnalysis::InsertLabel(MachineBasicBlock &MBB,
|
||||
MachineBasicBlock::iterator MI,
|
||||
DebugLoc DL) const {
|
||||
unsigned Label = MMI->NextLabelID();
|
||||
|
||||
BuildMI(MBB, MI, DL,
|
||||
TII->get(TargetOpcode::GC_LABEL)).addImm(Label);
|
||||
|
||||
MCSymbol *MachineCodeAnalysis::InsertLabel(MachineBasicBlock &MBB,
|
||||
MachineBasicBlock::iterator MI,
|
||||
DebugLoc DL) const {
|
||||
MCSymbol *Label = MMI->getLabelSym(MMI->NextLabelID());
|
||||
BuildMI(MBB, MI, DL, TII->get(TargetOpcode::GC_LABEL)).addSym(Label);
|
||||
return Label;
|
||||
}
|
||||
|
||||
|
@@ -603,9 +603,9 @@ void Emitter<CodeEmitter>::emitInstruction(const MachineInstr &MI,
|
||||
llvm_report_error("JIT does not support inline asm!");
|
||||
break;
|
||||
case TargetOpcode::DBG_LABEL:
|
||||
case TargetOpcode::GC_LABEL:
|
||||
MCE.emitLabel(MMI->getLabelSym(MI.getOperand(0).getImm()));
|
||||
break;
|
||||
case TargetOpcode::GC_LABEL:
|
||||
case TargetOpcode::EH_LABEL:
|
||||
MCE.emitLabel(MI.getOperand(0).getMCSymbol());
|
||||
break;
|
||||
|
Reference in New Issue
Block a user