|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| | Move the logic for checking self moves into SemaChecking and add that function
to Sema since it is now used in multiple places.
llvm-svn: 225756 | 
| | 
| 
| 
| 
| 
| | the tokens around so we can diagnose an error rather than silently discarding them.
llvm-svn: 225755 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | even though every basic source character literal has the same numerical value
as a narrow or wide character literal.
It appears that the FreeBSD folks are trying to use this macro to mean
something other than what the relevant standards say it means, but their usage
is conforming, so put up with it.
llvm-svn: 225751 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Introduce the following -fsanitize-recover flags:
  - -fsanitize-recover=<list>: Enable recovery for selected checks or
      group of checks. It is forbidden to explicitly list unrecoverable
      sanitizers here (that is, "address", "unreachable", "return").
  - -fno-sanitize-recover=<list>: Disable recovery for selected checks or
     group of checks.
  - -f(no-)?sanitize-recover is now a synonym for
    -f(no-)?sanitize-recover=undefined,integer and will soon be deprecated.
These flags are parsed left to right, and mask of "recoverable"
sanitizer is updated accordingly, much like what we do for -fsanitize= flags.
-fsanitize= and -fsanitize-recover= flag families are independent.
CodeGen change: If there is a single UBSan handler function, responsible
for implementing multiple checks, which have different recoverable setting,
then we emit two handler calls instead of one:
the first one for the set of "unrecoverable" checks, another one - for
set of "recoverable" checks. If all checks implemented by a handler have the
same recoverability setting, then the generated code will be the same.
llvm-svn: 225719 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The llvm IR until recently had no support for comdats. This was a problem when
targeting C++ on ELF/COFF as just using weak linkage would cause quite a bit of
dead bits to remain on the executable (unless -ffunction-sections,
-fdata-sections and --gc-sections were used).
To fix the problem, llvm's codegen will just assume that any weak or linkonce
that is not in an explicit comdat should be output in one with the same name as
the global.
This unfortunately breaks cases like pr19848 where a weak symbol is not
xpected to be part of any comdat.
Now that we have explicit comdats in the IR, we can finally get both cases
right.
This first patch just makes clang give explicit comdats to GlobalValues where
t is allowed to.
A followup patch to llvm will then stop implicitly producing comdats.
llvm-svn: 225705 | 
| | 
| 
| 
| | llvm-svn: 225703 | 
| | 
| 
| 
| | llvm-svn: 225701 | 
| | 
| 
| 
| | llvm-svn: 225684 | 
| | 
| 
| 
| 
| 
| | Thanks for Jeremy for noticing!
llvm-svn: 225666 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | to the Alitivec support in clang. __bool is functionally identical to using bool when declaring vector types. For example:
vector bool char v_bc;
vector __bool char v___bc;
clang already supported vector/__vector and pixel/__pixel but was missing __bool.
http://llvm.org/bugs/show_bug.cgi?id=19220
For reference: https://gcc.gnu.org/onlinedocs/gcc-4.9.2/gcc/PowerPC-AltiVec_002fVSX-Built-in-Functions.html
http://reviews.llvm.org/D6882
llvm-svn: 225664 | 
| | 
| 
| 
| 
| 
| 
| 
| | This just tweaks the fix from r224892 (which handled PCHs) to work with
modules, where we will serialize each method individually and hence the
hasMoreThanOneDecl bit needs to be updated as we add the methods.
llvm-svn: 225659 | 
| | 
| 
| 
| | llvm-svn: 225632 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Reviewers: djasper
Reviewed By: djasper
Subscribers: klimek, cfe-commits
Differential Revision: http://reviews.llvm.org/D6894
llvm-svn: 225628 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Before:
  Constructor()
      : Constructor([] { // comment
        int i;
      }) {}
After:
  Constructor()
      : Constructor([] { // comment
          int i;
        }) {}
