|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 289787 | 
| | 
| 
| 
| | llvm-svn: 289713 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | At least the plugin used by the LibreOffice build
(<https://wiki.documentfoundation.org/Development/Clang_plugins>) indirectly
uses those members (through inline functions in LLVM/Clang include files in turn
using them), but they are not exported by utils/extract_symbols.py on Windows,
and accessing data across DLL/EXE boundaries on Windows is generally
problematic.
Differential Revision: https://reviews.llvm.org/D26671
llvm-svn: 289647 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | In amdgcn target, null pointers in global, constant, and generic address space take value 0 but null pointers in private and local address space take value -1. Currently LLVM assumes all null pointers take value 0, which results in incorrectly translated IR. To workaround this issue, instead of emit null pointers in local and private address space, a null pointer in generic address space is emitted and casted to local and private address space.
Tentative definition of global variables with non-zero initializer will have weak linkage instead of common linkage since common linkage requires zero initializer and does not have explicit section to hold the non-zero value.
Virtual member functions getNullPointer and performAddrSpaceCast are added to TargetCodeGenInfo which by default returns ConstantPointerNull and emitting addrspacecast instruction. A virtual member function getNullPointerValue is added to TargetInfo which by default returns 0. Each target can override these virtual functions to get target specific null pointer and the null pointer value for specific address space, and perform specific translations for addrspacecast.
Wrapper functions getNullPointer is added to CodegenModule and getTargetNullPointerValue is added to ASTContext to facilitate getting the target specific null pointers and their values.
This change has no effect on other targets except amdgcn target. Other targets can provide support of non-zero null pointer in a similar way.
This change only provides support for non-zero null pointer for C and OpenCL. Supporting for other languages will be added later incrementally.
Differential Revision: https://reviews.llvm.org/D26196
llvm-svn: 289252 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary: Removed unused headers, replaced some headers with forward class declarations
Patch by: Eugene <claprix@yandex.ru>
Differential Revision: https://reviews.llvm.org/D20100
llvm-svn: 275882 | 
| | 
| 
| 
| 
| 
| | r259192 post commit comment.
llvm-svn: 259232 | 
| | 
| 
| 
| 
| 
| | just letting them be implicitly created.
llvm-svn: 216528 | 
| | 
| 
| 
| 
| 
| 
| | will never be true in a well-defined context.  The checking for null pointers
has been moved into the caller logic so it does not rely on undefined behavior.
llvm-svn: 210498 | 
| | 
| 
| 
| | llvm-svn: 208517 | 
| | 
| 
| 
| | llvm-svn: 204012 | 
| | 
| 
| 
| 
| 
| | iterator_range fields(). Updating all of the usages of the iterators with range-based for loops.
llvm-svn: 203355 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | just valid C++11 =)
Original commit message:
PR18427: Use an appropriately-aligned buffer in APValue, to avoid a crash on
SPARC, where uint64_t apparently requires higher alignment than void*.
llvm-svn: 198903 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | crash on"
It broke building.
This reverts commit r198845.
llvm-svn: 198849 | 
| | 
| 
| 
| 
| 
| | SPARC, where uint64_t apparently requires higher alignment than void*.
llvm-svn: 198845 | 
| | 
| 
| 
| | llvm-svn: 183155 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This patch ensures that APValues are deallocated with the ASTContext by
registering a deallocation function for APValues to the ASTContext.
Original version of the patch by James Dennett.
llvm-svn: 183101 | 
| | 
| 
| 
| 
| 
| | decidedly non-reference, non-pointer type. Fixes <rdar://problem/13090123>.
llvm-svn: 173747 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | uncovered.
This required manually correcting all of the incorrect main-module
headers I could find, and running the new llvm/utils/sort_includes.py
script over the files.
I also manually added quite a few missing headers that were uncovered by
shuffling the order or moving headers up to be main-module-headers.
llvm-svn: 169237 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | and remove ASTContext reference (which was frequently bound to a dereferenced
null pointer) from the recursive lump of printPretty functions. In so doing,
fix (at least) one case where we intended to use the 'dump' mode, but that
failed because a null ASTContext reference had been passed in.
llvm-svn: 162011 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | filter_decl_iterator had a weird mismatch where both op* and op-> returned T*
making it difficult to generalize this filtering behavior into a reusable
library of any kind.
This change errs on the side of value, making op-> return T* and op* return
T&.
(reviewed by Richard Smith)
llvm-svn: 155808 | 
| | 
| 
| 
| 
| 
| | some calling code to actually pass in a non-null type, to avoid a crash.
llvm-svn: 153358 | 
| | 
| 
| 
| 
| 
| 
| 
| | copy-construction, which Daniel Dunbar reports as giving a 0.75% speedup on
403.gcc/combine.c. The performance differences on my constexpr torture tests
are below the noise floor.
llvm-svn: 152455 | 
| | 
| 
| 
| 
| 
| 
| | - This change seems to be a tiny loss on 403.gcc/combine.c (.2%), but I think
   it is the right thing to do.
llvm-svn: 152330 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | to be core constant expressions (including pointers and references to
temporaries), and makes constexpr calculations Turing-complete. A Turing machine
simulator is included as a testcase.
This opens up the possibilty of removing CCValue entirely, and removing some
copies from the constant evaluator in the process, but that cleanup is not part
of this change.
llvm-svn: 150557 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | address-of-label expressions.  Add support to Evaluate and CGExprConstant for generating/handling them.  Remove the special-case for such differences in Expr::isConstantInitializer.
With that done, remove a bunch of buggy code from CGExprConstant for handling scalar expressions which is no longer necessary.
Fixes PR11705.
llvm-svn: 147561 | 
| | 
| 
| 
| | llvm-svn: 146760 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | fails within a call to a constexpr function. Add -fconstexpr-backtrace-limit
argument to driver and frontend, to control the maximum number of notes so
produced (default 10). Fix APValue printing to be able to pretty-print all
APValue types, and move the testing for this functionality from a unittest to
a -verify test now that it's visible in clang's output.
llvm-svn: 146749 | 
| | 
| 
| 
| 
| 
| | and base-to-derived casts, and add proper handling of temporaries.
llvm-svn: 144926 | 
| | 
| 
| 
| 
| 
| 
| 
| | or MemberExpr which refers to it. As a side-effect, MemberExprs which refer to
static member functions and static data members are now emitted as constant
expressions.
llvm-svn: 144468 | 
| | 
| 
| 
| 
| 
| 
| | literal types, as well as derived-to-base casts for lvalues and
derived-to-virtual-base casts.
llvm-svn: 144265 | 
| | 
| 
| 
| | llvm-svn: 143922 | 
| | 
| 
| 
| | llvm-svn: 143914 | 
| | 
| 
| 
| 
| 
| | core constant value down to an APValue.
llvm-svn: 143909 | 
| | 
| 
| 
| 
| 
| 
| 
| | Track the function invocation where an lvalue referring to a constexpr function
parameter originated from, and use it to substitute the correct argument and to
determine whether such an argument's lifetime has ended.
llvm-svn: 143296 | 
| | 
| 
| 
| | llvm-svn: 140368 | 
| | 
| 
| 
| | llvm-svn: 140367 | 
| | 
| 
| 
| 
| 
| 
| 
| | LLVM.h imports
them into the clang namespace.
llvm-svn: 135852 | 
| | 
| 
| 
| 
| 
| | diagnostics.
llvm-svn: 135398 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This introduces a generic base class for the expression evaluator
classes, which handles a few common expression types which were
previously handled separately in each class.  Also, the expression
evaluator now uses ConstStmtVisitor.
llvm-svn: 131281 | 
| | 
| 
| 
| | llvm-svn: 101786 | 
| | 
| 
| 
| 
| 
| | the LValue-related methods of APValue out of line to avoid header file leaching.
llvm-svn: 93512 | 
| | 
| 
| 
| | llvm-svn: 81346 | 
| | 
| 
| 
| 
| 
| 
| 
| | through an array of void*), so that we don't run afoul of the
strict-aliasing rules in C++ 3.10p15. Unfortunately, GCC 4.4 still
complains about this code.
llvm-svn: 81251 | 
| | 
| 
| 
| | llvm-svn: 66555 | 
| | 
| 
| 
| | llvm-svn: 62455 | 
| | 
| 
| 
| | llvm-svn: 62438 | 
|  | llvm-svn: 59411 |