|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| | Factor some code better.
llvm-svn: 125006 | 
| | 
| 
| 
| 
| 
| 
| 
| | instcombine xform to exercise this.
Nothing forms exact udivs yet though.  This is progress on PR8862
llvm-svn: 124992 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | "this" pointer for any subclass of User, you could static_cast it to
User* and then reinterpret_cast that to Use* to get the end of the
operand list. This isn't a safe assumption in general, because the
static_cast might adjust the "this" pointer. Fixed by having these
OperandTraits classes take an extra template parameter, which is the
subclass of User. This is groundwork for PR889.
llvm-svn: 123235 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Add a unnamed_addr bit to global variables and functions. This will be used
to indicate that the address is not significant and therefore the constant
or function can be merged with others.
If an optimization pass can show that an address is not used, it can set this.
Examples of things that can have this set by the FE are globals created to
hold string literals and C++ constructors.
Adding unnamed_addr to a non-const global should have no effect unless
an optimization can transform that global into a constant.
Aliases are not allowed to have unnamed_addr since I couldn't figure
out any use for it.
llvm-svn: 123063 | 
| | 
| 
| 
| 
| 
| | a null pointer.
llvm-svn: 117551 | 
| | 
| 
| 
| 
| 
| 
| 
| | drastically reduce the linking time during LTO.
Patch by Shantonu Sen!
llvm-svn: 115728 | 
| | 
| 
| 
| | llvm-svn: 114974 | 
| | 
| 
| 
| | llvm-svn: 113764 | 
| | 
| 
| 
| 
| 
| 
| | (The Ada bindings probably need it too, but all the
obvious places to change say "do not edit this file".)
llvm-svn: 113618 | 
| | 
| 
| 
| 
| 
| | "llvm.eh.catch.all.value". Only the name needs to be changed.
llvm-svn: 113600 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | is different from what the code now uses in a two ways: NamedMDNodes
were considered Values and included in the numbering, and the
function-local metadata counter wasn't reset between functions.
The later problem breaks lazy deserialization, so instead of trying
to emulate the old numbering, just drop the old metadata. The only
in-tree use case is debug info with LTO, where the QOI loss is
considered acceptable.
llvm-svn: 113557 | 
| | 
| 
| 
| | llvm-svn: 113073 | 
| | 
| 
| 
| 
| 
| | being actively maintained, improved, or extended.
llvm-svn: 112356 | 
| | 
| 
| 
| | llvm-svn: 112083 | 
| | 
| 
| 
| 
| 
| 
| | from MDValueList between each function, now that the bitcode
writer is reusing the index space for function-local metadata.
llvm-svn: 112082 | 
| | 
| 
| 
| | llvm-svn: 112081 | 
| | 
| 
| 
| | llvm-svn: 112080 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | It's similar to "linker_private_weak", but it's known that the address of the
object is not taken. For instance, functions that had an inline definition, but
the compiler decided not to inline it. Note, unlike linker_private and
linker_private_weak, linker_private_weak_def_auto may have only default
visibility.  The symbols are removed by the linker from the final linked image
(executable or dynamic library).
llvm-svn: 111684 | 
| | 
| 
| 
| 
| 
| 
| 
| | not part of the IR, are not uniqued, and may be safely RAUW'd.
This replaces a variety of alternate mechanisms for achieving
the same effect.
llvm-svn: 111681 | 
| | 
| 
| 
| | llvm-svn: 111102 | 
| | 
| 
| 
| | llvm-svn: 111082 | 
| | 
| 
| 
| 
| 
| | for creating and populating NamedMDNodes.
llvm-svn: 109061 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Make MDNode::destroy private.
Fix the one thing that used MDNode::destroy, outside of MDNode itself.
One should never delete or destroy an MDNode explicitly. MDNodes
implicitly go away when there are no references to them (implementation
details aside).
llvm-svn: 109028 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | bitcode file, so that two bitcode files where the same metadata kind
name happens to have been assigned a different ID can still be
linked together.
Eliminate the restriction that metadata kind IDs can't be 0.
Change MD_dbg from 1 to 0, because we can now, and because it's
less mysterious that way.
llvm-svn: 108939 | 
| | 
| 
| 
| | llvm-svn: 108259 | 
| | 
| 
| 
| | llvm-svn: 107979 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Objective-C metadata types which should be marked as "weak", but which the
linker will remove upon final linkage. However, this linkage isn't specific to
Objective-C.
For example, the "objc_msgSend_fixup_alloc" symbol is defined like this:
      .globl l_objc_msgSend_fixup_alloc
      .weak_definition l_objc_msgSend_fixup_alloc
      .section __DATA, __objc_msgrefs, coalesced
      .align 3