llvm-svn: 225625 | 
| | 
| 
| 
| | llvm-svn: 225624 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Specifically, adjust the leading "__asm {" and trailing "}" while still
leaving the assembly inside it alone.
This fixes llvm.org/PR22190.
llvm-svn: 225623 | 
| | 
| 
| 
| 
| 
| 
| 
| | Similar to r225619, use a special EOF token to mark the end of the
exception specification instead of cxx_exceptspec_end.  Use the current
scope as the marker.
llvm-svn: 225622 | 
| | 
| 
| 
| 
| 
| | No functional change intended, just tidy up the parse flow.
llvm-svn: 225620 | 
| | 
| 
| 
| 
| 
| 
| | I added setEofData/getEofData to solve this sort of problem back in
r224505.  Use the Param's decl to tell us if this is *our* EOF token.
llvm-svn: 225619 | 
| | 
| 
| 
| | llvm-svn: 225616 | 
| | 
| 
| 
| 
| 
| 
| 
| | It is not correct to let it consume the cxx_defaultarg_end token.  I'm
starting to wonder if it makes more sense to stop SkipUntil from
consuming such tokens.
llvm-svn: 225615 | 
| | 
| 
| 
| 
| 
| 
| 
| | The rewrite map files are not copied, and so cannot be tracked as temporary
files.  Add them explicitly to the list of files that we request from the user
to be attached to bug reports.
llvm-svn: 225614 | 
| | 
| 
| 
| 
| 
| 
| 
| | Recovery from malformed lambda introducers would find us consuming the
synthetic default argument token, which is bad.  Instead, stop right
before that token.
llvm-svn: 225613 | 
| | 
| 
| 
| 
| 
| 
| | Clang would treat the digits in an "11m" input constraint separately as
if it was handling constraint 1 twice instead of constraint 11.
llvm-svn: 225606 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Input constraints like "0" and "[foo]" should be treated the same when
it comes to their corresponding output constraint.
This fixes PR21850.
llvm-svn: 225605 | 
| | 
| 
| 
| | llvm-svn: 225603 | 
| | 
| 
| 
| 
| 
| | LLVM the consecutive '%' modifiers are redundant, skip them.
llvm-svn: 225602 | 
| | 
| 
| 
| 
| 
| | LLVM the consecutive '&' modifiers are redundant, skip them.
llvm-svn: 225601 | 
| | 
| 
| 
| | llvm-svn: 225600 | 
| | 
| 
| 
| | llvm-svn: 225587 | 
| | 
| 
| 
| 
| 
| | Don't permit '+&m' to make it to CodeGen, it's invalid.
llvm-svn: 225586 | 
| | 
| 
| 
| 
| 
| 
| 
| | -Wself-move is similiar to -Wself-assign.  This warning is triggered when
a value is attempted to be moved to itself.  See r221008 for a bug that
would have been caught with this warning.
llvm-svn: 225581 | 
| | 
| 
| 
| 
| 
| | cast notation T{...} when T is a reference type.
llvm-svn: 225571 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Their linkage can change if they are later explicitly instantiated. We would
previously emit such functions eagerly (as opposed to lazily on first use) if
they have a 'dllexport' or 'used' attribute, and fail an assert when hitting the
explicit instantiation.
This is achieved by replacing the old CodeGenModule::MayDeferGeneration() method
with two new ones: MustBeEmitted() and MayBeEmittedEagerly().
Differential Revision: http://reviews.llvm.org/D6674
llvm-svn: 225570 | 
| | 
| 
| 
| | llvm-svn: 225559 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This reverts commit r225000, r225021, r225083, r225086, r225090.
The root change (r225000) still has several issues where it's caused
calls to be emitted without debug locations. This causes assertion
failures if/when those calls are inlined.
I'll work up some test cases and fixes before recommitting this.
llvm-svn: 225555 | 
| | 
| 
| 
| 
| 
| 
| | It's not safe to blindly call getIdentifierInfo without checking the
token is not an annotation token.
llvm-svn: 225533 | 
| | 
| 
| 
| 
| 
| 
| 
| | It seemed odd to have to make DefaultImageName be a mutable member of Driver.
We don't need to the full result of computeTargetTriple() to determine the
image name; just base it on DefaultTargetTriple.
llvm-svn: 225530 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | We have a diagnostic describing that constexpr changed in C++14 when
compiling in C++11 mode.  While doing this, it examines the previous
declaration and assumes that it is a function.  However it is possible,
in the context of error recovery, for this to not be the case.
llvm-svn: 225518 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Parser::ParseNamespace can get a little confused when it found itself
inside a compound statement inside of a non-static data member
initializer.
Try to determine that the statement expression's scope makes sense
before trying to parse it's contents.
llvm-svn: 225514 | 
| | 
| 
| 
| | llvm-svn: 225513 | 
| | 
| 
| 
| 
| 
| 
| | RecordDecls should have things like CXXMethodDecls or FriendDecls as a
decl but not things like FunctionDecls.
llvm-svn: 225511 | 
| | 
| 
| 
| 
| 
| 
| 
| | We assumed that class-scope specializations would result in a
CXXMethodDecl for that class.  However, globally qualified functions
will result in normal FunctionDecls.
llvm-svn: 225508 | 
| | 
| 
| 
| 
| 
| 
| | The same code is already in Sema::ActOnFunctionDeclarator, the only
caller of CreateNewFunctionDecl.
llvm-svn: 225506 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Sema::CheckParmsForFunctionDef can't cope with a null TypeSourceInfo.
Don't let the AST contain the malformed lambda.
This fixes PR22122.
llvm-svn: 225505 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Allow blessed access to the symbol rewriter from the driver. Although the
symbol rewriter could be invoked through tools like opt and llc, it would not
accessible from the frontend. This allows us to read the rewrite map files in
the frontend rather than the backend and enable symbol rewriting for actually
performing the symbol interpositioning.
llvm-svn: 225504 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | We were previously emitting counter increments even if we didn't have
an insertion point, which would result in a CallInst with no
parent. This leads to a crash, as in pr22166, if we try to do
GlobalDCE.
llvm-svn: 225495 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | We forgot to mark designated initializer expression that contain type
dependent array designators as type dependent.  This would lead to
crashes when we try to determine which array element we were trying to
initialize.
This fixes PR22056.
llvm-svn: 225494 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | we're instantiating, if there's a ParmVarDecl within a FunctionDecl context
that is not a parameter of that function. Add some asserts to catch this kind
of issue more generally, and fix another bug exposed by those asserts where we
were missing a local instantiation scope around substitution of
explicitly-specified template arguments.
llvm-svn: 225490 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | better than the 'template-parameter-x-y' name that we'd get in AST printing,
and is worse in several ways (it's harder to distinguish it from a
user-supplied name, it's wrong after substituting some number of outer
levels, it wastes time and space constructing an IdentifierInfo, ...).
llvm-svn: 225489 |