diff options
| -rw-r--r-- | llvm/include/llvm/MC/MCAsmInfo.h | 8 | ||||
| -rw-r--r-- | llvm/include/llvm/MC/MCExpr.h | 11 | ||||
| -rw-r--r-- | llvm/lib/MC/MCAsmInfo.cpp | 1 | ||||
| -rw-r--r-- | llvm/lib/MC/MCExpr.cpp | 10 | ||||
| -rw-r--r-- | llvm/lib/MC/MCParser/AsmParser.cpp | 2 | 
5 files changed, 23 insertions, 9 deletions
| diff --git a/llvm/include/llvm/MC/MCAsmInfo.h b/llvm/include/llvm/MC/MCAsmInfo.h index 658d77cbddf..05da1d1871f 100644 --- a/llvm/include/llvm/MC/MCAsmInfo.h +++ b/llvm/include/llvm/MC/MCAsmInfo.h @@ -339,7 +339,7 @@ protected:    std::vector<MCCFIInstruction> InitialFrameState; -  //===--- Integrated Assembler State ----------------------------------===// +  //===--- Integrated Assembler Information ----------------------------===//    /// Should we use the integrated assembler?    /// The integrated assembler should be enabled by default (by the @@ -351,6 +351,10 @@ protected:    /// Compress DWARF debug sections. Defaults to false.    bool CompressDebugSections; +  /// True if the integrated assembler should interpret 'a >> b' constant +  /// expressions as logical rather than arithmetic. +  bool UseLogicalShr; +  public:    explicit MCAsmInfo();    virtual ~MCAsmInfo(); @@ -538,6 +542,8 @@ public:    void setCompressDebugSections(bool CompressDebugSections) {      this->CompressDebugSections = CompressDebugSections;    } + +  bool shouldUseLogicalShr() const { return UseLogicalShr; }  };  } diff --git a/llvm/include/llvm/MC/MCExpr.h b/llvm/include/llvm/MC/MCExpr.h index d5a68be3ec6..7379f22a048 100644 --- a/llvm/include/llvm/MC/MCExpr.h +++ b/llvm/include/llvm/MC/MCExpr.h @@ -413,7 +413,8 @@ public:      NE,   ///< Inequality comparison.      Or,   ///< Bitwise or.      Shl,  ///< Shift left. -    Shr,  ///< Shift right (arithmetic or logical, depending on target) +    AShr, ///< Arithmetic shift right. +    LShr, ///< Logical shift right.      Sub,  ///< Subtraction.      Xor   ///< Bitwise exclusive or.    }; @@ -491,9 +492,13 @@ public:                                         MCContext &Ctx) {      return Create(Shl, LHS, RHS, Ctx);    } -  static const MCBinaryExpr *CreateShr(const MCExpr *LHS, const MCExpr *RHS, +  static const MCBinaryExpr *CreateAShr(const MCExpr *LHS, const MCExpr *RHS,                                         MCContext &Ctx) { -    return Create(Shr, LHS, RHS, Ctx); +    return Create(AShr, LHS, RHS, Ctx); +  } +  static const MCBinaryExpr *CreateLShr(const MCExpr *LHS, const MCExpr *RHS, +                                       MCContext &Ctx) { +    return Create(LShr, LHS, RHS, Ctx);    }    static const MCBinaryExpr *CreateSub(const MCExpr *LHS, const MCExpr *RHS,                                         MCContext &Ctx) { diff --git a/llvm/lib/MC/MCAsmInfo.cpp b/llvm/lib/MC/MCAsmInfo.cpp index bad257a961b..22de8bd13dc 100644 --- a/llvm/lib/MC/MCAsmInfo.cpp +++ b/llvm/lib/MC/MCAsmInfo.cpp @@ -90,6 +90,7 @@ MCAsmInfo::MCAsmInfo() {    DwarfRegNumForCFI = false;    NeedsDwarfSectionOffsetDirective = false;    UseParensForSymbolVariant = false; +  UseLogicalShr = false;    // FIXME: Clang's logic should be synced with the logic used to initialize    //        this member and the two implementations should be merged. diff --git a/llvm/lib/MC/MCExpr.cpp b/llvm/lib/MC/MCExpr.cpp index 0702539218c..93e49d6441c 100644 --- a/llvm/lib/MC/MCExpr.cpp +++ b/llvm/lib/MC/MCExpr.cpp @@ -89,6 +89,7 @@ void MCExpr::print(raw_ostream &OS) const {        OS <<  '+';        break; +    case MCBinaryExpr::AShr: OS << ">>"; break;      case MCBinaryExpr::And:  OS <<  '&'; break;      case MCBinaryExpr::Div:  OS <<  '/'; break;      case MCBinaryExpr::EQ:   OS << "=="; break; @@ -96,6 +97,7 @@ void MCExpr::print(raw_ostream &OS) const {      case MCBinaryExpr::GTE:  OS << ">="; break;      case MCBinaryExpr::LAnd: OS << "&&"; break;      case MCBinaryExpr::LOr:  OS << "||"; break; +    case MCBinaryExpr::LShr: OS << ">>"; break;      case MCBinaryExpr::LT:   OS <<  '<'; break;      case MCBinaryExpr::LTE:  OS << "<="; break;      case MCBinaryExpr::Mod:  OS <<  '%'; break; @@ -103,7 +105,6 @@ void MCExpr::print(raw_ostream &OS) const {      case MCBinaryExpr::NE:   OS << "!="; break;      case MCBinaryExpr::Or:   OS <<  '|'; break;      case MCBinaryExpr::Shl:  OS << "<<"; break; -    case MCBinaryExpr::Shr:  OS << ">>"; break;      case MCBinaryExpr::Sub:  OS <<  '-'; break;      case MCBinaryExpr::Xor:  OS <<  '^'; break;      } @@ -709,11 +710,12 @@ bool MCExpr::EvaluateAsRelocatableImpl(MCValue &Res, const MCAssembler *Asm,      }      // FIXME: We need target hooks for the evaluation. It may be limited in -    // width, and gas defines the result of comparisons and right shifts -    // differently from Apple as. +    // width, and gas defines the result of comparisons differently from +    // Apple as.      int64_t LHS = LHSValue.getConstant(), RHS = RHSValue.getConstant();      int64_t Result = 0;      switch (ABE->getOpcode()) { +    case MCBinaryExpr::AShr: Result = LHS >> RHS; break;      case MCBinaryExpr::Add:  Result = LHS + RHS; break;      case MCBinaryExpr::And:  Result = LHS & RHS; break;      case MCBinaryExpr::Div:  Result = LHS / RHS; break; @@ -722,6 +724,7 @@ bool MCExpr::EvaluateAsRelocatableImpl(MCValue &Res, const MCAssembler *Asm,      case MCBinaryExpr::GTE:  Result = LHS >= RHS; break;      case MCBinaryExpr::LAnd: Result = LHS && RHS; break;      case MCBinaryExpr::LOr:  Result = LHS || RHS; break; +    case MCBinaryExpr::LShr: Result = uint64_t(LHS) >> uint64_t(RHS); break;      case MCBinaryExpr::LT:   Result = LHS < RHS; break;      case MCBinaryExpr::LTE:  Result = LHS <= RHS; break;      case MCBinaryExpr::Mod:  Result = LHS % RHS; break; @@ -729,7 +732,6 @@ bool MCExpr::EvaluateAsRelocatableImpl(MCValue &Res, const MCAssembler *Asm,      case MCBinaryExpr::NE:   Result = LHS != RHS; break;      case MCBinaryExpr::Or:   Result = LHS | RHS; break;      case MCBinaryExpr::Shl:  Result = LHS << RHS; break; -    case MCBinaryExpr::Shr:  Result = LHS >> RHS; break;      case MCBinaryExpr::Sub:  Result = LHS - RHS; break;      case MCBinaryExpr::Xor:  Result = LHS ^ RHS; break;      } diff --git a/llvm/lib/MC/MCParser/AsmParser.cpp b/llvm/lib/MC/MCParser/AsmParser.cpp index 6f6b28530aa..47da58e385e 100644 --- a/llvm/lib/MC/MCParser/AsmParser.cpp +++ b/llvm/lib/MC/MCParser/AsmParser.cpp @@ -1128,7 +1128,7 @@ unsigned AsmParser::getBinOpPrecedence(AsmToken::TokenKind K,      Kind = MCBinaryExpr::Shl;      return 4;    case AsmToken::GreaterGreater: -    Kind = MCBinaryExpr::Shr; +    Kind = MAI.shouldUseLogicalShr() ? MCBinaryExpr::LShr : MCBinaryExpr::AShr;      return 4;    // High Intermediate Precedence: +, - | 

