diff options
author | Reid Kleckner <reid@kleckner.net> | 2013-05-21 13:48:39 +0000 |
---|---|---|
committer | Reid Kleckner <reid@kleckner.net> | 2013-05-21 13:48:39 +0000 |
commit | 52195b74d01520b6bce0f8c08234bf6eb8cfd496 (patch) | |
tree | 162deca74e4b9d1cc878b07f2be194b3df0d9145 | |
parent | 5f11de60f2a95d7a1369797c731a1039c547d37a (diff) |
Reverting r182337, which merged r182266, __declspec(selectany)
Was "Implement __declspec(selectany) under -fms-extensions ..."
git-svn-id: https://llvm.org/svn/llvm-project/cfe/branches/release_33@182381 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/clang/Basic/Attr.td | 4 | ||||
-rw-r--r-- | include/clang/Basic/DiagnosticSemaKinds.td | 2 | ||||
-rw-r--r-- | lib/CodeGen/CodeGenModule.cpp | 8 | ||||
-rw-r--r-- | lib/Sema/SemaDecl.cpp | 9 | ||||
-rw-r--r-- | lib/Sema/SemaDeclAttr.cpp | 13 | ||||
-rw-r--r-- | test/CodeGen/ms-declspecs.c | 5 | ||||
-rw-r--r-- | test/SemaCXX/attr-selectany.cpp | 33 |
7 files changed, 1 insertions, 73 deletions
diff --git a/include/clang/Basic/Attr.td b/include/clang/Basic/Attr.td index 25c9fcb5af..441a79a23b 100644 --- a/include/clang/Basic/Attr.td +++ b/include/clang/Basic/Attr.td @@ -948,10 +948,6 @@ def ForceInline : InheritableAttr { let Spellings = [Keyword<"__forceinline">]; } -def SelectAny : InheritableAttr { - let Spellings = [Declspec<"selectany">]; -} - def Win64 : InheritableAttr { let Spellings = [Keyword<"__w64">]; } diff --git a/include/clang/Basic/DiagnosticSemaKinds.td b/include/clang/Basic/DiagnosticSemaKinds.td index b770c07339..f5345eb8c3 100644 --- a/include/clang/Basic/DiagnosticSemaKinds.td +++ b/include/clang/Basic/DiagnosticSemaKinds.td @@ -1948,8 +1948,6 @@ def warn_weak_identifier_undeclared : Warning< "weak identifier %0 never declared">; def err_attribute_weak_static : Error< "weak declaration cannot have internal linkage">; -def err_attribute_selectany_non_extern_data : Error< - "'selectany' can only be applied to data items with external linkage">; def warn_attribute_weak_import_invalid_on_definition : Warning< "'weak_import' attribute cannot be specified on a definition">, InGroup<IgnoredAttributes>; diff --git a/lib/CodeGen/CodeGenModule.cpp b/lib/CodeGen/CodeGenModule.cpp index b3b05199a5..0b03a3c4b6 100644 --- a/lib/CodeGen/CodeGenModule.cpp +++ b/lib/CodeGen/CodeGenModule.cpp @@ -1900,13 +1900,7 @@ CodeGenModule::GetLLVMLinkageVarDefinition(const VarDecl *D, return llvm::Function::DLLImportLinkage; else if (D->hasAttr<DLLExportAttr>()) return llvm::Function::DLLExportLinkage; - else if (D->hasAttr<SelectAnyAttr>()) { - // selectany symbols are externally visible, so use weak instead of - // linkonce. MSVC optimizes away references to const selectany globals, so - // all definitions should be the same and ODR linkage should be used. - // http://msdn.microsoft.com/en-us/library/5tkz6s71.aspx - return llvm::GlobalVariable::WeakODRLinkage; - } else if (D->hasAttr<WeakAttr>()) { + else if (D->hasAttr<WeakAttr>()) { if (GV->isConstant()) return llvm::GlobalVariable::WeakODRLinkage; else diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index 03e9afc002..e0e8bd646b 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/lib/Sema/SemaDecl.cpp @@ -4638,15 +4638,6 @@ static void checkAttributesAfterMerging(Sema &S, NamedDecl &ND) { ND.dropAttr<WeakRefAttr>(); } } - - // 'selectany' only applies to externally visible varable declarations. - // It does not apply to functions. - if (SelectAnyAttr *Attr = ND.getAttr<SelectAnyAttr>()) { - if (isa<FunctionDecl>(ND) || !ND.isExternallyVisible()) { - S.Diag(Attr->getLocation(), diag::err_attribute_selectany_non_extern_data); - ND.dropAttr<SelectAnyAttr>(); - } - } } /// Given that we are within the definition of the given function, diff --git a/lib/Sema/SemaDeclAttr.cpp b/lib/Sema/SemaDeclAttr.cpp index ddcbafc30a..7b3345a332 100644 --- a/lib/Sema/SemaDeclAttr.cpp +++ b/lib/Sema/SemaDeclAttr.cpp @@ -4683,16 +4683,6 @@ static void handleForceInlineAttr(Sema &S, Decl *D, const AttributeList &Attr) { S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << Attr.getName(); } -static void handleSelectAnyAttr(Sema &S, Decl *D, const AttributeList &Attr) { - if (!checkMicrosoftExt(S, Attr)) - return; - // Check linkage after possibly merging declaratinos. See - // checkAttributesAfterMerging(). - D->addAttr(::new (S.Context) - SelectAnyAttr(Attr.getRange(), S.Context, - Attr.getAttributeSpellingListIndex())); -} - //===----------------------------------------------------------------------===// // Top Level Sema Entry Points //===----------------------------------------------------------------------===// @@ -4919,9 +4909,6 @@ static void ProcessInheritableDeclAttr(Sema &S, Scope *scope, Decl *D, case AttributeList::AT_ForceInline: handleForceInlineAttr(S, D, Attr); break; - case AttributeList::AT_SelectAny: - handleSelectAnyAttr(S, D, Attr); - break; // Thread safety attributes: case AttributeList::AT_GuardedVar: diff --git a/test/CodeGen/ms-declspecs.c b/test/CodeGen/ms-declspecs.c index 5dc7787b8f..26bdc58ebb 100644 --- a/test/CodeGen/ms-declspecs.c +++ b/test/CodeGen/ms-declspecs.c @@ -1,10 +1,5 @@ // RUN: %clang_cc1 -triple i386-pc-win32 %s -emit-llvm -fms-compatibility -o - | FileCheck %s -__declspec(selectany) int x1 = 1; -const __declspec(selectany) int x2 = 2; -// CHECK: @x1 = weak_odr global i32 1, align 4 -// CHECK: @x2 = weak_odr constant i32 2, align 4 - struct __declspec(align(16)) S { char x; }; diff --git a/test/SemaCXX/attr-selectany.cpp b/test/SemaCXX/attr-selectany.cpp deleted file mode 100644 index 0f9776dbf5..0000000000 --- a/test/SemaCXX/attr-selectany.cpp +++ /dev/null @@ -1,33 +0,0 @@ -// RUN: %clang_cc1 -fms-extensions -fsyntax-only -verify %s -// MSVC produces similar diagnostics. - -__declspec(selectany) void foo() { } // expected-error{{'selectany' can only be applied to data items with external linkage}} - -__declspec(selectany) int x1 = 1; - -const __declspec(selectany) int x2 = 2; // expected-error{{'selectany' can only be applied to data items with external linkage}} - -extern const __declspec(selectany) int x3 = 3; - -extern const int x4; -const __declspec(selectany) int x4 = 4; - -// MSDN says this is incorrect, but MSVC doesn't diagnose it. -extern __declspec(selectany) int x5; - -static __declspec(selectany) int x6 = 2; // expected-error{{'selectany' can only be applied to data items with external linkage}} - -// FIXME: MSVC accepts this and makes x7 externally visible and comdat, but keep -// it as internal and not weak/linkonce. -static int x7; // expected-note{{previous definition}} -extern __declspec(selectany) int x7; // expected-warning{{attribute declaration must precede definition}} - -int asdf() { return x7; } - -class X { - public: - X(int i) { i++; }; - int i; -}; - -__declspec(selectany) X x(1); |