|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| | we need to synthesize has been marked as used by Sema.
Change Sema to avoid these asserts.
llvm-svn: 97589 | 
| | 
| 
| 
| 
| 
| | llvm-gcc does, but are more strict on what uses of weakref we accept.
llvm-svn: 96992 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 1) emit base destructors as aliases to their unique base class destructors
under some careful conditions.  This is enabled for the same targets that can
support complete-to-base aliases, i.e. not darwin.
2) Emit non-variadic complete constructors for classes with no virtual bases
as calls to the base constructor.  This is enabled on all targets and in
theory can trigger in situations that the alias optimization can't (mostly
involving virtual bases, mostly not yet supported).
These are bundled together because I didn't think it worthwhile to split them,
not because they really need to be.
llvm-svn: 96842 | 
| | 
| 
| 
| 
| 
| | command-line option which defaults off.
llvm-svn: 96649 | 
| | 
| 
| 
| 
| 
| | some failure here that I can't.
llvm-svn: 96612 | 
| | 
| 
| 
| 
| 
| 
| 
| | and destructors when the two entities are semantically identical, i.e. when
the class has no virtual base classes.  We only do this for linkage types
for which aliases are supported, i.e. internal and external, i.e. not linkonce.
llvm-svn: 96451 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | array allocated using the allocator in ASTContext.  This addresses
these strings getting leaked when using a BumpPtrAllocator (in
ASTContext).
Fixes: <rdar://problem/7636765>
llvm-svn: 95853 | 
| | 
| 
| 
| 
| 
| 
| | The standard actually says that such references should have internal linkage,
but gcc doesn't do that, so we probably can't get away with it.
llvm-svn: 95577 | 
| | 
| 
| 
| 
| 
| 
| 
| | their parent's visibility.
(This is kind of a risky change, but I did a self-host build and everything appears to work fine!)
llvm-svn: 95511 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | over to VarDecl::isThisDeclarationADefinition(), which handles
variables declared with linkage specifications better (among other
things). CMake 2.9 (from CVS) now builds with clang++ and is somewhat
functional.
llvm-svn: 95486 | 
| | 
| 
| 
| 
| 
| | attributes. Fixes PR6245.
llvm-svn: 95474 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that is in an anonymous namespace, give that function or variable
internal linkage.
This change models an oddity of the C++ standard, where names declared
in an anonymous namespace have external linkage but, because anonymous
namespace are really "uniquely-named" namespaces, the names cannot be
referenced from other translation units. That means that they have
external linkage for semantic analysis, but the only sensible
implementation for code generation is to give them internal
linkage. We now model this notion via the UniqueExternalLinkage
linkage type. There are several changes here:
  - Extended NamedDecl::getLinkage() to produce UniqueExternalLinkage
    when the declaration is in an anonymous namespace.
  - Added Type::getLinkage() to determine the linkage of a type, which
    is defined as the minimum linkage of the types (when we're dealing
    with a compound type that is not a struct/class/union).
  - Extended NamedDecl::getLinkage() to consider the linkage of the
    template arguments and template parameters of function template
    specializations and class template specializations.
  - Taught code generation to rely on NamedDecl::getLinkage() when
    determining the linkage of variables and functions, also
    considering the linkage of the types of those variables and
    functions (C++ only). Map UniqueExternalLinkage to internal
    linkage, taking out the explicit checks for
    isInAnonymousNamespace().
This fixes much of PR5792, which, as discovered by Anders Carlsson, is
actually the reason behind the pass-manager assertion that causes the
majority of clang-on-clang regression test failures. With this fix,
Clang-built-Clang+LLVM passes 88% of its regression tests (up from
67%). The specific numbers are:
LLVM:
  Expected Passes    : 4006
  Expected Failures  : 32
  Unsupported Tests  : 40
  Unexpected Failures: 736
Clang:
  Expected Passes    : 1903
  Expected Failures  : 14
  Unexpected Failures: 75
Overall:
  Expected Passes    : 5909
  Expected Failures  : 46
  Unsupported Tests  : 40
  Unexpected Failures: 811
Still to do:
  - Improve testing
  - Check whether we should allow the presence of types with
  InternalLinkage (in addition to UniqueExternalLinkage) given
  variables/functions internal linkage in C++, as mentioned in
  PR5792. 
  - Determine how expensive the getLinkage() calls are in practice;
  consider caching the result in NamedDecl.
  - Assess the feasibility of Chris's idea in comment #1 of PR5792.
