/// isMem - Is this a memory operand?
virtual bool isMem() const = 0;
+ /// isMSAsmWildcard - Is this a wildcard operand? This is specific to
+ /// MS-style inline assembly and should never happen in normal assembly.
+ virtual bool isMSAsmWildcard() const { return false; }
+
+ /// setMSAsmWildcard - Convert the operand into a wildcard.
+ virtual void setMSAsmWildcard(unsigned Size) { }
+
/// getStartLoc - Get the location of the first token of this operand.
virtual SMLoc getStartLoc() const = 0;
/// getEndLoc - Get the location of the last token of this operand.
Token,
Register,
Immediate,
- Memory
+ Memory,
+ MSAsmWildcard
} Kind;
SMLoc StartLoc, EndLoc;
unsigned Scale;
unsigned Size;
} Mem;
+
+ struct {
+ unsigned Size;
+ } MSAsm;
};
X86Operand(KindTy K, SMLoc Start, SMLoc End)
bool isMem() const { return Kind == Memory; }
bool isMem8() const {
- return Kind == Memory && (!Mem.Size || Mem.Size == 8);
+ return (Kind == Memory && (!Mem.Size || Mem.Size == 8)) ||
+ (Kind == MSAsmWildcard && MSAsm.Size == 8);
}
bool isMem16() const {
- return Kind == Memory && (!Mem.Size || Mem.Size == 16);
+ return (Kind == Memory && (!Mem.Size || Mem.Size == 16)) ||
+ (Kind == MSAsmWildcard && MSAsm.Size == 16);
}
bool isMem32() const {
- return Kind == Memory && (!Mem.Size || Mem.Size == 32);
+ return (Kind == Memory && (!Mem.Size || Mem.Size == 32)) ||
+ (Kind == MSAsmWildcard && MSAsm.Size == 32);
}
bool isMem64() const {
- return Kind == Memory && (!Mem.Size || Mem.Size == 64);
+ return (Kind == Memory && (!Mem.Size || Mem.Size == 64)) ||
+ (Kind == MSAsmWildcard && MSAsm.Size == 64);
}
bool isMem80() const {
- return Kind == Memory && (!Mem.Size || Mem.Size == 80);
+ return (Kind == Memory && (!Mem.Size || Mem.Size == 80)) ||
+ (Kind == MSAsmWildcard && MSAsm.Size == 80);
}
bool isMem128() const {
- return Kind == Memory && (!Mem.Size || Mem.Size == 128);
+ return (Kind == Memory && (!Mem.Size || Mem.Size == 128)) ||
+ (Kind == MSAsmWildcard && MSAsm.Size == 128);
}
bool isMem256() const {
- return Kind == Memory && (!Mem.Size || Mem.Size == 256);
+ return (Kind == Memory && (!Mem.Size || Mem.Size == 256)) ||
+ (Kind == MSAsmWildcard && MSAsm.Size == 256);
}
bool isMemVX32() const {
bool isReg() const { return Kind == Register; }
+ bool isMSAsmWildcard() const { return Kind == MSAsmWildcard; }
+ void setMSAsmWildcard(unsigned Size) {
+ Kind = MSAsmWildcard;
+ this->MSAsm.Size = Size;
+ }
+
void addExpr(MCInst &Inst, const MCExpr *Expr) const {
// Add as immediates when possible.
if (const MCConstantExpr *CE = dyn_cast<MCConstantExpr>(Expr))