mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-13 20:25:12 +00:00
Revert "[SEH] Remove the old __C_specific_handler code now that WinEHPrepare works"
We still have some "uses remain after removal" issues in -O0 builds. This reverts commit r235557. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@235617 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -206,6 +206,12 @@ void Win64Exception::emitCSpecificHandlerTable() {
|
||||
for (const CallSiteEntry &CSE : CallSites) {
|
||||
if (!CSE.LPad)
|
||||
continue; // Ignore gaps.
|
||||
for (int Selector : CSE.LPad->TypeIds) {
|
||||
// Ignore C++ filter clauses in SEH.
|
||||
// FIXME: Implement cleanup clauses.
|
||||
if (isCatchEHSelector(Selector))
|
||||
++NumEntries;
|
||||
}
|
||||
NumEntries += CSE.LPad->SEHHandlers.size();
|
||||
}
|
||||
Asm->OutStreamer.EmitIntValue(NumEntries, 4);
|
||||
@ -261,6 +267,40 @@ void Win64Exception::emitCSpecificHandlerTable() {
|
||||
else
|
||||
Asm->OutStreamer.EmitIntValue(0, 4);
|
||||
}
|
||||
if (!LPad->SEHHandlers.empty())
|
||||
continue;
|
||||
|
||||
// These aren't really type info globals, they are actually pointers to
|
||||
// filter functions ordered by selector. The zero selector is used for
|
||||
// cleanups, so slot zero corresponds to selector 1.
|
||||
const std::vector<const GlobalValue *> &SelectorToFilter = MMI->getTypeInfos();
|
||||
|
||||
// Do a parallel iteration across typeids and clause labels, skipping filter
|
||||
// clauses.
|
||||
size_t NextClauseLabel = 0;
|
||||
for (size_t I = 0, E = LPad->TypeIds.size(); I < E; ++I) {
|
||||
// AddLandingPadInfo stores the clauses in reverse, but there is a FIXME
|
||||
// to change that.
|
||||
int Selector = LPad->TypeIds[E - I - 1];
|
||||
|
||||
// Ignore C++ filter clauses in SEH.
|
||||
// FIXME: Implement cleanup clauses.
|
||||
if (!isCatchEHSelector(Selector))
|
||||
continue;
|
||||
|
||||
Asm->OutStreamer.EmitValue(Begin, 4);
|
||||
Asm->OutStreamer.EmitValue(End, 4);
|
||||
if (isCatchEHSelector(Selector)) {
|
||||
assert(unsigned(Selector - 1) < SelectorToFilter.size());
|
||||
const GlobalValue *TI = SelectorToFilter[Selector - 1];
|
||||
if (TI) // Emit the filter function pointer.
|
||||
Asm->OutStreamer.EmitValue(createImageRel32(Asm->getSymbol(TI)), 4);
|
||||
else // Otherwise, this is a "catch i8* null", or catch all.
|
||||
Asm->OutStreamer.EmitIntValue(1, 4);
|
||||
}
|
||||
MCSymbol *ClauseLabel = LPad->ClauseLabels[NextClauseLabel++];
|
||||
Asm->OutStreamer.EmitValue(createImageRel32(ClauseLabel), 4);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user