|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 144648 | 
| | 
| 
| 
| | llvm-svn: 135375 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | patch brings numerous advantages to LLVM.  One way to look at it
is through diffstat:
 109 files changed, 3005 insertions(+), 5906 deletions(-)
Removing almost 3K lines of code is a good thing.  Other advantages
include:
1. Value::getType() is a simple load that can be CSE'd, not a mutating
   union-find operation.
2. Types a uniqued and never move once created, defining away PATypeHolder.
3. Structs can be "named" now, and their name is part of the identity that
   uniques them.  This means that the compiler doesn't merge them structurally
   which makes the IR much less confusing.
4. Now that there is no way to get a cycle in a type graph without a named
   struct type, "upreferences" go away.
5. Type refinement is completely gone, which should make LTO much MUCH faster
   in some common cases with C++ code.
6. Types are now generally immutable, so we can use "Type *" instead 
   "const Type *" everywhere.
Downsides of this patch are that it removes some functions from the C API,
so people using those will have to upgrade to (not yet added) new API.  
"LLVM 3.0" is the right time to do this.
There are still some cleanups pending after this, this patch is large enough
as-is.
llvm-svn: 134829 | 
| | 
| 
| 
| 
| 
| | removes some gunk from LLVMContext.
llvm-svn: 133360 | 
| | 
| 
| 
| | llvm-svn: 120298 | 
| | 
| 
| 
| | llvm-svn: 108130 | 
| | 
| 
| 
| | llvm-svn: 100709 | 
| | 
| 
| 
| | llvm-svn: 99918 | 
| | 
| 
| 
| | llvm-svn: 99886 | 
| | 
| 
| 
| 
| 
| | external Functions (the JIT does honour this).
llvm-svn: 99885 | 
| | 
| 
| 
| | llvm-svn: 94746 | 
| | 
| 
| 
| | llvm-svn: 92673 | 
| | 
| 
| 
| | llvm-svn: 92618 | 
| | 
| 
| 
| | llvm-svn: 89198 | 
| | 
| 
| 
| 
| 
| 
| | libffi support and that the interpreter can't call external functions without
it. Patch by Timo Juhani Lindfors! Fixes PR5466.
llvm-svn: 89062 | 
| | 
| 
| 
| | llvm-svn: 86458 | 
| | 
| 
| 
| 
| 
| | native anyways. This fixes a crash using %d and similar in a scanf statement.
llvm-svn: 86440 | 
| | 
| 
| 
| | llvm-svn: 82225 | 
| | 
| 
| 
| | llvm-svn: 82100 | 
| | 
| 
| 
| | llvm-svn: 79842 | 
| | 
| 
| 
| | llvm-svn: 78948 | 
| | 
| 
| 
| | llvm-svn: 78848 | 
| | 
| 
| 
| | llvm-svn: 78405 | 
| | 
| 
| 
| | llvm-svn: 76962 | 
| | 
| 
| 
| | llvm-svn: 76786 | 
| | 
| 
| 
| 
| 
| | and abort()/exit() -> llvm_report_error().
llvm-svn: 75363 | 
| | 
| 
| 
| | llvm-svn: 74931 | 
| | 
| 
| 
| | llvm-svn: 73912 | 
| | 
| 
| 
| 
| 
| | interpreter mode" when it's not.
llvm-svn: 68937 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | there.
This changes the interpreter to use libffi. After this patch, the interpreter
will barely be able to call any external functions if built on a system without
libffi installed (just enough to pass 'make check' really). But with libffi,
we can now call any function that isn't variadic or taking a struct or vector
parameter (but pointer to struct is fine). Patch by Alexei Svitkine!
llvm-svn: 63723 | 
| | 
| 
| 
| | llvm-svn: 62777 | 
| | 
| 
| 
| | llvm-svn: 62616 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This requires a rebuild of 'configure' itself. I will be committing that next, but
built with the wrong version of autoconf. Somebody who has the right one, please update
it.
As a side-note, because of the way autoconf works, all built tools will link against
libffi, not just lli. If you know how to fix this, please let me know ...
llvm-svn: 62553 | 
| | 
| 
| 
| 
| 
| | Patch by Samuel Tardieu.
llvm-svn: 57291 | 
| | 
| 
| 
| 
| 
| 
| | warning. There wasn't actually a problem here, because the contents of
the string are known.
llvm-svn: 54385 | 
| | 
| 
| 
| 
| 
| | annoying warnings.
llvm-svn: 47367 | 
| | 
| 
| 
| | llvm-svn: 47363 | 
| | 
| 
| 
| | llvm-svn: 46514 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| | llvm-svn: 45034 | 
| | 
| 
| 
| 
| 
| | not support it.
llvm-svn: 44914 | 
| | 
| 
| 
| 
| 
| 
| | Make lli interpreter correctly call external functions sin()/cos(),
__cxa_guard_acquire() and __cxa_guard_release().
llvm-svn: 44910 | 
| | 
| 
| 
| 
| 
| | get it to compile.
llvm-svn: 44791 | 
| | 
| 
| 
| 
| 
| | things, it wasn't designed to handle.
llvm-svn: 40608 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | ManagedStatic control.
This commit fixes two things.  One is a pair of VStudio compiler errors stemming from variables
which defined within the for loop statement and also within the body of the for loop.  I fixed these 
by renaming one of the two variables.  Additionally, I've made the Function*->ExFunc map in 
ExternalFunctions.cpp a ManagedStatic object, so that cleanup will be done on llvm_shutdown.  In repeated
uses of the interpreter, where the same Function* address may get used for completely differnet functions,
this was causing a crash.
llvm-svn: 40558 | 
| | 
| 
| 
| 
| 
| 
| | turn "putchar" calls into _IO_putc calls which is a lower-level interface.
This patch allows these calls to be executed by lli in interpreter mode.
llvm-svn: 37254 | 
| | 
| 
| 
| 
| 
| | users.
llvm-svn: 36305 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | * Rename the FunctionType* parameter from M to FT on all the functions.
* Implement a fix for PR1293 by just asserting that library functions that
  must return pointers should have pointer typed results. This just makes
  sure that we don't attempt to use an uninitialized integer or something
  later on.
llvm-svn: 35508 | 
| | 
| 
| 
| 
| 
| | a single integer field of type APInt.
llvm-svn: 34950 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Implement the arbitrary bit-width integer feature. The feature allows
integers of any bitwidth (up to 64) to be defined instead of just 1, 8,
16, 32, and 64 bit integers.
This change does several things:
1. Introduces a new Derived Type, IntegerType, to represent the number of
   bits in an integer. The Type classes SubclassData field is used to
   store the number of bits. This allows 2^23 bits in an integer type.
2. Removes the five integer Type::TypeID values for the 1, 8, 16, 32 and
   64-bit integers. These are replaced with just IntegerType which is not
   a primitive any more.
3. Adjust the rest of LLVM to account for this change.
Note that while this incremental change lays the foundation for arbitrary
bit-width integers, LLVM has not yet been converted to actually deal with
them in any significant way. Most optimization passes, for example, will
still only deal with the byte-width integer types.  Future increments
will rectify this situation.
llvm-svn: 33113 |