|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Constants.cpp and ConstantFold.cpp.
This involves temporarily hard wiring some parts to use the global context.  This isn't ideal, but it's
the only way I could figure out to make this process vaguely incremental.
llvm-svn: 75445 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | implemented in codegen, have no frontend to generate them, and are 
better implemented with pattern matching (like the ppc backend does
to generate rlwimi/rlwinm etc).
PR4543
llvm-svn: 75430 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Make llvm_unreachable take an optional string, thus moving the cerr<< out of
line.
LLVM_UNREACHABLE is now a simple wrapper that makes the message go away for
NDEBUG builds.
llvm-svn: 75379 | 
| | 
| 
| 
| 
| 
| | and abort()/exit() -> llvm_report_error().
llvm-svn: 75363 | 
| | 
| 
| 
| | llvm-svn: 75040 | 
| | 
| 
| 
| 
| 
| | we had multiple type planes and these lookups were expensive.
llvm-svn: 74319 | 
| | 
| 
| 
| | llvm-svn: 74143 | 
| | 
| 
| 
| | llvm-svn: 71587 | 
| | 
| 
| 
| 
| 
| | memcpy, memmove and memset.
llvm-svn: 71427 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and extern_weak_odr.  These are the same as the non-odr versions,
except that they indicate that the global will only be overridden
by an *equivalent* global.  In C, a function with weak linkage can
be overridden by a function which behaves completely differently.
This means that IP passes have to skip weak functions, since any
deductions made from the function definition might be wrong, since
the definition could be replaced by something completely different
at link time.   This is not allowed in C++, thanks to the ODR
(One-Definition-Rule): if a function is replaced by another at
link-time, then the new function must be the same as the original
function.  If a language knows that a function or other global can
only be overridden by an equivalent global, it can give it the
weak_odr linkage type, and the optimizers will understand that it
is alright to make deductions based on the function body.  The
code generators on the other hand map weak and weak_odr linkage
to the same thing.
llvm-svn: 66339 | 
| | 
| 
| 
| | llvm-svn: 64040 | 
| | 
| 
| 
| 
| 
| | Thanks, Duncan.
llvm-svn: 63389 | 
| | 
| 
| 
| 
| 
| 
| 
| | the LowerPartSet(). It didn't handle the situation correctly when
the low, high argument values are in reverse order (low > high)
with 'Val' type i32 (a corner case).
llvm-svn: 63388 | 
| | 
| 
| 
| 
| 
| | arbitrary integer width for the count.
llvm-svn: 59823 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | g++ -m32 -c -g -DIN_GCC -W -Wall -Wwrite-strings -Wmissing-format-attribute -fno-common -mdynamic-no-pic -DHAVE_CONFIG_H -Wno-unused -DTARGET_NAME=\"i386-apple-darwin9.5.0\" -I. -I. -I../../llvm-gcc.src/gcc -I../../llvm-gcc.src/gcc/. -I../../llvm-gcc.src/gcc/../include -I./../intl -I../../llvm-gcc.src/gcc/../libcpp/include  -I../../llvm-gcc.src/gcc/../libdecnumber -I../libdecnumber -I/Volumes/Sandbox/Buildbot/llvm/full-llvm/build/llvm.obj/include -I/Volumes/Sandbox/Buildbot/llvm/full-llvm/build/llvm.src/include -DENABLE_LLVM -I/Volumes/Sandbox/Buildbot/llvm/full-llvm/build/llvm.obj/../llvm.src/include  -D_DEBUG  -D_GNU_SOURCE -D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS   -I. -I. -I../../llvm-gcc.src/gcc -I../../llvm-gcc.src/gcc/. -I../../llvm-gcc.src/gcc/../include -I./../intl -I../../llvm-gcc.src/gcc/../libcpp/include  -I../../llvm-gcc.src/gcc/../libdecnumber -I../libdecnumber -I/Volumes/Sandbox/Buildbot/llvm/full-llvm/build/llvm.obj/include -I/Volumes/Sandbox/Buildbot/llvm/full-llvm/build/llvm.src/include ../../llvm-gcc.src/gcc/llvm-types.cpp -o llvm-types.o
../../llvm-gcc.src/gcc/llvm-convert.cpp: In member function 'void TreeToLLVM::EmitMemCpy(llvm::Value*, llvm::Value*, llvm::Value*, unsigned int)':
../../llvm-gcc.src/gcc/llvm-convert.cpp:1496: error: 'memcpy_i32' is not a member of 'llvm::Intrinsic'
../../llvm-gcc.src/gcc/llvm-convert.cpp:1496: error: 'memcpy_i64' is not a member of 'llvm::Intrinsic'
../../llvm-gcc.src/gcc/llvm-convert.cpp: In member function 'void TreeToLLVM::EmitMemMove(llvm::Value*, llvm::Value*, llvm::Value*, unsigned int)':
../../llvm-gcc.src/gcc/llvm-convert.cpp:1512: error: 'memmove_i32' is not a member of 'llvm::Intrinsic'
../../llvm-gcc.src/gcc/llvm-convert.cpp:1512: error: 'memmove_i64' is not a member of 'llvm::Intrinsic'
../../llvm-gcc.src/gcc/llvm-convert.cpp: In member function 'void TreeToLLVM::EmitMemSet(llvm::Value*, llvm::Value*, llvm::Value*, unsigned int)':
../../llvm-gcc.src/gcc/llvm-convert.cpp:1528: error: 'memset_i32' is not a member of 'llvm::Intrinsic'
../../llvm-gcc.src/gcc/llvm-convert.cpp:1528: error: 'memset_i64' is not a member of 'llvm::Intrinsic'
make[3]: *** [llvm-convert.o] Error 1
make[3]: *** Waiting for unfinished jobs....
rm fsf-funding.pod gcov.pod gfdl.pod cpp.pod gpl.pod gcc.pod
make[2]: *** [all-stage1-gcc] Error 2
make[1]: *** [stage1-bubble] Error 2
make: *** [all] Error 2
llvm-svn: 59809 | 
| | 
| 
| 
| | llvm-svn: 59802 | 
| | 
| 
| 
| | llvm-svn: 56468 | 
| | 
| 
| 
| | llvm-svn: 56456 | 
| | 
| 
| 
| 
| 
| | No functional change (and no FE change to generate them).
llvm-svn: 55753 | 
| | 
| 
| 
| 
| 
| | Legacy interfaces will be in place for some time.  (Merge from use-diet branch.)
llvm-svn: 51200 | 
| | 
| 
| 
| 
| 
| 
| 
| | Specifically, introduction of XXX::Create methods
for Users that have a potentially variable number of
Uses.
llvm-svn: 49277 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| | Codegen bits and llvm-gcc support will follow.
llvm-svn: 44182 | 
| | 
| 
| 
| | llvm-svn: 43020 | 
| | 
| 
| 
| | llvm-svn: 42537 | 
| | 
| 
| 
| | llvm-svn: 42439 | 
| | 
| 
| 
| 
| 
| 
| 
| | needed, because they just "mark" register
liveins and we let frontend solve type issue, not lowering code :)
llvm-svn: 41763 | 
| | 
| 
| 
| 
| 
| | Patch by Sterling Stein!
llvm-svn: 41758 | 
| | 
| 
| 
| 
| 
| | introduced by chandler's patch.
llvm-svn: 40864 | 
| | 
| 
| 
| 
| 
| 
| 
| | indexing an empty std::vector.
Updates to all clients.
llvm-svn: 40660 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | so must be lowered to a value, not nothing at all.
Subtle point: I made eh_selector return 0 and
eh_typeid_for return 1.  This means that only
cleanups (destructors) will be run as the exception
unwinds [if eh_typeid_for returned 0 then it would
be as if the first catch always matched, and the
corresponding handler would be run], which is
probably want you want in the CBE.
llvm-svn: 37947 | 
| | 
| 
| 
| 
| 
| | Drop the eh.filter intrinsic.
llvm-svn: 37875 | 
| | 
| 
| 
| | llvm-svn: 37608 | 
| | 
| 
| 
| | llvm-svn: 37544 | 
| | 
| 
| 
| | llvm-svn: 37397 | 
| | 
| 
| 
| | llvm-svn: 37331 | 
| | 
| 
| 
| | llvm-svn: 37071 | 
| | 
| 
| 
| 
| 
| | just aids in readability and debugability of the output. No functional change.
llvm-svn: 37037 | 
| | 
| 
| 
| | llvm-svn: 37006 | 
| | 
| 
| 
| | llvm-svn: 36180 | 
| | 
| 
| 
| 
| 
| 
| | linkage so we only end up with one of them in a program. These are, after
all overloaded and templatish in nature.
llvm-svn: 35956 | 
| | 
| 
| 
| 
| 
| | barf when CBE is run with a program that contains these intrinsics.
llvm-svn: 35946 | 
| | 
| 
| 
| 
| 
| | the size of the value, not just zext. Also, give better names to two BBs.
llvm-svn: 35945 | 
| | 
| 
| 
| 
| 
| | Implement the "part_set" intrinsic.
llvm-svn: 35938 | 
| | 
| 
| 
| 
| 
| | commit a LOT of files.
llvm-svn: 35858 | 
| | 
| 
| 
| | llvm-svn: 35678 | 
| | 
| 
| 
| 
| 
| 
| | Make sure that the CTPOP result is casted to i32 as the bit counting
intrinsics all return i32 now (this affects CTLZ and CTTZ as well).
llvm-svn: 35567 | 
| | 
| 
| 
| 
| 
| | Support overloaded intrinsics bswap, ctpop, cttz, ctlz.
llvm-svn: 35547 | 
| | 
| 
| 
| | llvm-svn: 34802 |