summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorCharles Davis <cdavis@mines.edu>2011-05-19 04:04:13 +0000
committerCharles Davis <cdavis@mines.edu>2011-05-19 04:04:13 +0000
commitb4222589bfc0b80b4e4248c62ae901a9e77445f4 (patch)
treeafe3fd9027d6ff114c8b1eeaf74740a32b787717 /llvm/lib
parentaf247d7b98c9bfac07602907c34a4bf5bac806b0 (diff)
downloadbcm5719-llvm-b4222589bfc0b80b4e4248c62ae901a9e77445f4.tar.gz
bcm5719-llvm-b4222589bfc0b80b4e4248c62ae901a9e77445f4.zip
Implement the StartChained and EndChained Win64 EH methods on MCStreamer.
llvm-svn: 131629
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/MC/MCStreamer.cpp36
1 files changed, 23 insertions, 13 deletions
diff --git a/llvm/lib/MC/MCStreamer.cpp b/llvm/lib/MC/MCStreamer.cpp
index ed73c1b3a34..4163198e394 100644
--- a/llvm/lib/MC/MCStreamer.cpp
+++ b/llvm/lib/MC/MCStreamer.cpp
@@ -310,20 +310,19 @@ void MCStreamer::EmitCFISameValue(int64_t Register) {
CurFrame->Instructions.push_back(Instruction);
}
-MCWin64EHUnwindInfo *MCStreamer::getCurrentW64UnwindInfo() {
- if (W64UnwindInfos.empty())
- return NULL;
- return &W64UnwindInfos.back();
+void MCStreamer::setCurrentW64UnwindInfo(MCWin64EHUnwindInfo *Frame) {
+ W64UnwindInfos.push_back(*Frame);
+ CurrentW64UnwindInfo = &W64UnwindInfos.back();
}
void MCStreamer::EnsureValidW64UnwindInfo() {
- MCWin64EHUnwindInfo *CurFrame = getCurrentW64UnwindInfo();
+ MCWin64EHUnwindInfo *CurFrame = CurrentW64UnwindInfo;
if (!CurFrame || CurFrame->End)
report_fatal_error("No open Win64 EH frame function!");
}
void MCStreamer::EmitWin64EHStartProc(MCSymbol *Symbol, MCSymbol *EHandler) {
- MCWin64EHUnwindInfo *CurFrame = getCurrentW64UnwindInfo();
+ MCWin64EHUnwindInfo *CurFrame = CurrentW64UnwindInfo;
if (CurFrame && !CurFrame->End)
report_fatal_error("Starting a function before ending the previous one!");
MCWin64EHUnwindInfo Frame;
@@ -331,13 +330,13 @@ void MCStreamer::EmitWin64EHStartProc(MCSymbol *Symbol, MCSymbol *EHandler) {
Frame.Function = Symbol;
Frame.ExceptionHandler = EHandler;
EmitLabel(Frame.Begin);
- W64UnwindInfos.push_back(Frame);
+ setCurrentW64UnwindInfo(&Frame);
}
void MCStreamer::EmitWin64EHEndProc() {
EnsureValidW64UnwindInfo();
- MCWin64EHUnwindInfo *CurFrame = getCurrentW64UnwindInfo();
- if (CurFrame->Chained)
+ MCWin64EHUnwindInfo *CurFrame = CurrentW64UnwindInfo;
+ if (CurFrame->ChainedParent)
report_fatal_error("Not all chained regions terminated!");
CurFrame->End = getContext().CreateTempSymbol();
EmitLabel(CurFrame->End);
@@ -345,14 +344,25 @@ void MCStreamer::EmitWin64EHEndProc() {
void MCStreamer::EmitWin64EHStartChained()
{
- errs() << "Not implemented yet\n";
- abort();
+ EnsureValidW64UnwindInfo();
+ MCWin64EHUnwindInfo Frame;
+ MCWin64EHUnwindInfo *CurFrame = CurrentW64UnwindInfo;
+ Frame.Begin = getContext().CreateTempSymbol();
+ Frame.Function = CurFrame->Function;
+ Frame.ChainedParent = CurFrame;
+ EmitLabel(Frame.Begin);
+ setCurrentW64UnwindInfo(&Frame);
}
void MCStreamer::EmitWin64EHEndChained()
{
- errs() << "Not implemented yet\n";
- abort();
+ EnsureValidW64UnwindInfo();
+ MCWin64EHUnwindInfo *CurFrame = CurrentW64UnwindInfo;
+ if (!CurFrame->ChainedParent)
+ report_fatal_error("End of a chained region outside a chained region!");
+ CurFrame->End = getContext().CreateTempSymbol();
+ EmitLabel(CurFrame->End);
+ CurrentW64UnwindInfo = CurFrame->ChainedParent;
}
void MCStreamer::EmitWin64EHUnwindOnly()
OpenPOWER on IntegriCloud