The JIT calls TidyLandingPads to tidy up the landing pads. However, because the
authorBill Wendling <isanbard@gmail.com>
Fri, 16 Apr 2010 08:46:10 +0000 (08:46 +0000)
committerBill Wendling <isanbard@gmail.com>
Fri, 16 Apr 2010 08:46:10 +0000 (08:46 +0000)
commit47639fc5be0b8f4873d076a9ed24b9a3c0682b15
tree0e7b9e63cfb4a26799db1de4dbf68d83dc7098c9
parent8b5d9c89146c012f8e532c03720814b84b4ee359
The JIT calls TidyLandingPads to tidy up the landing pads. However, because the
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.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@101453 91177308-0d34-0410-b5e6-96231b3b80d8
include/llvm/CodeGen/JITCodeEmitter.h
include/llvm/CodeGen/MachineModuleInfo.h
lib/CodeGen/MachineModuleInfo.cpp
lib/ExecutionEngine/JIT/JITDwarfEmitter.cpp
lib/ExecutionEngine/JIT/JITEmitter.cpp