зеркало из https://github.com/microsoft/clang-1.git
When compiling with -fno-threadsafe-statics, guard variables for globals with internal linkage don't have to be i64, i8 works just fine!
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@130286 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
6add6fbc59
Коммит
173d51286b
|
@ -1066,10 +1066,18 @@ void ItaniumCXXABI::EmitGuardedInit(CodeGenFunction &CGF,
|
|||
// global initialization is always single-threaded.
|
||||
bool ThreadsafeStatics = (getContext().getLangOptions().ThreadsafeStatics &&
|
||||
D.isLocalVarDecl());
|
||||
|
||||
// Guard variables are 64 bits in the generic ABI and 32 bits on ARM.
|
||||
const llvm::IntegerType *GuardTy
|
||||
= (IsARM ? Builder.getInt32Ty() : Builder.getInt64Ty());
|
||||
|
||||
const llvm::IntegerType *GuardTy;
|
||||
|
||||
// If we have a global variable with internal linkage and thread-safe statics
|
||||
// are disabled, we can just let the guard variable be of type i8.
|
||||
bool UseInt8GuardVariable = !ThreadsafeStatics && GV->hasInternalLinkage();
|
||||
if (UseInt8GuardVariable)
|
||||
GuardTy = Builder.getInt8Ty();
|
||||
else {
|
||||
// Guard variables are 64 bits in the generic ABI and 32 bits on ARM.
|
||||
GuardTy = (IsARM ? Builder.getInt32Ty() : Builder.getInt64Ty());
|
||||
}
|
||||
const llvm::PointerType *GuardPtrTy = GuardTy->getPointerTo();
|
||||
|
||||
// Create the guard variable.
|
||||
|
@ -1100,7 +1108,7 @@ void ItaniumCXXABI::EmitGuardedInit(CodeGenFunction &CGF,
|
|||
// if (__cxa_guard_acquire(&obj_guard))
|
||||
// ...
|
||||
// }
|
||||
if (IsARM) {
|
||||
if (IsARM && !UseInt8GuardVariable) {
|
||||
llvm::Value *V = Builder.CreateLoad(GuardVariable);
|
||||
V = Builder.CreateAnd(V, Builder.getInt32(1));
|
||||
IsInitialized = Builder.CreateIsNull(V, "guard.uninitialized");
|
||||
|
|
|
@ -1,8 +1,11 @@
|
|||
// RUN: %clang_cc1 -emit-llvm -o - %s | FileCheck -check-prefix=WITH-TSS %s
|
||||
// RUN: %clang_cc1 -emit-llvm -o - %s -fno-threadsafe-statics | FileCheck -check-prefix=NO-TSS %s
|
||||
// RUN: %clang_cc1 -emit-llvm -triple=x86_64-apple-darwin10 -o - %s | FileCheck -check-prefix=WITH-TSS %s
|
||||
// RUN: %clang_cc1 -emit-llvm -triple=x86_64-apple-darwin10 -o - %s -fno-threadsafe-statics | FileCheck -check-prefix=NO-TSS %s
|
||||
|
||||
int f();
|
||||
|
||||
// WITH-TSS: @_ZZ1gvE1a = internal global i32 0, align 4
|
||||
// WITH-TSS: @_ZGVZ1gvE1a = internal global i64 0
|
||||
|
||||
// WITH-TSS: define void @_Z1gv() nounwind
|
||||
// WITH-TSS: call i32 @__cxa_guard_acquire
|
||||
// WITH-TSS: call void @__cxa_guard_release
|
||||
|
@ -11,6 +14,9 @@ void g() {
|
|||
static int a = f();
|
||||
}
|
||||
|
||||
// NO-TSS: @_ZZ1gvE1a = internal global i32 0, align 4
|
||||
// NO-TSS: @_ZGVZ1gvE1a = internal global i8 0
|
||||
|
||||
// NO-TSS: define void @_Z1gv() nounwind
|
||||
// NO-TSS-NOT: call i32 @__cxa_guard_acquire
|
||||
// NO-TSS-NOT: call void @__cxa_guard_release
|
||||
|
|
Загрузка…
Ссылка в новой задаче