diff options
author | Reid Kleckner <reid@kleckner.net> | 2015-04-21 18:23:57 +0000 |
---|---|---|
committer | Reid Kleckner <reid@kleckner.net> | 2015-04-21 18:23:57 +0000 |
commit | d2a1a519965155c3509204498849126c59ce73de (patch) | |
tree | 6b39981f5ff0e443326c39a1b6469fc938604168 /llvm/lib/CodeGen/MachineModuleInfo.cpp | |
parent | d0a2ae054fe39ba3e499c5415a62915477acaf3e (diff) | |
download | llvm-d2a1a519965155c3509204498849126c59ce73de.zip llvm-d2a1a519965155c3509204498849126c59ce73de.tar.gz llvm-d2a1a519965155c3509204498849126c59ce73de.tar.bz2 |
Re-land r235154-r235156 under the existing -sehprepare flag
Keep the old SEH fan-in lowering on by default for now, since projects
rely on it. This will make it easy to test this change with a simple
flag flip.
llvm-svn: 235399
Diffstat (limited to 'llvm/lib/CodeGen/MachineModuleInfo.cpp')
-rw-r--r-- | llvm/lib/CodeGen/MachineModuleInfo.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/MachineModuleInfo.cpp b/llvm/lib/CodeGen/MachineModuleInfo.cpp index e8bd1f8..e4f2aea 100644 --- a/llvm/lib/CodeGen/MachineModuleInfo.cpp +++ b/llvm/lib/CodeGen/MachineModuleInfo.cpp @@ -469,6 +469,25 @@ MachineModuleInfo::addClauseForLandingPad(MachineBasicBlock *LandingPad) { return ClauseLabel; } +void MachineModuleInfo::addSEHCatchHandler(MachineBasicBlock *LandingPad, + const Function *Filter, + const BlockAddress *RecoverBA) { + LandingPadInfo &LP = getOrCreateLandingPadInfo(LandingPad); + SEHHandler Handler; + Handler.FilterOrFinally = Filter; + Handler.RecoverBA = RecoverBA; + LP.SEHHandlers.push_back(Handler); +} + +void MachineModuleInfo::addSEHCleanupHandler(MachineBasicBlock *LandingPad, + const Function *Cleanup) { + LandingPadInfo &LP = getOrCreateLandingPadInfo(LandingPad); + SEHHandler Handler; + Handler.FilterOrFinally = Cleanup; + Handler.RecoverBA = nullptr; + LP.SEHHandlers.push_back(Handler); +} + /// TidyLandingPads - Remap landing pad labels and remove any deleted landing /// pads. void MachineModuleInfo::TidyLandingPads(DenseMap<MCSymbol*, uintptr_t> *LPMap) { |