forked from OSchip/llvm-project
add scaffolding for target-specific MCExprs.
llvm-svn: 95559
This commit is contained in:
parent
e77bebc4ba
commit
38d022efe9
|
@ -29,7 +29,8 @@ public:
|
||||||
Binary, ///< Binary expressions.
|
Binary, ///< Binary expressions.
|
||||||
Constant, ///< Constant expressions.
|
Constant, ///< Constant expressions.
|
||||||
SymbolRef, ///< References to labels and assigned expressions.
|
SymbolRef, ///< References to labels and assigned expressions.
|
||||||
Unary ///< Unary expressions.
|
Unary, ///< Unary expressions.
|
||||||
|
Target ///< Target specific expression.
|
||||||
};
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -326,6 +327,28 @@ public:
|
||||||
static bool classof(const MCBinaryExpr *) { return true; }
|
static bool classof(const MCBinaryExpr *) { return true; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// MCTargetExpr - This is an extension point for target-specific MCExpr
|
||||||
|
/// subclasses to implement.
|
||||||
|
///
|
||||||
|
/// NOTE: All subclasses are required to have trivial destructors because
|
||||||
|
/// MCExprs are bump pointer allocated and not destructed.
|
||||||
|
class MCTargetExpr : public MCExpr {
|
||||||
|
virtual ~MCTargetExpr(); // Not accessible.
|
||||||
|
protected:
|
||||||
|
MCTargetExpr() : MCExpr(Target) {}
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
virtual void PrintImpl(raw_ostream &OS) const = 0;
|
||||||
|
virtual bool EvaluateAsRelocatableImpl(MCValue &Res) const = 0;
|
||||||
|
|
||||||
|
|
||||||
|
static bool classof(const MCExpr *E) {
|
||||||
|
return E->getKind() == MCExpr::Target;
|
||||||
|
}
|
||||||
|
static bool classof(const MCTargetExpr *) { return true; }
|
||||||
|
};
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -17,6 +17,8 @@ using namespace llvm;
|
||||||
|
|
||||||
void MCExpr::print(raw_ostream &OS) const {
|
void MCExpr::print(raw_ostream &OS) const {
|
||||||
switch (getKind()) {
|
switch (getKind()) {
|
||||||
|
case MCExpr::Target:
|
||||||
|
return cast<MCTargetExpr>(this)->PrintImpl(OS);
|
||||||
case MCExpr::Constant:
|
case MCExpr::Constant:
|
||||||
OS << cast<MCConstantExpr>(*this).getValue();
|
OS << cast<MCConstantExpr>(*this).getValue();
|
||||||
return;
|
return;
|
||||||
|
@ -131,6 +133,7 @@ const MCSymbolRefExpr *MCSymbolRefExpr::Create(StringRef Name, MCContext &Ctx) {
|
||||||
return Create(Ctx.GetOrCreateSymbol(Name), Ctx);
|
return Create(Ctx.GetOrCreateSymbol(Name), Ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MCTargetExpr::~MCTargetExpr() {}
|
||||||
|
|
||||||
/* *** */
|
/* *** */
|
||||||
|
|
||||||
|
@ -168,6 +171,9 @@ static bool EvaluateSymbolicAdd(const MCValue &LHS, const MCSymbol *RHS_A,
|
||||||
|
|
||||||
bool MCExpr::EvaluateAsRelocatable(MCValue &Res) const {
|
bool MCExpr::EvaluateAsRelocatable(MCValue &Res) const {
|
||||||
switch (getKind()) {
|
switch (getKind()) {
|
||||||
|
case Target:
|
||||||
|
return cast<MCTargetExpr>(this)->EvaluateAsRelocatableImpl(Res);
|
||||||
|
|
||||||
case Constant:
|
case Constant:
|
||||||
Res = MCValue::get(cast<MCConstantExpr>(this)->getValue());
|
Res = MCValue::get(cast<MCConstantExpr>(this)->getValue());
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -87,6 +87,7 @@ public:
|
||||||
|
|
||||||
const MCExpr *AddValueSymbols(const MCExpr *Value) {
|
const MCExpr *AddValueSymbols(const MCExpr *Value) {
|
||||||
switch (Value->getKind()) {
|
switch (Value->getKind()) {
|
||||||
|
case MCExpr::Target: assert(0 && "Can't handle target exprs yet!");
|
||||||
case MCExpr::Constant:
|
case MCExpr::Constant:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue