mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-25 13:24:46 +00:00
Avoid a Symbol -> Name -> Symbol conversion.
Before this we were producing a TargetExternalSymbol from a MCSymbol. That meant extracting the symbol name and fetching the symbol again down the pipeline. This patch adds a DAG.getMCSymbol that lets the MCSymbol pass unchanged on the DAG. Doing so removes the need for MO_NOPREFIX and fixes the root cause of pr23900, allowing r240130 to be committed again. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@240300 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -1810,6 +1810,21 @@ public:
|
||||
}
|
||||
};
|
||||
|
||||
class MCSymbolSDNode : public SDNode {
|
||||
MCSymbol *Symbol;
|
||||
|
||||
friend class SelectionDAG;
|
||||
MCSymbolSDNode(MCSymbol *Symbol, EVT VT)
|
||||
: SDNode(ISD::MCSymbol, 0, DebugLoc(), getSDVTList(VT)), Symbol(Symbol) {}
|
||||
|
||||
public:
|
||||
MCSymbol *getMCSymbol() const { return Symbol; }
|
||||
|
||||
static bool classof(const SDNode *N) {
|
||||
return N->getOpcode() == ISD::MCSymbol;
|
||||
}
|
||||
};
|
||||
|
||||
class CondCodeSDNode : public SDNode {
|
||||
ISD::CondCode Condition;
|
||||
friend class SelectionDAG;
|
||||
|
Reference in New Issue
Block a user