Author: rsmith Date: Wed Sep 6 22:41:24 2017 New Revision: 312700 URL: http://llvm.org/viewvc/llvm-project?rev=312700&view=rev Log: Fix off-by-one error in block mangling.
This restores the ABI prior to r214699. Modified: cfe/trunk/lib/AST/ItaniumMangle.cpp cfe/trunk/test/CodeGenObjCXX/mangle-blocks.mm Modified: cfe/trunk/lib/AST/ItaniumMangle.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/AST/ItaniumMangle.cpp?rev=312700&r1=312699&r2=312700&view=diff ============================================================================== --- cfe/trunk/lib/AST/ItaniumMangle.cpp (original) +++ cfe/trunk/lib/AST/ItaniumMangle.cpp Wed Sep 6 22:41:24 2017 @@ -1669,6 +1669,10 @@ void CXXNameMangler::mangleUnqualifiedBl // the symbol in question isn't externally visible. if (!Number) Number = Context.getBlockId(Block, false); + else { + // Stored mangling numbers are 1-based. + --Number; + } Out << "Ub"; if (Number > 0) Out << Number - 1; Modified: cfe/trunk/test/CodeGenObjCXX/mangle-blocks.mm URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenObjCXX/mangle-blocks.mm?rev=312700&r1=312699&r2=312700&view=diff ============================================================================== --- cfe/trunk/test/CodeGenObjCXX/mangle-blocks.mm (original) +++ cfe/trunk/test/CodeGenObjCXX/mangle-blocks.mm Wed Sep 6 22:41:24 2017 @@ -1,8 +1,9 @@ // RUN: %clang_cc1 -emit-llvm -fblocks -o - -triple x86_64-apple-darwin10 -fobjc-runtime=macosx-fragile-10.5 %s | FileCheck %s -// CHECK: @_ZZZN26externally_visible_statics1S3fooEiEd_Ub0_E1k = linkonce_odr global i32 0 -// CHECK: @_ZZZN26externally_visible_statics10inlinefuncEvEUb0_E1i = linkonce_odr global i32 0 -// CHECK: @_ZZ26externally_visible_statics1S1xMUb0_E1j = linkonce_odr global i32 0 +// CHECK-DAG: @_ZZZN26externally_visible_statics1S3fooEiEd_Ub_E1k = linkonce_odr global i32 0 +// CHECK-DAG: @_ZZZN26externally_visible_statics10inlinefuncEvEUb_E1i = linkonce_odr global i32 0 +// CHECK-DAG: @_ZZZN26externally_visible_statics10inlinefuncEvEUb0_E1j = linkonce_odr global i32 0 +// CHECK-DAG: @_ZZ26externally_visible_statics1S1xMUb_E1j = linkonce_odr global i32 0 int f(); @@ -68,6 +69,9 @@ namespace externally_visible_statics { ^{ static int i = f(); }(); + ^{ + static int j = f(); + }(); } struct S { int x = ^{ _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits