|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 51822 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | insertvalue and extractvalue to use constant indices instead of
Value* indices. And begin updating LangRef.html.
There's definately more to come here, but I'm checking this 
basic support in now to make it available to people who are
interested.
llvm-svn: 51806 | 
| | 
| 
| 
| | llvm-svn: 51570 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | and bitcode support for the extractvalue and insertvalue
instructions and constant expressions.
Note that this does not yet include CodeGen support.
llvm-svn: 51468 | 
| | 
| 
| 
| 
| 
| | Legacy interfaces will be in place for some time.  (Merge from use-diet branch.)
llvm-svn: 51200 | 
| | 
| 
| 
| 
| 
| | makefile targets to find these better.
llvm-svn: 51143 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | are represented as "weak", but there are subtle differences
in some cases on Darwin, so we need both.  The intent
is that "common" will behave identically to "weak" unless
somebody changes their target to do something else.
No functional change as yet.
llvm-svn: 51118 | 
| | 
| 
| 
| | llvm-svn: 50998 | 
| | 
| 
| 
| | llvm-svn: 50996 | 
| | 
| 
| 
| | llvm-svn: 50994 | 
| | 
| 
| 
| 
| 
| | for details.  CodeGen support coming in a follow up patch
llvm-svn: 50985 | 
| | 
| 
| 
| | llvm-svn: 50943 | 
| | 
| 
| 
| 
| 
| | r48047 r48084 r48085 r48086 r48088 r48096 r48099 r48109 and r48123.
llvm-svn: 50265 | 
| | 
| 
| 
| | llvm-svn: 49977 | 
| | 
| 
| 
| 
| 
| | not # of operands as an input.
llvm-svn: 49599 | 
| | 
| 
| 
| 
| 
| 
| 
| | Specifically, introduction of XXX::Create methods
for Users that have a potentially variable number of
Uses.
llvm-svn: 49277 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 1. There is now a "PAListPtr" class, which is a smart pointer around
   the underlying uniqued parameter attribute list object, and manages
   its refcount.  It is now impossible to mess up the refcount.
2. PAListPtr is now the main interface to the underlying object, and
   the underlying object is now completely opaque.
3. Implementation details like SmallVector and FoldingSet are now no
   longer part of the interface.
4. You can create a PAListPtr with an arbitrary sequence of
   ParamAttrsWithIndex's, no need to make a SmallVector of a specific 
   size (you can just use an array or scalar or vector if you wish).
5. All the client code that had to check for a null pointer before
   dereferencing the pointer is simplified to just access the 
   PAListPtr directly.
6. The interfaces for adding attrs to a list and removing them is a
   bit simpler.
Phase #2 will rename some stuff (e.g. PAListPtr) and do other less 
invasive changes.
llvm-svn: 48289 | 
| | 
| 
| 
| 
| 
| | refcount.
llvm-svn: 48276 | 
| | 
| 
| 
| | llvm-svn: 48268 | 
| | 
| 
| 
| | llvm-svn: 48248 | 
| | 
| 
| 
| 
| 
| | This is the first checkin for PR1269, the new EH infrastructure.
llvm-svn: 47802 | 
| | 
| 
| 
| | llvm-svn: 47619 | 
| | 
| 
| 
| 
| 
| | Take 2.
llvm-svn: 47583 | 
| | 
| 
| 
| | llvm-svn: 47533 | 
| | 
| 
| 
| | llvm-svn: 47521 | 
| | 
| 
| 
| 
| 
| 
| | stuff into ParamAttrsList.h.  Per feedback from
ParamAttrs changes.
llvm-svn: 47504 | 
| | 
| 
| 
| | llvm-svn: 47471 | 
| | 
| 
| 
| | llvm-svn: 46514 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| 
| 
| | it's auto-upgraded to a shufflevector instruction.
llvm-svn: 45131 | 
| | 
| 
| 
| 
| 
| | of PointerType::get() has become PointerType::getUnqual(), which returns a pointer in the generic address space. The new prototype of PointerType::get() requires both a type and an address space.
llvm-svn: 45082 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | regions of memory that have a target specific relationship, as described in the 
Embedded C Technical Report. 
This also implements the 2007-12-11-AddressSpaces test, 
which demonstrates how address space attributes can be used in LLVM IR.
In addition, this patch changes the bitcode signature for stores (in a backwards 
compatible manner), such that the pointer type, rather than the pointee type, is 
encoded. This permits type information in the pointer (e.g. address space) to be 
preserved for stores.
LangRef updates are forthcoming.
llvm-svn: 44858 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | methods are new to Function:
  bool hasCollector() const;
  const std::string &getCollector() const;
  void setCollector(const std::string &);
  void clearCollector();
The assembly representation is as such:
  define void @f() gc "shadow-stack" { ...
The implementation uses an on-the-side table to map Functions to 
collector names, such that there is no overhead. A StringPool is 
further used to unique collector names, which are extremely
likely to be unique per process.
llvm-svn: 44769 | 
| | 
| 
| 
| 
| 
| 
| | introduced by this patch:
http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20071126/055824.html
llvm-svn: 44364 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | the function type, instead they belong to functions
and function calls.  This is an updated and slightly
corrected version of Reid Spencer's original patch.
The only known problem is that auto-upgrading of
bitcode files doesn't seem to work properly (see
test/Bitcode/AutoUpgradeIntrinsics.ll).  Hopefully
a bitcode guru (who might that be? :) ) will fix it.
llvm-svn: 44359 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | any sense it is important that ParamAttr::None gets
treated the same as not supplying an attribute at
all.  Rather than stripping ParamAttr::None out of
the list of attributes, assert if ParamAttr::None
is seen.  Fix up the bitcode reader which liked to
insert ParamAttr::None all over the place.  Patch
based on one by Török Edwin.
llvm-svn: 44250 | 
| | 
| 
| 
| | llvm-svn: 44234 | 
| | 
| 
| 
| 
| 
| 
| | parameters.  Rename ValueRefList to ParamList
in AsmParser, since its only use is for parameters.
llvm-svn: 43734 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | No compile-time support for constant operations yet,
just format transformations.  Make readers and
writers work.  Split constants into 2 doubles in
Legalize.
llvm-svn: 42865 | 
| | 
| 
| 
| 
| 
| 
| | Next round of x87 long double stuff.
Getting close now, basically works.
llvm-svn: 41875 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | access to bits).  Use them in place of float and
double interfaces where appropriate.
First bits of x86 long double constants handling 
(untested, probably does not work).
llvm-svn: 41858 | 
| | 
| 
| 
| | llvm-svn: 41769 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Use APFloat in UpgradeParser and AsmParser.
Change all references to ConstantFP to use the
APFloat interface rather than double.  Remove
the ConstantFP double interfaces.
Use APFloat functions for constant folding arithmetic
and comparisons.
(There are still way too many places APFloat is
just a wrapper around host float/double, but we're
getting there.)
llvm-svn: 41747 | 
| | 
| 
| 
| 
| 
| | GLIBCXX_DEBUG issues.
llvm-svn: 41697 | 
| | 
| 
| 
| | llvm-svn: 41506 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | to handle values bigger than double.  If we assume host==target and host
long double works correctly, this is not too bad, but we don't want to
have that limitation longterm.  I could implement accepting double
constants as long double or something like that, which would lead to
incorrect codegen with no errors; the more I think about that the worse
it seems.  Rather than do such a hack that would be backed out later,
I'm settling for giving reasonable error messages, for now.
llvm-svn: 40974 | 
| | 
| 
| 
| 
| 
| 
| 
| | LLVM. It cleans up the intrinsic definitions and generally smooths the process for more complicated intrinsic writing. It will be used by the upcoming atomic intrinsics as well as vector and float intrinsics in the future.
This also changes the syntax for llvm.bswap, llvm.part.set, llvm.part.select, and llvm.ct* intrinsics. They are automatically upgraded by both the LLVM ASM reader and the bitcode reader. The test cases have been updated, with special tests added to ensure the automatic upgrading is supported.
llvm-svn: 40807 | 
| | 
| 
| 
| | llvm-svn: 40774 | 
| | 
| 
| 
| 
| 
| 
| 
| | indexing an empty std::vector.
Updates to all clients.
llvm-svn: 40660 | 
| | 
| 
| 
| 
| 
| | Almost all occurrences of "bytecode" in the sources have been eliminated.
llvm-svn: 37913 |