diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-06-03 15:20:48 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-06-03 15:20:48 +0000 | 
| commit | 551c698530debaae81139c7c76a29fb762793362 (patch) | |
| tree | 547e0e59163c33f2142998714eb5f957e65d1a57 /lib/AST/ItaniumMangle.cpp | |
| parent | 416ada0f75bab22b084a1776deb229cd4a669c4d (diff) | |
Diffstat (limited to 'lib/AST/ItaniumMangle.cpp')
| -rw-r--r-- | lib/AST/ItaniumMangle.cpp | 23 | 
1 files changed, 17 insertions, 6 deletions
| diff --git a/lib/AST/ItaniumMangle.cpp b/lib/AST/ItaniumMangle.cpp index 7db0b4d8e4ff..c9bb45a37eb5 100644 --- a/lib/AST/ItaniumMangle.cpp +++ b/lib/AST/ItaniumMangle.cpp @@ -1459,8 +1459,6 @@ void CXXNameMangler::mangleNestedName(const NamedDecl *ND,      // We do not consider restrict a distinguishing attribute for overloading      // purposes so we must not mangle it.      MethodQuals.removeRestrict(); -    // __unaligned is not currently mangled in any way, so remove it. -    MethodQuals.removeUnaligned();      mangleQualifiers(MethodQuals);      mangleRefQualifier(Method->getRefQualifier());    } @@ -2140,7 +2138,8 @@ CXXNameMangler::mangleOperatorName(OverloadedOperatorKind OO, unsigned Arity) {  }  void CXXNameMangler::mangleQualifiers(Qualifiers Quals) { -  // Vendor qualifiers come first. +  // Vendor qualifiers come first and if they are order-insensitive they must +  // be emitted in reversed alphabetical order, see Itanium ABI 5.1.5.    // Address space qualifiers start with an ordinary letter.    if (Quals.hasAddressSpace()) { @@ -2176,17 +2175,28 @@ void CXXNameMangler::mangleQualifiers(Qualifiers Quals) {    }    // The ARC ownership qualifiers start with underscores. -  switch (Quals.getObjCLifetime()) {    // Objective-C ARC Extension:    //    //   <type> ::= U "__strong"    //   <type> ::= U "__weak"    //   <type> ::= U "__autoreleasing" +  // +  // Note: we emit __weak first to preserve the order as +  // required by the Itanium ABI. +  if (Quals.getObjCLifetime() == Qualifiers::OCL_Weak) +    mangleVendorQualifier("__weak"); + +  // __unaligned (from -fms-extensions) +  if (Quals.hasUnaligned()) +    mangleVendorQualifier("__unaligned"); + +  // Remaining ARC ownership qualifiers. +  switch (Quals.getObjCLifetime()) {    case Qualifiers::OCL_None:      break;    case Qualifiers::OCL_Weak: -    mangleVendorQualifier("__weak"); +    // Do nothing as we already handled this case above.      break;    case Qualifiers::OCL_Strong: @@ -3775,6 +3785,7 @@ recurse:      Out << "v1U" << Kind.size() << Kind;    }    // Fall through to mangle the cast itself. +  LLVM_FALLTHROUGH;    case Expr::CStyleCastExprClass:      mangleCastExpression(E, "cv"); @@ -4327,7 +4338,7 @@ bool CXXNameMangler::mangleSubstitution(const NamedDecl *ND) {  /// substitutions.  static bool hasMangledSubstitutionQualifiers(QualType T) {    Qualifiers Qs = T.getQualifiers(); -  return Qs.getCVRQualifiers() || Qs.hasAddressSpace(); +  return Qs.getCVRQualifiers() || Qs.hasAddressSpace() || Qs.hasUnaligned();  }  bool CXXNameMangler::mangleSubstitution(QualType T) { | 
