|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | A [*] is only allowed in a declaration for a function, not in its
definition.  We didn't correctly recurse while looking for it, causing
us to crash in CodeGen instead of rejecting it.
This fixes PR23151.
llvm-svn: 234363 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The zEC12 provides the transactional-execution facility.  This is exposed
to users via a set of builtin routines on other compilers.  This patch
adds clang support to enable those builtins.  In partciular, the patch:
- enables the transactional-execution feature by default on zEC12
- allows to override presence of that feature via the -mhtm/-mno-htm options
- adds a predefined macro __HTM__ if the feature is enabled
- adds support for the transactional-execution GCC builtins
- adds Sema checking to verify the __builtin_tabort abort code
- adds the s390intrin.h header file (for GCC compatibility)
- adds s390 sections to the htmintrin.h and htmxlintrin.h header files
Since this is first use of target-specific intrinsics on the platform,
the patch creates the include/clang/Basic/BuiltinsSystemZ.def file and
hooks it up in TargetBuiltins.h and lib/Basic/Targets.cpp.
An associated LLVM patch adds the required LLVM IR intrinsics.
For reference, the transactional-execution instructions are documented
in the z/Architecture Principles of Operation for the zEC12:
http://publibfp.boulder.ibm.com/cgi-bin/bookmgr/download/DZ9ZR009.pdf
The associated builtins are documented in the GCC manual:
http://gcc.gnu.org/onlinedocs/gcc/S_002f390-System-z-Built-in-Functions.html
The htmxlintrin.h intrinsics provided for compatibility with the IBM XL
compiler are documented in the "z/OS XL C/C++ Programming Guide".
llvm-svn: 233804 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The argument range checks for the HTM and Crypto builtins were implemented in
CGBuiltin.cpp, not in Sema. This change moves them to the appropriate location
in SemaChecking.cpp. It requires the creation of a new method in the Sema class
to do checks for PPC-specific builtins.
http://reviews.llvm.org/D8672
llvm-svn: 233586 | 
| | 
| 
| 
| 
| 
| 
| | It looks like not warning on this was an oversight in the original
implementation of this warning.
llvm-svn: 232900 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The diff looks intimidating, but this just moves the -Wdynamic-class-memaccess
code out a scope, protected by a
    if (PointeeTy == QualType())
      continue;
check so that it still only runs when it should.
llvm-svn: 232899 | 
| | 
| 
| 
| 
| 
| | This fixes PR22961.
llvm-svn: 232824 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary: This patch consists of the suggestions of clang-tidy/misc-static-assert check.
Reviewers: alexfh
Subscribers: dblaikie, xazax.hun, cfe-commits
Differential Revision: http://reviews.llvm.org/D8344
Patch by Szabolcs Sipos!
llvm-svn: 232367 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | When if statement condition ended in a macro:
    if (ptr == NULL);
the check used to consider the definition location of NULL, instead of the
current line.
Patch by Manasij Mukherjee.
llvm-svn: 232295 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | std::make_exception_ptr calls std::__GetExceptionInfo in order to figure
out how to properly copy the exception object.
Differential Revision: http://reviews.llvm.org/D8280
llvm-svn: 232188 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is nearly identical to the v*f128_si256 parts of r231792 and r232052.
AVX2 introduced proper integer variants of the hacked integer insert/extract
C intrinsics that were created for this same functionality with AVX1.
This should complete the front end fixes for insert/extract128 intrinsics. 
Corresponding LLVM patch to follow.
llvm-svn: 232109 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is very much like D8088 (checked in at r231792).
Now that we've replaced the vinsertf128 intrinsics,
do the same for their extract twins.
Differential Revision: http://reviews.llvm.org/D8275
llvm-svn: 232052 | 
| | 
| 
| 
| 
| 
| | __builtin_longjmp to Sema as requested by John McCall.
llvm-svn: 231986 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | We want to replace as much custom x86 shuffling via intrinsics
as possible because pushing the code down the generic shuffle
optimization path allows for better codegen and less complexity
in LLVM.
This is the sibling patch for the LLVM half of this change:
http://reviews.llvm.org/D8086
Differential Revision: http://reviews.llvm.org/D8088
llvm-svn: 231792 | 
| | 
| 
| 
| 
| 
| | NFC.
llvm-svn: 231657 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This commit adds new warning to prevent user from creating 'circular containers'.
Mutable collections from NSFoundation allows user to add collection to itself, e.g.: 
NSMutableArray *a = [NSMutableArray new]; 
[a addObject:a]; 
The code above leads to really weird behaviour (crashes, 'endless' recursion) and 
retain cycles (collection retains itself) if ARC enabled.
Patch checks the following collections: 
  - NSMutableArray, 
  - NSMutableDictionary, 
  - NSMutableSet, 
  - NSMutableOrderedSet, 
  - NSCountedSet. 
