|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| | scope hasn't been set up yet so this isn't valid. It was just a cleanup to the
IR, so I'm going to ignore it for now.
llvm-svn: 107356 | 
| | 
| 
| 
| | llvm-svn: 107320 | 
| | 
| 
| 
| | llvm-svn: 106978 | 
| | 
| 
| 
| 
| 
| 
| 
| | have CGF create and make accessible standard int32,int64 and 
intptr types.  This fixes a ton of 80 column violations 
introduced by LLVMContextification and cleans up stuff a lot.
llvm-svn: 106977 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | load/store nonsense in the epilog.  For example, for:
int foo(int X) {
  int A[100];
  return A[X];
}
we used to generate:
  %arrayidx = getelementptr inbounds [100 x i32]* %A, i32 0, i64 %idxprom ; <i32*> [#uses=1]
  %tmp1 = load i32* %arrayidx                     ; <i32> [#uses=1]
  store i32 %tmp1, i32* %retval
  %0 = load i32* %retval                          ; <i32> [#uses=1]
  ret i32 %0
}
which codegen'd to this code:
_foo:                                   ## @foo
## BB#0:                                ## %entry
	subq	$408, %rsp              ## imm = 0x198
	movl	%edi, 400(%rsp)
	movl	400(%rsp), %edi
	movslq	%edi, %rax
	movl	(%rsp,%rax,4), %edi
	movl	%edi, 404(%rsp)
	movl	404(%rsp), %eax
	addq	$408, %rsp              ## imm = 0x198
	ret
Now we generate:
  %arrayidx = getelementptr inbounds [100 x i32]* %A, i32 0, i64 %idxprom ; <i32*> [#uses=1]
  %tmp1 = load i32* %arrayidx                     ; <i32> [#uses=1]
  ret i32 %tmp1
}
and:
_foo:                                   ## @foo
## BB#0:                                ## %entry
	subq	$408, %rsp              ## imm = 0x198
	movl	%edi, 404(%rsp)
	movl	404(%rsp), %edi
	movslq	%edi, %rax
	movl	(%rsp,%rax,4), %eax
	addq	$408, %rsp              ## imm = 0x198
	ret
This actually does matter, cutting out 2000 lines of IR from CGStmt.ll 
for example.
Another interesting effect is that altivec.h functions which are dead
now get dce'd by the inliner.  Hence all the changes to 
builtins-ppc-altivec.c to ensure the calls aren't dead.
llvm-svn: 106970 | 
| | 
| 
| 
| | llvm-svn: 106618 | 
| | 
| 
| 
| 
| 
| | Elhage!
llvm-svn: 106507 | 
| | 
| 
| 
| 
| 
| | UniqueAggreDestructorCount from CodeGenFunction and let LLVM handle uniquing the internal functions instead.
llvm-svn: 105648 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | variables within blocks. We loosely follow GCC's mangling, but since
these are always internal symbols the names don't really matter. I
intend to revisit block mangling later, because GCC's mangling is
rather verbose. <rdar://problem/8015719>.
llvm-svn: 104610 | 
| | 
| 
| 
| | llvm-svn: 104446 | 
| | 
| 
| 
| | llvm-svn: 104390 | 
| | 
| 
| 
| 
| 
| | setting null data member pointers correctly. Fixes PR7139.
llvm-svn: 104387 | 
| | 
| 
| 
| | llvm-svn: 102891 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | assignment operators. 
Previously, Sema provided type-checking and template instantiation for
copy assignment operators, then CodeGen would synthesize the actual
body of the copy constructor. Unfortunately, the two were not in sync,
and CodeGen might pick a copy-assignment operator that is different
from what Sema chose, leading to strange failures, e.g., link-time
failures when CodeGen called a copy-assignment operator that was not
instantiation, run-time failures when copy-assignment operators were
overloaded for const/non-const references and the wrong one was
picked, and run-time failures when by-value copy-assignment operators
did not have their arguments properly copy-initialized.
This implementation synthesizes the implicitly-defined copy assignment
operator bodies in Sema, so that the resulting ASTs encode exactly
what CodeGen needs to do; there is no longer any special code in
CodeGen to synthesize copy-assignment operators. The synthesis of the
body is relatively simple, and we generate one of three different
kinds of copy statements for each base or member:
  - For a class subobject, call the appropriate copy-assignment
    operator, after overload resolution has determined what that is.
  - For an array of scalar types or an array of class types that have
    trivial copy assignment operators, construct a call to
    __builtin_memcpy.
  - For an array of class types with non-trivial copy assignment
    operators, synthesize a (possibly nested!) for loop whose inner
    statement calls the copy constructor.
  - For a scalar type, use built-in assignment.
This patch fixes at least a few tests cases in Boost.Spirit that were
failing because CodeGen picked the wrong copy-assignment operator
(leading to link-time failures), and I suspect a number of undiagnosed
problems will also go away with this change.
Some of the diagnostics we had previously have gotten worse with this
change, since we're going through generic code for our
type-checking. I will improve this in a subsequent patch.
llvm-svn: 102853 | 
| | 
| 
| 
| | llvm-svn: 101100 | 
| | 
| 
| 
| 
| 
| | field to memcpy, memmove, and memset.
llvm-svn: 100305 | 
| | 
| 
| 
| | llvm-svn: 100200 | 
| | 
| 
| 
| 
| 
| | field to memcpy, memmove, and memset.
llvm-svn: 100193 | 
| | 
| 
| 
| | llvm-svn: 99949 | 
| | 
| 
| 
| 
| 
| | memmove, and memset
llvm-svn: 99930 | 
| | 
| 
| 
| 
| 
| 
| 
| | This introduces FunctionType::ExtInfo to hold the calling convention and the
noreturn attribute. The next patch will extend it to include the regparm
attribute and fix the bug.
llvm-svn: 99920 | 
| | 
| 
| 
| 
| 
| | VTableInfo class.
llvm-svn: 99250 | 
| | 
| 
| 
| 
| 
| 
| 
| | fixing up a few callers that thought they were propagating NoReturn
information but were in fact saying something about exception
specifications.
llvm-svn: 96766 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Fix some bugs with function-try-blocks and simplify normal try-block
code generation.
This implementation excludes a deleting destructor's call to
operator delete() from the function-try-block, which I believe
is correct but which I can't find straightforward support for at
a moment's glance.
llvm-svn: 96670 | 
| | 
| 
| 
| 
| 
| 
| 
| | calling them as subroutines.  This triggers whenever the alias optimization
doesn't, i.e. when the dtor has linkonce linkage or there are virtual bases
or it's the deleting dtor.
llvm-svn: 96605 | 
| | 
| 
| 
| 
| 
| | change.
llvm-svn: 96564 | 
| | 
| 
| 
| 
| 
| 
| 
| | repeatedly reloading from an alloca.  We still need to create the alloca
for debug info purposes (although we currently create it in all cases
because of some abstraction boundaries that're hard to break down).
llvm-svn: 96403 | 
| | 
| 
| 
| | llvm-svn: 96376 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | At the moment the inlinehint attribute is ignored by the Inliner unless you
pass a -respect-inlinehint option.  This will soon be the default.
The inlinehint attribute is set if the inline keyword is explicitly specified
on any declaration.
llvm-svn: 95623 | 
| | 
| 
| 
| | llvm-svn: 95525 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | follows (as conservatively as possible) gcc's current behavior:  attributes
written on return types that don't apply there are applied to the function
instead, etc.  Only parse CC attributes as type attributes, not as decl attributes;
don't accepet noreturn as a decl attribute on ValueDecls, either (it still
needs to apply to other decls, like blocks).  Consistently consume CC/noreturn
information throughout codegen;  enforce this by removing their default values
in CodeGenTypes::getFunctionInfo().
llvm-svn: 95436 | 
| | 
| 
| 
| 
| 
| | BeginConditionalBranch/EndConditionalBranch.
llvm-svn: 95308 | 
| | 
| 
| 
| 
| 
| | some cases.
llvm-svn: 94341 | 
| | 
| 
| 
| 
| 
| | if it matches regular name.
llvm-svn: 93383 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | "ASTContext::getTypeSize() / 8". Replace [u]int64_t variables with CharUnits
ones as appropriate. 
Also rename RawType, fromRaw(), and getRaw() in CharUnits to QuantityType, 
fromQuantity(), and getQuantity() for clarity.
llvm-svn: 93153 | 
| | 
| 
| 
| 
| 
| | aren't yet used in the ctors/dtors, but that will follow.
llvm-svn: 92409 | 
| | 
| 
| 
| 
| 
| | since the context is available in the Decl
llvm-svn: 91862 | 
| | 
| 
| 
| 
| 
| | instead of abort to improve codesize and codegen.
llvm-svn: 91374 | 
| | 
| 
| 
| | llvm-svn: 91341 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This implements a new flag -fcatch-undefined-behavior.  The flag turns
on additional runtime checks for:
  T a[I];
  a[i]    abort when i < 0 or i >= I.
Future stuff includes shifts by >= bitwidth amounts.
llvm-svn: 91198 | 
| | 
| 
| 
| | llvm-svn: 91041 | 
| | 
| 
| 
| | llvm-svn: 90998 | 
| | 
| 
| 
| | llvm-svn: 90940 | 
| | 
| 
| 
| | llvm-svn: 90856 | 
| | 
| 
| 
| | llvm-svn: 90817 | 
| | 
| 
| 
| | llvm-svn: 90622 | 
| | 
| 
| 
| 
| 
| 
| | directly into the sret pointer. This is an optimization in C, but is required
for correctness in C++ for classes with a non-trivial copy constructor.
llvm-svn: 90526 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Highlights include:
  Add a helper to generate __cxa_free_exception and _ZSt9terminatev.
  Add a region to handle EH object deallocation for ctor failures for throw.
  Add a terminate handler for __cxa_end_catch.
  A framework for adding cleanup actions for the exceptional edges only.
llvm-svn: 90305 | 
| | 
| 
| 
| 
| 
| | yet).
llvm-svn: 89835 | 
| | 
| 
| 
| | llvm-svn: 89467 |