l_objc_msgSend_fixup_alloc:
       .quad   _objc_msgSend_fixup
       .quad   L_OBJC_METH_VAR_NAME_1
This is different from the "linker_private" linkage type, because it can't have
the metadata defined with ".weak_definition".
Currently only supported on Darwin platforms.
llvm-svn: 107433 | 
| | 
| 
| 
| | llvm-svn: 107215 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | metadata types which should be marked as "weak", but which the linker will
remove upon final linkage. For example, the "objc_msgSend_fixup_alloc" symbol is
defined like this:
       .globl l_objc_msgSend_fixup_alloc
       .weak_definition l_objc_msgSend_fixup_alloc
       .section __DATA, __objc_msgrefs, coalesced
       .align 3
l_objc_msgSend_fixup_alloc:
        .quad   _objc_msgSend_fixup
        .quad   L_OBJC_METH_VAR_NAME_1
This is different from the "linker_private" linkage type, because it can't have
the metadata defined with ".weak_definition".
llvm-svn: 107205 | 
| | 
| 
| 
| | llvm-svn: 104915 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | having the bitcode writer materialize mdnodes for all the
debug location tuples when writing out the bc file and 
stores the information in a more compact form.  For example,
the -O0 -g bc file for combine.c in 176.gcc shrinks from
739392 to 512096 bytes.
This concludes my planned short-term debug info work.
llvm-svn: 100261 | 
| | 
| 
| 
| 
| 
| 
| | likely not a bitcode file at all, rather than being a bitcode file which
is truncated. Check for this case and issue a more relevant error message.
llvm-svn: 100156 | 
| | 
| 
| 
| 
| 
| | handling constant unions.
llvm-svn: 98680 | 
| | 
| 
| 
| | llvm-svn: 98662 | 
| | 
| 
| 
| | llvm-svn: 98656 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | keep track of instructions that return void) per-function. This fixes PR5278.
This breaks backwards compatibility with the metadata format. That's okay
because we haven't released the metadata bitcode yet.
llvm-svn: 97132 | 
| | 
| 
| 
| 
| 
| 
| | and T->isPointerTy().  Convert most instances of the first form to the second form.
Requested by Chris.
llvm-svn: 96344 | 
| | 
| 
| 
| 
| 
| | isInteger, we now have isFloatTy and isIntegerTy.  Requested by Chris!
llvm-svn: 96223 | 
| | 
| 
| 
| | llvm-svn: 96011 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Modules and ModuleProviders. Because the "ModuleProvider" simply materializes
GlobalValues now, and doesn't provide modules, it's renamed to
"GVMaterializer". Code that used to need a ModuleProvider to materialize
Functions can now materialize the Functions directly. Functions no longer use a
magic linkage to record that they're materializable; they simply ask the
GVMaterializer.
Because the C ABI must never change, we can't remove LLVMModuleProviderRef or
the functions that refer to it. Instead, because Module now exposes the same
functionality ModuleProvider used to, we store a Module* in any
LLVMModuleProviderRef and translate in the wrapper methods.  The bindings to
other languages still use the ModuleProvider concept.  It would probably be
worth some time to update them to follow the C++ more closely, but I don't
intend to do it.
Fixes http://llvm.org/PR5737 and http://llvm.org/PR5735.
llvm-svn: 94686 | 
| | 
| 
| 
| 
| 
| | of a forward-reference, which doesn't use an "abbrev" encoding.
llvm-svn: 94454 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | if one of the vectors didn't have elements (such as undef). Fixes PR 6096.
Fix an issue in the constant folder where fcmp (<2 x %ty>, <2 x %ty>) would
have <2 x i1> type if constant folding was successful and i1 type if it wasn't.
This exposed a related issue in the bitcode reader.
llvm-svn: 94069 | 
| | 
| 
| 
| | llvm-svn: 93337 | 
| | 
| 
| 
| | llvm-svn: 93165 | 
| | 
| 
| 
| 
| 
| 
| 
| | getWhenValsUnresolved().
Document PFS argument to ParseValID() and ConvertGlobalOrMetadataValIDToValue().
llvm-svn: 93108 | 
| | 
| 
| 
| | llvm-svn: 93042 | 
| | 
| 
| 
| 
| 
| | NamedMDNode record.
llvm-svn: 93037 | 
| | 
| 
| 
| | llvm-svn: 92783 | 
| | 
| 
| 
| | llvm-svn: 92761 | 
| | 
| 
| 
| 
| 
| | dereference the type pointer.
llvm-svn: 92726 |