|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Thisadds a new warning that warns on code like this:
  if (memcmp(a, b, sizeof(a) != 0))
The warning looks like:
test4.cc:5:30: warning: size argument in 'memcmp' call is a comparison [-Wmemsize-comparison]
  if (memcmp(a, b, sizeof(a) != 0))
                   ~~~~~~~~~~^~~~
test4.cc:5:7: note: did you mean to compare the result of 'memcmp' instead?
  if (memcmp(a, b, sizeof(a) != 0))
      ^                          ~
                            )
test4.cc:5:20: note: explicitly cast the argument to size_t to silence this warning
  if (memcmp(a, b, sizeof(a) != 0))
                   ^
                   (size_t)(     )
1 warning generated.
This found 2 bugs in chromium and has 0 false positives on both chromium and
llvm.
The idea of triggering this warning on a binop in the size argument is due to
rnk.
llvm-svn: 198063 | 
| | 
| 
| 
| | llvm-svn: 196888 | 
| | 
| 
| 
| | llvm-svn: 196510 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
MSVC destroys arguments in the callee from left to right.  Because C++
objects have to be destroyed in the reverse order of construction, Clang
has to construct arguments from right to left and destroy arguments from
left to right.
This patch fixes the ordering by reversing the order of evaluation of
all call arguments under the MS C++ ABI.
Fixes PR18035.
Reviewers: rsmith
Differential Revision: http://llvm-reviews.chandlerc.com/D2275
llvm-svn: 196402 | 
| | 
| 
| 
| | llvm-svn: 194660 | 
| | 
| 
| 
| | llvm-svn: 194513 | 
| | 
| 
| 
| | llvm-svn: 194197 | 
| | 
| 
| 
| 
| 
| | checking an expression for constant overflow.
llvm-svn: 194099 | 
| | 
| 
| 
| | llvm-svn: 193888 | 
| | 
| 
| 
| | llvm-svn: 193887 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The AST was constructed so that this builtin returned the default BoolTy and
since I'd opted for custom SemaChecking, I should have set it properly at that
point.
This caused an assertion failure when the types didn't match up with what we
generated. This makes it return an IntTy, which is as good as anything.
llvm-svn: 193606 | 
| | 
| 
| 
| 
| 
| 
| | attributes when such methods are actually envoked in message
expression. // rdar://15242010
llvm-svn: 193003 | 
| | 
| 
| 
| 
| 
| 
| 
| | that can represent unicode characters
Fixes <rdar://problem/13991617>.
llvm-svn: 192673 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | OpaqueValueExprs.
Fixes a false positive with -Wconversion involving Objective-C properties.
Fixes <rdar://problem/14415662>.
llvm-svn: 192611 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | _Bool in C, if the macro is defined. Also teach FixItUtils to look at whether
the macro was defined at the source location for which it is creating a fixit,
rather than looking at whether it's defined *now*. This is especially relevant
for analysis-based warnings which are delayed until end of TU.
llvm-svn: 191057 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | LLVM supports applying conversion instructions to vectors of the same number of
elements (fptrunc, fptosi, etc.) but there had been no way for a Clang user to
cause such instructions to be generated when using builtin vector types.
C-style casting on vectors is already defined in terms of bitcasts, and so
cannot be used for these conversions as well (without leading to a very
confusing set of semantics). As a result, this adds a __builtin_convertvector
intrinsic (patterned after the OpenCL __builtin_astype intrinsic). This is
intended to aid the creation of vector intrinsic headers that create generic IR
instead of target-dependent intrinsics (in other words, this is a generic
_mm_cvtepi32_ps). As noted in the documentation, the action of
__builtin_convertvector is defined in terms of the action of a C-style cast on
each vector element.
llvm-svn: 190915 | 
| | 
| 
| 
| 
| 
| | PR17123.
llvm-svn: 190484 | 
| | 
| 
| 
| 
| 
| | StringArgument since that is a more accurate modeling.
llvm-svn: 189851 | 
| | 
| 
| 
| 
| 
| 
| 
| | I changed the diagnostic printing code because it's probably better
to cut off a digit from DBL_MAX than to print something like
1.300000001 when the user wrote 1.3.
llvm-svn: 189625 | 
| | 
| 
| 
| 
| 
| | No functionality change intended.
llvm-svn: 189112 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Basically, isInMainFile considers line markers, and isWrittenInMainFile
doesn't.  Distinguishing between the two is useful when dealing with
files which are preprocessed files or rewritten with -frewrite-includes
(so we don't, for example, print useless warnings).
llvm-svn: 188968 | 
| | 
| 
| 
| 
| 
| | in include/clang/Basic/LLVM.h.
llvm-svn: 188138 | 
| | 
| 
| 
| | llvm-svn: 188063 | 
| | 
| 
| 
| | llvm-svn: 187975 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | function: it can't be 'void' and it can't be an initializer list. We give a
hard error for these rather than treating them as undefined behavior (we can
and probably should do the same for non-POD types in C++11, but as of this
change we don't).
Slightly rework the checking of variadic arguments in a function with a format
attribute to ensure that certain kinds of format string problem (non-literal
string, too many/too few arguments, ...) don't suppress this error.
llvm-svn: 187735 | 
| | 
| 
| 
| 
| 
| | undefined element value to match IR capabilities.
llvm-svn: 187694 | 
| | 
| 
| 
| | llvm-svn: 187644 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Patch by Ana Pazos
- Completed implementation of instruction formats:
AdvSIMD three same
AdvSIMD modified immediate
AdvSIMD scalar pairwise
- Completed implementation of instruction classes
(some of the instructions in these classes
belong to yet unfinished instruction formats):
Vector Arithmetic
Vector Immediate
Vector Pairwise Arithmetic
- Initial implementation of instruction formats:
AdvSIMD scalar two-reg misc
AdvSIMD scalar three same
- Intial implementation of instruction class:
Scalar Arithmetic
- Initial clang changes to support arm v8 intrinsics.
Note: no clang changes for scalar intrinsics function name mangling yet.
- Comprehensive test cases for added instructions
To verify auto codegen, encoding, decoding, diagnosis, intrinsics.
llvm-svn: 187568 | 
| | 
| 
| 
| 
| 
| 
| 
| | __builtin_shufflvector don't have the same number of elements or the mask isn't an integer vector.
Previously a diagnostic was issued, but the code went ahead and built the ShuffleVectorExpr. While I'm here also simplify a couple lines by wrapping the return ExprError around the Diag calls.
llvm-svn: 187344 | 
| | 
| 
| 
| | llvm-svn: 187334 | 
| | 
| 
| 
| | llvm-svn: 186652 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This adds three overloaded intrinsics to Clang:
    T __builtin_arm_ldrex(const volatile T *addr)
    int __builtin_arm_strex(T val, volatile T *addr)
    void __builtin_arm_clrex()
The intent is that these do what users would expect when given most sensible
types. Currently, "sensible" translates to ints, floats and pointers.
llvm-svn: 186394 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | & operator (ignoring any overloaded operator& for the type). The purpose of
this builtin is for use in std::addressof, to allow it to be made constexpr;
the existing implementation technique (reinterpret_cast to some reference type,
take address, reinterpert_cast back) does not permit this because
reinterpret_cast between reference types is not permitted in a constant
expression in C++11 onwards.
llvm-svn: 186053 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Use UsualArithmeticConversions unconditionally in analysis of
comparisons and conditional operators: the method performs
the usual arithmetic conversions if both sides are arithmetic, and
usual unary conversions if they are not.  This is just a cleanup
for conditional operators; for comparisons, it fixes the issue that
we would try to check isArithmetic() on an atomic type.
Also, fix GetExprRange() in SemaChecking.cpp so it deals with variables
of atomic type correctly.
Fixes PR15537.
llvm-svn: 185857 | 
| | 
| 
| 
| | llvm-svn: 185752 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | before the value computation of the result. In C, this is implied by there being
a sequence point after their evaluation, and in C++, it's implied by the
side-effects being sequenced before the expressions and statements in the
function body.
llvm-svn: 185282 | 
| | 
| 
| 
| 
| 
| 
| 
| | side-effect is not sequenced before its value computation. Also fix a
mishandling of ?: expressions where the condition is constant that was
exposed by the tests for this.
llvm-svn: 185035 | 
| | 
| 
| 
| 
| 
| 
| | CheckParmForFunctionDef performs standard checks for type completeness
and other things like a destructor check for the MSVC++ ABI.
llvm-svn: 184740 | 
| | 
| 
| 
| 
| 
| | types and function pointer arrays.
llvm-svn: 184616 | 
| | 
| 
| 
| 
| 
| | Reviewed by Richard Smith.
llvm-svn: 184612 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Itanium destroys them in the caller at the end of the full expression,
but MSVC destroys them in the callee.  This is further complicated by
the need to emit EH-only destructor cleanups in the caller.
This should help clang compile MSVC's debug iterators more correctly.
There is still an outstanding issue in PR5064 of a memcpy emitted by the
LLVM backend, which is not correct for C++ records.
Fixes PR16226.
Reviewers: rjmccall
Differential Revision: http://llvm-reviews.chandlerc.com/D929
llvm-svn: 184543 | 
| | 
| 
| 
| | llvm-svn: 184496 | 
| | 
| 
| 
| 
| 
| 
| | operations in the case where evaluating a subexpression fails. No functionality
change, but test/Sema/many-logical-ops.c gets ~100x faster with this change.
llvm-svn: 184489 | 
| | 
| 
| 
| | llvm-svn: 184470 | 
| | 
| 
| 
| 
| 
| | whether to emit a -Wformat-security warning.  <rdar://problem/14178260>.
llvm-svn: 184214 | 
| | 
| 
| 
| 
| 
| | The approach r183084 took was wrong, back it out.
llvm-svn: 183575 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | In some cases, clang applies the C++ rules for computing the range of a
value when said value is an enum.
Instead, apply C semantics when in C mode.
llvm-svn: 183084 | 
| | 
| 
| 
| 
| 
| 
| | does not support large load/store of atomic objects.
// rdar://13973577
llvm-svn: 182781 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2005/n1905.pdf 18.7p3
explicitly calls this (and some other things) out as undefined.
Also move 2 other existing warnings behind the new -Wvarargs flag.
llvm-svn: 182694 | 
| | 
| 
| 
| 
| 
| 
| | working on new Objective-C array subscripting
syntax. // rdar://13855682
llvm-svn: 181940 |