llvm-svn: 231265 | 
| | 
| 
| 
| 
| 
| | This was apparently overlooked in r231211.
llvm-svn: 231242 | 
| | 
| 
| 
| | llvm-svn: 231213 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | GCC -pedantic produces a format warning when the "%p" specifier is used with
arguments that are not void*. It's useful for portability to be able to
catch such warnings with clang as well. The warning is off by default in
both gcc and with this patch. This patch enables it either when extensions
are disabled with -pedantic, or with the specific flag -Wformat-pedantic.
The C99 and C11 specs do appear to require arguments corresponding to 'p'
specifiers to be void*: "If any argument is not the correct type for the
corresponding conversion specification, the behavior is undefined."
[7.19.6.1 p9], and of the 'p' format specifier "The argument shall be a
pointer to void." [7.19.6.1 p8]
Both printf and scanf format checking are covered.
llvm-svn: 231211 | 
| | 
| 
| 
| 
| 
| 
| | This is a real bug if the code path is ever used with different pointer
sizes in the same process.
llvm-svn: 230893 | 
| | 
| 
| 
| 
| 
| 
| | is null due to its previous bad declaration, etc.
rdar://19871240
llvm-svn: 230649 | 
| | 
| 
| 
| 
| 
| | headers. We use appropriate shuffle vector instead.
llvm-svn: 230616 | 
| | 
| 
| 
| | llvm-svn: 230615 | 
| | 
| 
| 
| 
| 
| 
| 
| | We'd diagnose an __assume expression which contained a function call.
This would result in us wrongly returning ExprError, causing mysterious
failures later on.
llvm-svn: 230597 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | We would wrongfully reject (a.~A)() in both the destructor and
pseudo-destructor cases.
This fixes PR22668.
llvm-svn: 230512 | 
| | 
| 
| 
| 
| 
| | This is going to be needed in clang-tidy as more checks add complex fixits.
llvm-svn: 230495 | 
| | 
| 
| 
| 
| 
| 
| | can take a "const char*" format but supports standard printf 
and CF/NS types . rdar://19904147
llvm-svn: 230109 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This adds a new __freebsd_kprintf__ format string type, which enables
checking when used in __attribute__((format(...))) attributes.  It can
check the FreeBSD kernel specific %b, %D, %r and %y specifiers, using
existing diagnostic messages.  Also adds test cases for all these
specifiers.
Differential Revision: http://reviews.llvm.org/D7154
llvm-svn: 229921 | 
| | 
| 
| 
| | llvm-svn: 229067 | 
| | 
| 
| 
| | llvm-svn: 227679 | 
| | 
| 
| 
| 
| 
| | builtins.
llvm-svn: 227674 | 
| | 
| 
| 
| 
| 
| 
| 
| | Pointer arithmetic is only makes sense if the pointee type is complete.
This fixes PR22361.
llvm-svn: 227295 | 
| | 
| 
| 
| | llvm-svn: 227066 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The lowering looks a lot like normal EH lowering, with the exception
that the exceptions are caught by executing filter expression code
instead of matching typeinfo globals. The filter expressions are
outlined into functions which are used in landingpad clauses where
typeinfo would normally go.
Major aspects that still need work:
- Non-call exceptions in __try bodies won't work yet. The plan is to
  outline the __try block in the frontend to keep things simple.
- Filter expressions cannot use local variables until capturing is
  implemented.
- __finally blocks will not run after exceptions. Fixing this requires
  work in the LLVM SEH preparation pass.
