|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | llvm-svn: 115996 | 
| | 
| 
| 
| | llvm-svn: 113073 | 
| | 
| 
| 
| | llvm-svn: 110460 | 
| | 
| 
| 
| | llvm-svn: 110410 | 
| | 
| 
| 
| 
| 
| 
| 
| | address of the static
ID member as the sole unique type identifier.  Clean up APIs related to this change.
llvm-svn: 110396 | 
| | 
| 
| 
| | llvm-svn: 109045 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | since it doesn't work for front-ends which don't emit column information
(which includes llvm-gcc in its present configuration), and doesn't
work for clang for K&R style variables where the variables are declared
in a different order from the parameter list.
Instead, make a separate pass through the instructions to collect the
llvm.dbg.declare instructions in order. This ensures that the debug
information for variables is emitted in this order.
llvm-svn: 108538 | 
| | 
| 
| 
| 
| 
| 
| 
| | independent of the order that isel happens to visit the dbg_declare
intrinsics. This fixes a bug in which the formal arguments were
being printed in reverse order, now that fast isel is going bottom up.
llvm-svn: 108369 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | JIT doesn't use the MC back-end asm printer to emit labels that it uses, the
section for the MCSymbol is never set. And thus the MCSymbol for the EH label
isn't marked as "defined". Because of that, TidyLandingPads removes the needed
landing pads from the JIT output. This breaks EH for every JIT program.
This is a work-around for this limitation. We pass in the label locations
map. If the label has a non-zero value, then it was "emitted" by the JIT and
TidyLandingPads shouldn't remove that label.
A nicer solution would be to mark the MCSymbol as "used" by the JIT and not rely
upon the section being set to determine if it's defined or not.
llvm-svn: 101453 | 
| | 
| 
| 
| | llvm-svn: 101385 | 
| | 
| 
| 
| | llvm-svn: 101334 | 
| | 
| 
| 
| | llvm-svn: 100508 | 
| | 
| 
| 
| | llvm-svn: 99227 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | to LLVM IR changes with addr label weirdness.  In the testcase, we
generate references to the two bb's when codegen'ing the first
function:
_test1:                                 ## @test1
	leaq	Ltmp0(%rip), %rax
..
	leaq	Ltmp1(%rip), %rax
Then continue to codegen the second function where the blocks
get merged.  We're now smart enough to emit both labels, producing
this code:
_test_fun:                              ## @test_fun
## BB#0:                                ## %entry
Ltmp1:                                  ## Block address taken
Ltmp0:
## BB#1:                                ## %ret
	movl	$-1, %eax
	ret
