From 852c346ad24334f6e65b57331cb43f651219d5d8 Mon Sep 17 00:00:00 2001 From: Hans Wennborg Date: Tue, 17 Jun 2014 00:09:05 +0000 Subject: MS static locals mangling: don't double-increment mangling number for switches Differential Revision: http://reviews.llvm.org/D4165 llvm-svn: 211079 --- .../microsoft-abi-static-initializers.cpp | 29 ++++++++++++++++++++++ 1 file changed, 29 insertions(+) (limited to 'clang/test/CodeGenCXX/microsoft-abi-static-initializers.cpp') diff --git a/clang/test/CodeGenCXX/microsoft-abi-static-initializers.cpp b/clang/test/CodeGenCXX/microsoft-abi-static-initializers.cpp index e96a5edd654..b353d0c9c2c 100644 --- a/clang/test/CodeGenCXX/microsoft-abi-static-initializers.cpp +++ b/clang/test/CodeGenCXX/microsoft-abi-static-initializers.cpp @@ -162,12 +162,41 @@ struct T { } }; +inline int switch_test(int x) { + // CHECK-LABEL: define linkonce_odr i32 @"\01?switch_test@@YAHH@Z"(i32 %x) + switch (x) { + static int a; + // CHECK: @"\01?a@?3??switch_test@@YAHH@Z@4HA" + case 0: + a++; + return 1; + case 1: + static int b; + // CHECK: @"\01?b@?3??switch_test@@YAHH@Z@4HA" + return b++; + case 2: { + static int c; + // CHECK: @"\01?c@?4??switch_test@@YAHH@Z@4HA" + return b + c++; + } + }; +} + +int f(); +inline void switch_test2() { + // CHECK-LABEL: define linkonce_odr void @"\01?switch_test2@@YAXXZ"() + // CHECK: @"\01?x@?2??switch_test2@@YAXXZ@4HA" + switch (1) default: static int x = f(); +} + void force_usage() { UnreachableStatic(); getS(); (void)B::foo; // (void) - force usage enum_in_function(); (void)&T::enum_in_struct; + switch_test(1); + switch_test2(); } // CHECK: define linkonce_odr void @"\01??__Efoo@?$B@H@@2VA@@A@YAXXZ"() -- cgit v1.2.3