The IR lowering looks like this:
// C code:
bool safe_div(int n, int d, int *r) {
  __try {
    *r = normal_div(n, d);
  } __except(_exception_code() == EXCEPTION_INT_DIVIDE_BY_ZERO) {
    return false;
  }
  return true;
}
; LLVM IR:
define i32 @filter(i8* %e, i8* %fp) {
  %ehptrs = bitcast i8* %e to i32**
  %ehrec = load i32** %ehptrs
  %code = load i32* %ehrec
  %matches = icmp eq i32 %code, i32 u0xC0000094
  %matches.i32 = zext i1 %matches to i32
  ret i32 %matches.i32
}
define i1 zeroext @safe_div(i32 %n, i32 %d, i32* %r) {
  %rr = invoke i32 @normal_div(i32 %n, i32 %d)
      to label %normal unwind to label %lpad
normal:
  store i32 %rr, i32* %r
  ret i1 1
lpad:
  %ehvals = landingpad {i8*, i32} personality i32 (...)* @__C_specific_handler
      catch i8* bitcast (i32 (i8*, i8*)* @filter to i8*)
  %ehptr = extractvalue {i8*, i32} %ehvals, i32 0
  %sel = extractvalue {i8*, i32} %ehvals, i32 1
  %filter_sel = call i32 @llvm.eh.seh.typeid.for(i8* bitcast (i32 (i8*, i8*)* @filter to i8*))
  %matches = icmp eq i32 %sel, %filter_sel
  br i1 %matches, label %eh.except, label %eh.resume
eh.except:
  ret i1 false
eh.resume:
  resume
}
Reviewers: rjmccall, rsmith, majnemer
Differential Revision: http://reviews.llvm.org/D5607
llvm-svn: 226760 | 
| | 
| 
| 
| 
| 
| | buitins.
llvm-svn: 226422 | 
| | 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| | llvm-svn: 225624 | 
| | 
| 
| 
| | llvm-svn: 224880 | 
| | 
| 
| 
| 
| 
| 
| 
| | when source range is incorrect causing the warning to be
issued when it should not because expression is in a macro.
rdar://19256338
llvm-svn: 224549 | 
| | 
| 
| 
| 
| 
| 
| | Bitfield RefersToEnclosingLocal of Stmt::DeclRefExprBitfields renamed to RefersToCapturedVariable to reflect latest changes introduced in commit 224323. Also renamed method Expr::refersToEnclosingLocal() to Expr::refersToCapturedVariable() and comments for constant arguments.
No functional changes.
llvm-svn: 224329 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The extension has the following syntax:
  __builtin_call_with_static_chain(Call, Chain)
  where Call must be a function call expression and Chain must be of pointer type
This extension performs a function call Call with a static chain pointer
Chain passed to the callee in a designated register. This is useful for
calling foreign language functions whose ABI uses static chain pointers
(e.g. to implement closures).
Differential Revision: http://reviews.llvm.org/D6332
llvm-svn: 224167 | 
| | 
| 
| 
| 
| 
| | since the attribute may reside there, instead of just on the FunctionDecl. Fixes PR21668.
llvm-svn: 224039 | 
| | 
| 
| 
| 
| 
| | that contained side effects.
llvm-svn: 223184 | 
| | 
| 
| 
| 
| 
| | for C code.
llvm-svn: 222327 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | nonnull attribute when comparison is always true/false. 
Original patch by Steven Wu. I have added extra code to prevent issuing of
warning  when the nonnull parameter is modified prior to the comparison.
This addition prevents false positives in the most obvious cases.
There may still be false positive warnings in some cases (as one of my tests
indicates), but benefit far outweighs such cases. rdar://18712242
llvm-svn: 222264 | 
| | 
| 
| 
| 
| 
| 
| | Shift some functions around, make a method in Sema private,
call the correct overloaded function.  No functional change.
llvm-svn: 222081 | 
| | 
| 
| 
| 
| 
| | for a typedef before arithmetic conversion in all rare corner cases.
llvm-svn: 222049 | 
| | 
| 
| 
| | llvm-svn: 222047 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
Ok, here is somewhat addition to D6217 aiming to preserve old darwin behavior wrt the typedefed types. The actual change to SemaChecking turned out to be pretty gross, in particular:
  1. We need to extract the typedef'ed type for proper diagnostics
  2. We need to walk over paren expressions as well
Reviewers: chandlerc, rsmith
Reviewed By: rsmith
Subscribers: cfe-commits
Differential Revision: http://reviews.llvm.org/D6256
llvm-svn: 222044 | 
| | 
| 
| 
| 
| 
| 
| | which evaluates to true. rdar://18716393.
Reviewed by Richard Trieu
llvm-svn: 222009 | 
| | 
| 
| 
| 
| 
| | comments.
llvm-svn: 221714 |