diff options
Diffstat (limited to 'lib/Target/X86/AsmParser')
| -rw-r--r-- | lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp | 122 | ||||
| -rw-r--r-- | lib/Target/X86/AsmParser/X86AsmInstrumentation.h | 17 | ||||
| -rw-r--r-- | lib/Target/X86/AsmParser/X86AsmParser.cpp | 93 | ||||
| -rw-r--r-- | lib/Target/X86/AsmParser/X86Operand.h | 6 | 
4 files changed, 136 insertions, 102 deletions
| diff --git a/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp b/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp index db29228..f3e6b3f 100644 --- a/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp +++ b/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp @@ -11,21 +11,25 @@  #include "X86AsmInstrumentation.h"  #include "X86Operand.h"  #include "llvm/ADT/StringExtras.h" +#include "llvm/ADT/Triple.h" +#include "llvm/IR/Function.h"  #include "llvm/MC/MCContext.h"  #include "llvm/MC/MCInst.h"  #include "llvm/MC/MCInstBuilder.h" +#include "llvm/MC/MCInstrInfo.h" +#include "llvm/MC/MCParser/MCParsedAsmOperand.h"  #include "llvm/MC/MCStreamer.h"  #include "llvm/MC/MCSubtargetInfo.h" +#include "llvm/MC/MCTargetOptions.h"  #include "llvm/Support/CommandLine.h" -#include "llvm/Support/Compiler.h" -#include "llvm/MC/MCParser/MCParsedAsmOperand.h"  namespace llvm {  namespace { -static cl::opt<bool> ClAsanInstrumentInlineAssembly( -    "asan-instrument-inline-assembly", cl::desc("instrument inline assembly"), -    cl::Hidden, cl::init(false)); +static cl::opt<bool> ClAsanInstrumentAssembly( +    "asan-instrument-assembly", +    cl::desc("instrument assembly with AddressSanitizer checks"), cl::Hidden, +    cl::init(false));  bool IsStackReg(unsigned Reg) {    return Reg == X86::RSP || Reg == X86::ESP || Reg == X86::SP; @@ -38,14 +42,14 @@ std::string FuncName(unsigned AccessSize, bool IsWrite) {  class X86AddressSanitizer : public X86AsmInstrumentation {  public: -  X86AddressSanitizer(MCSubtargetInfo &sti) : STI(sti) {} +  X86AddressSanitizer(const MCSubtargetInfo &STI) : STI(STI) {}    virtual ~X86AddressSanitizer() {}    // X86AsmInstrumentation implementation:    virtual void InstrumentInstruction(        const MCInst &Inst, SmallVectorImpl<MCParsedAsmOperand *> &Operands, -      MCContext &Ctx, MCStreamer &Out) override { -    InstrumentMOV(Inst, Operands, Ctx, Out); +      MCContext &Ctx, const MCInstrInfo &MII, MCStreamer &Out) override { +    InstrumentMOV(Inst, Operands, Ctx, MII, Out);    }    // Should be implemented differently in x86_32 and x86_64 subclasses. @@ -57,13 +61,13 @@ public:                              bool IsWrite, MCContext &Ctx, MCStreamer &Out);    void InstrumentMOV(const MCInst &Inst,                       SmallVectorImpl<MCParsedAsmOperand *> &Operands, -                     MCContext &Ctx, MCStreamer &Out); +                     MCContext &Ctx, const MCInstrInfo &MII, MCStreamer &Out);    void EmitInstruction(MCStreamer &Out, const MCInst &Inst) {      Out.EmitInstruction(Inst, STI);    }  protected: -  MCSubtargetInfo &STI; +  const MCSubtargetInfo &STI;  };  void X86AddressSanitizer::InstrumentMemOperand( @@ -83,68 +87,53 @@ void X86AddressSanitizer::InstrumentMemOperand(  void X86AddressSanitizer::InstrumentMOV(      const MCInst &Inst, SmallVectorImpl<MCParsedAsmOperand *> &Operands, -    MCContext &Ctx, MCStreamer &Out) { +    MCContext &Ctx, const MCInstrInfo &MII, MCStreamer &Out) {    // Access size in bytes.    unsigned AccessSize = 0; -  unsigned long OpIx = Operands.size(); +    switch (Inst.getOpcode()) {    case X86::MOV8mi:    case X86::MOV8mr: -    AccessSize = 1; -    OpIx = 2; -    break;    case X86::MOV8rm:      AccessSize = 1; -    OpIx = 1;      break;    case X86::MOV16mi:    case X86::MOV16mr: -    AccessSize = 2; -    OpIx = 2; -    break;    case X86::MOV16rm:      AccessSize = 2; -    OpIx = 1;      break;    case X86::MOV32mi:    case X86::MOV32mr: -    AccessSize = 4; -    OpIx = 2; -    break;    case X86::MOV32rm:      AccessSize = 4; -    OpIx = 1;      break;    case X86::MOV64mi32:    case X86::MOV64mr: -    AccessSize = 8; -    OpIx = 2; -    break;    case X86::MOV64rm:      AccessSize = 8; -    OpIx = 1;      break;    case X86::MOVAPDmr:    case X86::MOVAPSmr: -    AccessSize = 16; -    OpIx = 2; -    break;    case X86::MOVAPDrm:    case X86::MOVAPSrm:      AccessSize = 16; -    OpIx = 1;      break; -  } -  if (OpIx >= Operands.size()) +  default:      return; +  } -  const bool IsWrite = (OpIx != 1); -  InstrumentMemOperand(Operands[OpIx], AccessSize, IsWrite, Ctx, Out); +  const bool IsWrite = MII.get(Inst.getOpcode()).mayStore(); +  for (unsigned Ix = 0; Ix < Operands.size(); ++Ix) { +    MCParsedAsmOperand *Op = Operands[Ix]; +    if (Op && Op->isMem()) +      InstrumentMemOperand(Op, AccessSize, IsWrite, Ctx, Out); +  }  }  class X86AddressSanitizer32 : public X86AddressSanitizer {  public: -  X86AddressSanitizer32(MCSubtargetInfo &sti) : X86AddressSanitizer(sti) {} +  X86AddressSanitizer32(const MCSubtargetInfo &STI) +      : X86AddressSanitizer(STI) {}    virtual ~X86AddressSanitizer32() {}    virtual void InstrumentMemOperandImpl(X86Operand *Op, unsigned AccessSize, @@ -172,14 +161,14 @@ void X86AddressSanitizer32::InstrumentMemOperandImpl(          MCSymbolRefExpr::Create(FuncSym, MCSymbolRefExpr::VK_PLT, Ctx);      EmitInstruction(Out, MCInstBuilder(X86::CALLpcrel32).addExpr(FuncExpr));    } -  EmitInstruction(Out, MCInstBuilder(X86::ADD32ri).addReg(X86::ESP) -                           .addReg(X86::ESP).addImm(4)); +  EmitInstruction(Out, MCInstBuilder(X86::POP32r).addReg(X86::EAX));    EmitInstruction(Out, MCInstBuilder(X86::POP32r).addReg(X86::EAX));  }  class X86AddressSanitizer64 : public X86AddressSanitizer {  public: -  X86AddressSanitizer64(MCSubtargetInfo &sti) : X86AddressSanitizer(sti) {} +  X86AddressSanitizer64(const MCSubtargetInfo &STI) +      : X86AddressSanitizer(STI) {}    virtual ~X86AddressSanitizer64() {}    virtual void InstrumentMemOperandImpl(X86Operand *Op, unsigned AccessSize, @@ -187,13 +176,26 @@ public:                                          MCStreamer &Out) override;  }; -void X86AddressSanitizer64::InstrumentMemOperandImpl( -    X86Operand *Op, unsigned AccessSize, bool IsWrite, MCContext &Ctx, -    MCStreamer &Out) { +void X86AddressSanitizer64::InstrumentMemOperandImpl(X86Operand *Op, +                                                     unsigned AccessSize, +                                                     bool IsWrite, +                                                     MCContext &Ctx, +                                                     MCStreamer &Out) {    // FIXME: emit .cfi directives for correct stack unwinding. -  // Set %rsp below current red zone (128 bytes wide) -  EmitInstruction(Out, MCInstBuilder(X86::SUB64ri32).addReg(X86::RSP) -                           .addReg(X86::RSP).addImm(128)); + +  // Set %rsp below current red zone (128 bytes wide) using LEA instruction to +  // preserve flags. +  { +    MCInst Inst; +    Inst.setOpcode(X86::LEA64r); +    Inst.addOperand(MCOperand::CreateReg(X86::RSP)); + +    const MCExpr *Disp = MCConstantExpr::Create(-128, Ctx); +    std::unique_ptr<X86Operand> Op( +        X86Operand::CreateMem(0, Disp, X86::RSP, 0, 1, SMLoc(), SMLoc())); +    Op->addMemOperands(Inst, 5); +    EmitInstruction(Out, Inst); +  }    EmitInstruction(Out, MCInstBuilder(X86::PUSH64r).addReg(X86::RDI));    {      MCInst Inst; @@ -210,8 +212,19 @@ void X86AddressSanitizer64::InstrumentMemOperandImpl(      EmitInstruction(Out, MCInstBuilder(X86::CALL64pcrel32).addExpr(FuncExpr));    }    EmitInstruction(Out, MCInstBuilder(X86::POP64r).addReg(X86::RDI)); -  EmitInstruction(Out, MCInstBuilder(X86::ADD64ri32).addReg(X86::RSP) -                           .addReg(X86::RSP).addImm(128)); + +  // Restore old %rsp value. +  { +    MCInst Inst; +    Inst.setOpcode(X86::LEA64r); +    Inst.addOperand(MCOperand::CreateReg(X86::RSP)); + +    const MCExpr *Disp = MCConstantExpr::Create(128, Ctx); +    std::unique_ptr<X86Operand> Op( +        X86Operand::CreateMem(0, Disp, X86::RSP, 0, 1, SMLoc(), SMLoc())); +    Op->addMemOperands(Inst, 5); +    EmitInstruction(Out, Inst); +  }  }  } // End anonymous namespace @@ -221,10 +234,15 @@ X86AsmInstrumentation::~X86AsmInstrumentation() {}  void X86AsmInstrumentation::InstrumentInstruction(      const MCInst &Inst, SmallVectorImpl<MCParsedAsmOperand *> &Operands, -    MCContext &Ctx, MCStreamer &Out) {} - -X86AsmInstrumentation *CreateX86AsmInstrumentation(MCSubtargetInfo &STI) { -  if (ClAsanInstrumentInlineAssembly) { +    MCContext &Ctx, const MCInstrInfo &MII, MCStreamer &Out) {} + +X86AsmInstrumentation * +CreateX86AsmInstrumentation(const MCTargetOptions &MCOptions, +                            const MCContext &Ctx, const MCSubtargetInfo &STI) { +  Triple T(STI.getTargetTriple()); +  const bool hasCompilerRTSupport = T.isOSLinux(); +  if (ClAsanInstrumentAssembly && hasCompilerRTSupport && +      MCOptions.SanitizeAddress) {      if ((STI.getFeatureBits() & X86::Mode32Bit) != 0)        return new X86AddressSanitizer32(STI);      if ((STI.getFeatureBits() & X86::Mode64Bit) != 0) diff --git a/lib/Target/X86/AsmParser/X86AsmInstrumentation.h b/lib/Target/X86/AsmParser/X86AsmInstrumentation.h index c783a78..0369b14 100644 --- a/lib/Target/X86/AsmParser/X86AsmInstrumentation.h +++ b/lib/Target/X86/AsmParser/X86AsmInstrumentation.h @@ -16,13 +16,17 @@ namespace llvm {  class MCContext;  class MCInst; +class MCInstrInfo;  class MCParsedAsmOperand;  class MCStreamer;  class MCSubtargetInfo; +class MCTargetOptions;  class X86AsmInstrumentation; -X86AsmInstrumentation *CreateX86AsmInstrumentation(MCSubtargetInfo &STI); +X86AsmInstrumentation * +CreateX86AsmInstrumentation(const MCTargetOptions &MCOptions, +                            const MCContext &Ctx, const MCSubtargetInfo &STI);  class X86AsmInstrumentation {  public: @@ -32,15 +36,18 @@ public:    // instruction is sent to Out.    virtual void InstrumentInstruction(        const MCInst &Inst, SmallVectorImpl<MCParsedAsmOperand *> &Operands, -      MCContext &Ctx, MCStreamer &Out); +      MCContext &Ctx, +      const MCInstrInfo &MII, +      MCStreamer &Out);  protected:    friend X86AsmInstrumentation * -  CreateX86AsmInstrumentation(MCSubtargetInfo &STI); +  CreateX86AsmInstrumentation(const MCTargetOptions &MCOptions, +                              const MCContext &Ctx, const MCSubtargetInfo &STI);    X86AsmInstrumentation();  }; -}  // End llvm namespace +} // End llvm namespace -#endif  // X86_ASM_INSTRUMENTATION_H +#endif // X86_ASM_INSTRUMENTATION_H diff --git a/lib/Target/X86/AsmParser/X86AsmParser.cpp b/lib/Target/X86/AsmParser/X86AsmParser.cpp index 9eddc74..d3e695e 100644 --- a/lib/Target/X86/AsmParser/X86AsmParser.cpp +++ b/lib/Target/X86/AsmParser/X86AsmParser.cpp @@ -20,6 +20,7 @@  #include "llvm/MC/MCContext.h"  #include "llvm/MC/MCExpr.h"  #include "llvm/MC/MCInst.h" +#include "llvm/MC/MCInstrInfo.h"  #include "llvm/MC/MCParser/MCAsmLexer.h"  #include "llvm/MC/MCParser/MCAsmParser.h"  #include "llvm/MC/MCParser/MCParsedAsmOperand.h" @@ -55,6 +56,7 @@ static const char OpPrecedence[] = {  class X86AsmParser : public MCTargetAsmParser {    MCSubtargetInfo &STI;    MCAsmParser &Parser; +  const MCInstrInfo &MII;    ParseInstructionInfo *InstInfo;    std::unique_ptr<X86AsmInstrumentation> Instrumentation;  private: @@ -257,7 +259,7 @@ private:    public:      IntelExprStateMachine(int64_t imm, bool stoponlbrac, bool addimmprefix) :        State(IES_PLUS), PrevState(IES_ERROR), BaseReg(0), IndexReg(0), TmpReg(0), -      Scale(1), Imm(imm), Sym(0), StopOnLBrac(stoponlbrac), +      Scale(1), Imm(imm), Sym(nullptr), StopOnLBrac(stoponlbrac),        AddImmPrefix(addimmprefix) { Info.clear(); }      unsigned getBaseReg() { return BaseReg; } @@ -618,7 +620,7 @@ private:    X86Operand *ErrorOperand(SMLoc Loc, StringRef Msg) {      Error(Loc, Msg); -    return 0; +    return nullptr;    }    X86Operand *DefaultMemSIOperand(SMLoc Loc); @@ -710,13 +712,17 @@ private:  public:    X86AsmParser(MCSubtargetInfo &sti, MCAsmParser &parser, -               const MCInstrInfo &MII) -      : MCTargetAsmParser(), STI(sti), Parser(parser), InstInfo(0) { +               const MCInstrInfo &mii, +               const MCTargetOptions &Options) +      : MCTargetAsmParser(), STI(sti), Parser(parser), MII(mii), +        InstInfo(nullptr) {      // Initialize the set of available features.      setAvailableFeatures(ComputeAvailableFeatures(STI.getFeatureBits())); -    Instrumentation.reset(CreateX86AsmInstrumentation(STI)); +    Instrumentation.reset( +        CreateX86AsmInstrumentation(Options, Parser.getContext(), STI));    } +    bool ParseRegister(unsigned &RegNo, SMLoc &StartLoc, SMLoc &EndLoc) override;    bool @@ -1173,9 +1179,9 @@ X86Operand *X86AsmParser::ParseIntelBracExpression(unsigned SegReg, SMLoc Start,    // expression.    IntelExprStateMachine SM(ImmDisp, /*StopOnLBrac=*/false, /*AddImmPrefix=*/true);    if (ParseIntelExpression(SM, End)) -    return 0; +    return nullptr; -  const MCExpr *Disp = 0; +  const MCExpr *Disp = nullptr;    if (const MCExpr *Sym = SM.getSym()) {      // A symbolic displacement.      Disp = Sym; @@ -1199,7 +1205,7 @@ X86Operand *X86AsmParser::ParseIntelBracExpression(unsigned SegReg, SMLoc Start,    if (Tok.getString().find('.') != StringRef::npos) {      const MCExpr *NewDisp;      if (ParseIntelDotOperator(Disp, NewDisp)) -      return 0; +      return nullptr;      End = Tok.getEndLoc();      Parser.Lex();  // Eat the field. @@ -1220,7 +1226,7 @@ X86Operand *X86AsmParser::ParseIntelBracExpression(unsigned SegReg, SMLoc Start,      StringRef ErrMsg;      if (CheckBaseRegAndIndexReg(BaseReg, IndexReg, ErrMsg)) {        Error(StartInBrac, ErrMsg); -      return 0; +      return nullptr;      }      return X86Operand::CreateMem(SegReg, Disp, BaseReg, IndexReg, Scale, Start,                                   End, Size); @@ -1237,7 +1243,7 @@ bool X86AsmParser::ParseIntelIdentifier(const MCExpr *&Val,                                          InlineAsmIdentifierInfo &Info,                                          bool IsUnevaluatedOperand, SMLoc &End) {    assert (isParsingInlineAsm() && "Expected to be parsing inline assembly."); -  Val = 0; +  Val = nullptr;    StringRef LineBuf(Identifier.data());    SemaCallback->LookupInlineAsmIdentifier(LineBuf, Info, IsUnevaluatedOperand); @@ -1309,7 +1315,7 @@ X86Operand *X86AsmParser::ParseIntelSegmentOverride(unsigned SegReg,    StringRef Identifier = Tok.getString();    if (ParseIntelIdentifier(Val, Identifier, Info,                             /*Unevaluated=*/false, End)) -    return 0; +    return nullptr;    return CreateMemForInlineAsm(/*SegReg=*/0, Val, /*BaseReg=*/0,/*IndexReg=*/0,                                 /*Scale=*/1, Start, End, Size, Identifier, Info);  } @@ -1337,7 +1343,7 @@ X86Operand *X86AsmParser::ParseIntelMemOperand(int64_t ImmDisp, SMLoc Start,    StringRef Identifier = Tok.getString();    if (ParseIntelIdentifier(Val, Identifier, Info,                             /*Unevaluated=*/false, End)) -    return 0; +    return nullptr;    if (!getLexer().is(AsmToken::LBrac))      return CreateMemForInlineAsm(/*SegReg=*/0, Val, /*BaseReg=*/0, /*IndexReg=*/0, @@ -1349,19 +1355,19 @@ X86Operand *X86AsmParser::ParseIntelMemOperand(int64_t ImmDisp, SMLoc Start,    IntelExprStateMachine SM(/*ImmDisp=*/0, /*StopOnLBrac=*/true,                             /*AddImmPrefix=*/false);    if (ParseIntelExpression(SM, End)) -    return 0; +    return nullptr;    if (SM.getSym()) {      Error(Start, "cannot use more than one symbol in memory operand"); -    return 0; +    return nullptr;    }    if (SM.getBaseReg()) {      Error(Start, "cannot use base register with variable reference"); -    return 0; +    return nullptr;    }    if (SM.getIndexReg()) {      Error(Start, "cannot use index register with variable reference"); -    return 0; +    return nullptr;    }    const MCExpr *Disp = MCConstantExpr::Create(SM.getImm(), getContext()); @@ -1430,7 +1436,7 @@ X86Operand *X86AsmParser::ParseIntelOffsetOfOperator() {    StringRef Identifier = Tok.getString();    if (ParseIntelIdentifier(Val, Identifier, Info,                             /*Unevaluated=*/false, End)) -    return 0; +    return nullptr;    // Don't emit the offset operator.    InstInfo->AsmRewrites->push_back(AsmRewrite(AOK_Skip, OffsetOfLoc, 7)); @@ -1461,13 +1467,13 @@ X86Operand *X86AsmParser::ParseIntelOperator(unsigned OpKind) {    SMLoc TypeLoc = Tok.getLoc();    Parser.Lex(); // Eat operator. -  const MCExpr *Val = 0; +  const MCExpr *Val = nullptr;    InlineAsmIdentifierInfo Info;    SMLoc Start = Tok.getLoc(), End;    StringRef Identifier = Tok.getString();    if (ParseIntelIdentifier(Val, Identifier, Info,                             /*Unevaluated=*/true, End)) -    return 0; +    return nullptr;    if (!Info.OpDecl)      return ErrorOperand(Start, "unable to lookup expression"); @@ -1522,7 +1528,7 @@ X86Operand *X86AsmParser::ParseIntelOperand() {      IntelExprStateMachine SM(/*Imm=*/0, /*StopOnLBrac=*/true,                               /*AddImmPrefix=*/false);      if (ParseIntelExpression(SM, End)) -      return 0; +      return nullptr;      int64_t Imm = SM.getImm();      if (isParsingInlineAsm()) { @@ -1580,11 +1586,11 @@ X86Operand *X86AsmParser::ParseATTOperand() {      // Read the register.      unsigned RegNo;      SMLoc Start, End; -    if (ParseRegister(RegNo, Start, End)) return 0; +    if (ParseRegister(RegNo, Start, End)) return nullptr;      if (RegNo == X86::EIZ || RegNo == X86::RIZ) {        Error(Start, "%eiz and %riz can only be used as index registers",              SMRange(Start, End)); -      return 0; +      return nullptr;      }      // If this is a segment register followed by a ':', then this is the start @@ -1601,7 +1607,7 @@ X86Operand *X86AsmParser::ParseATTOperand() {      Parser.Lex();      const MCExpr *Val;      if (getParser().parseExpression(Val, End)) -      return 0; +      return nullptr;      return X86Operand::CreateImm(Val, Start, End);    }    } @@ -1630,7 +1636,7 @@ X86AsmParser::HandleAVX512Operand(SmallVectorImpl<MCParsedAsmOperand*> &Operands            StringSwitch<const char*>(getLexer().getTok().getIdentifier())              .Case("to8",  "{1to8}")              .Case("to16", "{1to16}") -            .Default(0); +            .Default(nullptr);          if (!BroadcastPrimitive)            return !ErrorAndEatStatement(getLexer().getLoc(),                                         "Invalid memory broadcast primitive."); @@ -1685,7 +1691,7 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {    const MCExpr *Disp = MCConstantExpr::Create(0, getParser().getContext());    if (getLexer().isNot(AsmToken::LParen)) {      SMLoc ExprEnd; -    if (getParser().parseExpression(Disp, ExprEnd)) return 0; +    if (getParser().parseExpression(Disp, ExprEnd)) return nullptr;      // After parsing the base expression we could either have a parenthesized      // memory address or not.  If not, return now.  If so, eat the (. @@ -1712,7 +1718,7 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {        // It must be an parenthesized expression, parse it now.        if (getParser().parseParenExpression(Disp, ExprEnd)) -        return 0; +        return nullptr;        // After parsing the base expression we could either have a parenthesized        // memory address or not.  If not, return now.  If so, eat the (. @@ -1736,11 +1742,11 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {    if (getLexer().is(AsmToken::Percent)) {      SMLoc StartLoc, EndLoc;      BaseLoc = Parser.getTok().getLoc(); -    if (ParseRegister(BaseReg, StartLoc, EndLoc)) return 0; +    if (ParseRegister(BaseReg, StartLoc, EndLoc)) return nullptr;      if (BaseReg == X86::EIZ || BaseReg == X86::RIZ) {        Error(StartLoc, "eiz and riz can only be used as index registers",              SMRange(StartLoc, EndLoc)); -      return 0; +      return nullptr;      }    } @@ -1756,7 +1762,7 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {      // like "1(%eax,,1)", the assembler doesn't. Use "eiz" or "riz" for this.      if (getLexer().is(AsmToken::Percent)) {        SMLoc L; -      if (ParseRegister(IndexReg, L, L)) return 0; +      if (ParseRegister(IndexReg, L, L)) return nullptr;        if (getLexer().isNot(AsmToken::RParen)) {          // Parse the scale amount: @@ -1764,7 +1770,7 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {          if (getLexer().isNot(AsmToken::Comma)) {            Error(Parser.getTok().getLoc(),                  "expected comma in scale expression"); -          return 0; +          return nullptr;          }          Parser.Lex(); // Eat the comma. @@ -1774,18 +1780,18 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {            int64_t ScaleVal;            if (getParser().parseAbsoluteExpression(ScaleVal)){              Error(Loc, "expected scale expression"); -            return 0; +            return nullptr;            }            // Validate the scale amount.  	  if (X86MCRegisterClasses[X86::GR16RegClassID].contains(BaseReg) &&                ScaleVal != 1) {              Error(Loc, "scale factor in 16-bit address must be 1"); -            return 0; +            return nullptr;  	  }            if (ScaleVal != 1 && ScaleVal != 2 && ScaleVal != 4 && ScaleVal != 8){              Error(Loc, "scale factor in address must be 1, 2, 4 or 8"); -            return 0; +            return nullptr;            }            Scale = (unsigned)ScaleVal;          } @@ -1797,7 +1803,7 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {        int64_t Value;        if (getParser().parseAbsoluteExpression(Value)) -        return 0; +        return nullptr;        if (Value != 1)          Warning(Loc, "scale factor without index register is ignored"); @@ -1808,7 +1814,7 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {    // Ok, we've eaten the memory operand, verify we have a ')' and eat it too.    if (getLexer().isNot(AsmToken::RParen)) {      Error(Parser.getTok().getLoc(), "unexpected token in memory operand"); -    return 0; +    return nullptr;    }    SMLoc MemEnd = Parser.getTok().getEndLoc();    Parser.Lex(); // Eat the ')'. @@ -1821,18 +1827,18 @@ X86Operand *X86AsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {                           BaseReg != X86::SI && BaseReg != X86::DI)) &&        BaseReg != X86::DX) {      Error(BaseLoc, "invalid 16-bit base register"); -    return 0; +    return nullptr;    }    if (BaseReg == 0 &&        X86MCRegisterClasses[X86::GR16RegClassID].contains(IndexReg)) {      Error(IndexLoc, "16-bit memory operand may not include only index register"); -    return 0; +    return nullptr;    }    StringRef ErrMsg;    if (CheckBaseRegAndIndexReg(BaseReg, IndexReg, ErrMsg)) {      Error(BaseLoc, ErrMsg); -    return 0; +    return nullptr;    }    return X86Operand::CreateMem(SegReg, Disp, BaseReg, IndexReg, Scale, @@ -1851,7 +1857,7 @@ ParseInstruction(ParseInstructionInfo &Info, StringRef Name, SMLoc NameLoc,      PatchedName = PatchedName.substr(0, Name.size()-1);    // FIXME: Hack to recognize cmp<comparison code>{ss,sd,ps,pd}. -  const MCExpr *ExtraImmOp = 0; +  const MCExpr *ExtraImmOp = nullptr;    if ((PatchedName.startswith("cmp") || PatchedName.startswith("vcmp")) &&        (PatchedName.endswith("ss") || PatchedName.endswith("sd") ||         PatchedName.endswith("ps") || PatchedName.endswith("pd"))) { @@ -2070,8 +2076,10 @@ ParseInstruction(ParseInstructionInfo &Info, StringRef Name, SMLoc NameLoc,        (Name == "smov" || Name == "smovb" || Name == "smovw" ||         Name == "smovl" || Name == "smovd" || Name == "smovq"))) {      if (Operands.size() == 1) { -      if (Name == "movsd") +      if (Name == "movsd") { +        delete Operands.back();          Operands.back() = X86Operand::CreateToken("movsl", NameLoc); +      }        if (isParsingIntelSyntax()) {          Operands.push_back(DefaultMemDIOperand(NameLoc));          Operands.push_back(DefaultMemSIOperand(NameLoc)); @@ -2253,7 +2261,8 @@ static const char *getSubtargetFeatureName(unsigned Val);  void X86AsmParser::EmitInstruction(      MCInst &Inst, SmallVectorImpl<MCParsedAsmOperand *> &Operands,      MCStreamer &Out) { -  Instrumentation->InstrumentInstruction(Inst, Operands, getContext(), Out); +  Instrumentation->InstrumentInstruction(Inst, Operands, getContext(), MII, +                                         Out);    Out.EmitInstruction(Inst, STI);  } @@ -2291,7 +2300,7 @@ MatchAndEmitInstruction(SMLoc IDLoc, unsigned &Opcode,          .Case("fstsw",  "fnstsw")          .Case("fstsww", "fnstsw")          .Case("fclex",  "fnclex") -        .Default(0); +        .Default(nullptr);      assert(Repl && "Unknown wait-prefixed instruction");      delete Operands[0];      Operands[0] = X86Operand::CreateToken(Repl, IDLoc); diff --git a/lib/Target/X86/AsmParser/X86Operand.h b/lib/Target/X86/AsmParser/X86Operand.h index 45fe2a9..de3be38 100644 --- a/lib/Target/X86/AsmParser/X86Operand.h +++ b/lib/Target/X86/AsmParser/X86Operand.h @@ -422,7 +422,7 @@ struct X86Operand : public MCParsedAsmOperand {                                 bool AddressOf = false,                                 SMLoc OffsetOfLoc = SMLoc(),                                 StringRef SymName = StringRef(), -                               void *OpDecl = 0) { +                               void *OpDecl = nullptr) {      X86Operand *Res = new X86Operand(Register, StartLoc, EndLoc);      Res->Reg.RegNo = RegNo;      Res->AddressOf = AddressOf; @@ -441,7 +441,7 @@ struct X86Operand : public MCParsedAsmOperand {    /// Create an absolute memory operand.    static X86Operand *CreateMem(const MCExpr *Disp, SMLoc StartLoc, SMLoc EndLoc,                                 unsigned Size = 0, StringRef SymName = StringRef(), -                               void *OpDecl = 0) { +                               void *OpDecl = nullptr) {      X86Operand *Res = new X86Operand(Memory, StartLoc, EndLoc);      Res->Mem.SegReg   = 0;      Res->Mem.Disp     = Disp; @@ -461,7 +461,7 @@ struct X86Operand : public MCParsedAsmOperand {                                 unsigned Scale, SMLoc StartLoc, SMLoc EndLoc,                                 unsigned Size = 0,                                 StringRef SymName = StringRef(), -                               void *OpDecl = 0) { +                               void *OpDecl = nullptr) {      // We should never just have a displacement, that should be parsed as an      // absolute memory operand.      assert((SegReg || BaseReg || IndexReg) && "Invalid memory operand!"); | 
