mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-16 14:31:59 +00:00
Fix assertion when C++ EH filters are present in functions using SEH
Should fix PR22305. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@226969 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
eabbe07449
commit
339591e0a9
@ -221,12 +221,11 @@ void Win64Exception::emitCSpecificHandlerTable() {
|
||||
|
||||
// Do a parallel iteration across typeids and clause labels, skipping filter
|
||||
// clauses.
|
||||
assert(LPad->TypeIds.size() == LPad->ClauseLabels.size());
|
||||
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];
|
||||
MCSymbol *ClauseLabel = LPad->ClauseLabels[I];
|
||||
|
||||
// Ignore C++ filter clauses in SEH.
|
||||
// FIXME: Implement cleanup clauses.
|
||||
@ -243,6 +242,7 @@ void Win64Exception::emitCSpecificHandlerTable() {
|
||||
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);
|
||||
}
|
||||
}
|
||||
|
21
test/CodeGen/X86/seh-filter.ll
Normal file
21
test/CodeGen/X86/seh-filter.ll
Normal file
@ -0,0 +1,21 @@
|
||||
; RUN: llc -O0 -mtriple=x86_64-windows-msvc < %s | FileCheck %s
|
||||
|
||||
declare void @g()
|
||||
define void @f() {
|
||||
invoke void @g() to label %return unwind label %lpad
|
||||
|
||||
return:
|
||||
ret void
|
||||
|
||||
lpad:
|
||||
%ehptrs = landingpad {i8*, i32} personality i8* bitcast (i32 (...)* @__C_specific_handler to i8*)
|
||||
filter [0 x i8*] zeroinitializer
|
||||
call void @__cxa_call_unexpected(i8* null)
|
||||
unreachable
|
||||
}
|
||||
declare i32 @__C_specific_handler(...)
|
||||
declare void @__cxa_call_unexpected(i8*)
|
||||
|
||||
; We don't emit entries for filters.
|
||||
; CHECK: .seh_handlerdata
|
||||
; CHECK: .long 0
|
Loading…
x
Reference in New Issue
Block a user