Rejoice.
llvm-svn: 98595 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | label is generated, but then the block is deleted.  Since the
value is undefined, we just emit the label right after the entry 
label of the function.  It might matter that the label is in the
same section as the function was afterall.
llvm-svn: 98579 | 
| | 
| 
| 
| 
| 
| 
| 
| | function, then the BB is RAUW'd before the definition is emitted.  There
are still two cases not being handled, but this should improve us back to
the situation before I touched anything.
llvm-svn: 98566 | 
| | 
| 
| 
| 
| 
| 
| | label instead of trying to form one based on the BB name (which
causes collisions if the name is empty).  This fixes PR6608
llvm-svn: 98495 | 
| | 
| 
| 
| 
| 
| | to get unique assembler temporary labels.
llvm-svn: 98489 | 
| | 
| 
| 
| 
| 
| 
| 
| | an MCSymbol.  Make the EH_LABEL MachineInstr hold its label
with an MCSymbol instead of ID.  Fix a bug in MMI.cpp which
would return labels named "Label4" instead of "label4".
llvm-svn: 98463 | 
| | 
| 
| 
| 
| 
| | them with a counter.
llvm-svn: 98462 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | instead of label ID's.  This cleans up and regularizes a bunch 
of code and makes way for future progress.
Unfortunately, this pointed out to me that JITDwarfEmitter.cpp
is largely copy and paste from DwarfException/MachineModuleInfo
and other places.  This is very sad and disturbing. :(
One major change here is that TidyLandingPads moved from being
called in DwarfException::BeginFunction to being called in
DwarfException::EndFunction.  There should not be any 
functionality change from doing this, but I'm not an EH expert.
llvm-svn: 98459 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and passing off ownership to AsmPrinter.  Now MachineModuleInfo
creates it and owns it by value.  This allows us to use MCSymbols
more consistently throughout the rest of the code generator, and
simplifies a bit of code.  This also allows MachineFunction to 
keep an MCContext reference handy, and cleans up the TargetRegistry
interfaces for AsmPrinters.
llvm-svn: 98450 | 
| | 
| 
| 
| 
| 
| 
| | and add a FIXME about how we are eventually going to zap this
lookup table once mc world domination is complete.
llvm-svn: 98031 | 
| | 
| 
| 
| | llvm-svn: 95488 | 
| | 
| 
| 
| 
| 
| 
| | This allows code gen and the exception table writer to cooperate to make sure
landing pads are associated with the correct invoke locations.
llvm-svn: 94726 | 
| | 
| 
| 
| | llvm-svn: 94097 | 
| | 
| 
| 
| 
| 
| | order for SjLj style exception handling.
llvm-svn: 94055 | 
| | 
| 
| 
| | llvm-svn: 89790 | 
| | 
| 
| 
| 
| 
| | make it permanent and remove old way of inserting intrinsics to encode debug info for line number and scopes.
llvm-svn: 87014 | 
| | 
| 
| 
| | llvm-svn: 83571 | 
| | 
| 
| 
| | llvm-svn: 83123 | 
| | 
| 
| 
| | llvm-svn: 82012 | 
| | 
| 
| 
| 
| 
| 
| | move MachineFunctionInfo virtual method out of line to give it
a home.
llvm-svn: 81940 | 
| | 
| 
| 
| 
| 
| | personality function.
llvm-svn: 80153 | 
| | 
| 
| 
| 
| 
| 
| | don't emit the default one. Explicitly check for the NULL
CIE later.
llvm-svn: 80146 | 
| | 
| 
| 
| | llvm-svn: 80145 | 
| | 
| 
| 
| | llvm-svn: 79842 | 
| | 
| 
| 
| | llvm-svn: 77754 | 
| | 
| 
| 
| 
| 
| | doesn't cause ".no_dead_strip" to be emitted on darwin.
llvm-svn: 76399 | 
| | 
| 
| 
| | llvm-svn: 76397 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This adds location info for all llvm_unreachable calls (which is a macro now) in
!NDEBUG builds.
In NDEBUG builds location info and the message is off (it only prints
"UREACHABLE executed").
llvm-svn: 75640 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| | redundant labels is referenced by debug info somewhere else. This patch provies a way so that dwarf writer can mark labels as used.
llvm-svn: 68813 | 
| | 
| 
| 
| | llvm-svn: 63653 | 
| | 
| 
| 
| | llvm-svn: 63198 | 
| | 
| 
| 
| 
| 
| | hierarchy) that were used to handle debug info.
llvm-svn: 62199 | 
| | 
| 
| 
| 
| 
| | between AsmPrinter and CodeGen.
llvm-svn: 62191 | 
| | 
| 
| 
| 
| 
| 
| | - Emit DW_AT_byte_size for struct and union of size zero.
- Emit DW_AT_declaration for forward type declaration.
llvm-svn: 60812 | 
| | 
| 
| 
| 
| 
| 
| | an array that is empty.  Instead of requiring this array, allow a null pointer.
This shrinks all forward references of structs.
llvm-svn: 58959 | 
| | 
| 
| 
| 
| 
| 
| 
| | because it declares a std::vector<MachineMove>, and strict
concept checking requires the definition of MachineMove to be
available.
llvm-svn: 57617 |