llvm-svn: 95216 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | by setting the section of the generated global.  This is an
optimization done by the code generator, and the code being
removed didn't handle the case when the string contained an
embedded nul (which the code generator does correctly 
handle).  This is rdar://7589850
llvm-svn: 95003 | 
| | 
| 
| 
| 
| 
| | definition. With that in mind, rename getDefinition to getAnyInitializer (to distinguish it from getInit) and reimplement it in terms of isThisDeclarationADefinition. Update all code to use this new function.
llvm-svn: 94999 | 
| | 
| 
| 
| 
| 
| 
| | now that the "InBytes" part of the name is implied by the return type, rename
it to getDeclAlign().
llvm-svn: 94681 | 
| | 
| 
| 
| | llvm-svn: 94564 | 
| | 
| 
| 
| | llvm-svn: 94555 | 
| | 
| 
| 
| 
| 
| | of LLVM types in character units.
llvm-svn: 94542 | 
| | 
| 
| 
| 
| 
| | deferred (even if it's in an anonymous namespace).
llvm-svn: 94525 | 
| | 
| 
| 
| 
| 
| | constant Objective-C strings.
llvm-svn: 94274 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | 1. Add helper class for sema checks for target attributes
 2. Add helper class for codegen of target attributes
As a proof-of-concept - implement msp430's 'interrupt' attribute.
llvm-svn: 93118 | 
| | 
| 
| 
| | llvm-svn: 93074 | 
| | 
| 
| 
| 
| 
| 
| | run-time initialization, and emit run-time initializers aggresively to avoid
ordering issues with deferred globals.
llvm-svn: 92976 | 
| | 
| 
| 
| 
| 
| 
| 
| | linkage of vtables. Before this, we were emitting RTTI names for
template instantiations with strong external linkage rather than with
weak ODR linkage.
llvm-svn: 92857 | 
| | 
| 
| 
| 
| 
| | virtual function has a body inlined in the class
llvm-svn: 92855 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - All classes can have a key function; templates don't change that.
  non-template classes when computing the key function.
  - We always mark all of the virtual member functions of class
  template instantiations. 
  - The vtable for an instantiation of a class template has weak
  linkage. 
We could probably use available_externally linkage for vtables of
classes instantiated by explicit instantiation declarations (extern
templates), but GCC doesn't do this and I'm not 100% that the ABI
permits it.
llvm-svn: 92753 | 
| | 
| 
| 
| | llvm-svn: 92749 | 
| | 
| 
| 
| | llvm-svn: 92253 | 
| | 
| 
| 
| 
| 
| | are about to not come in implicitly.
llvm-svn: 92228 | 
| | 
| 
| 
| 
| 
| | LLVM-Code-Symbols test.
llvm-svn: 92152 | 
| | 
| 
| 
| 
| 
| | no extra safety anyway.
llvm-svn: 91207 | 
| | 
| 
| 
| | llvm-svn: 91156 | 
| | 
| 
| 
| | llvm-svn: 91119 | 
| | 
| 
| 
| | llvm-svn: 91069 | 
| | 
| 
| 
| 
| 
| 
| | type of the builtin when generating the function declaration for a builtin
library call.
llvm-svn: 90936 | 
| | 
| 
| 
| | llvm-svn: 90831 | 
| | 
| 
| 
| 
| 
| | (Yes, I do intend to commit some tests for this.)
llvm-svn: 90818 | 
| | 
| 
| 
| 
| 
| 
| | generation, and make sure we generate thunks when the function is defined
rather than when the vtable is defined.
llvm-svn: 90722 | 
| | 
| 
| 
| | llvm-svn: 90711 | 
| | 
| 
| 
| | llvm-svn: 90624 | 
| | 
| 
| 
| 
| 
| | fixing a synthetic ctor/dtor bug.
llvm-svn: 90168 | 
| | 
| 
| 
| 
| 
| | the FE to set NoCommon, and simplify CodeGenOptions initialization.
llvm-svn: 90119 | 
| | 
| 
| 
| 
| 
| 
| 
| | operators, and destructors.  Avoids generating declarations/definitions of
trivial constructors/destructors, and makes sure the trivial copy assignment
operator is generated when necessary.
llvm-svn: 89943 | 
| | 
| 
| 
| 
| 
| | internal linkage.  Fixes PR5433.
llvm-svn: 89931 | 
| | 
| 
| 
| | llvm-svn: 89737 | 
| | 
| 
| 
| 
| 
| 
| 
| | - Sometimes we have to mangle things we wouldn't normally (e.g., because they appear in a template expression).
 - This also tidies up the predicate to be more obvious what is getting mangled.
llvm-svn: 89555 | 
| | 
| 
| 
| 
| 
| 
| | instead of requiring clients to make a raw_svector_ostream, which is just an
implementation detail.
llvm-svn: 89548 | 
| | 
| 
| 
| | llvm-svn: 89547 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The following attributes are currently supported in C++0x attribute
lists (and in GNU ones as well):
 - align() - semantics believed to be conformant to n3000, except for
   redeclarations and what entities it may apply to
 - final - semantics believed to be conformant to CWG issue 817's proposed
   wording, except for redeclarations
 - noreturn - semantics believed to be conformant to n3000, except for
   redeclarations
 - carries_dependency - currently ignored (this is an optimization hint)
llvm-svn: 89543 | 
| | 
| 
| 
| | llvm-svn: 89412 |