summaryrefslogtreecommitdiffstats
path: root/llvm/lib/MC/MCStreamer.cpp
diff options
context:
space:
mode:
authorCharles Davis <cdavis@mines.edu>2011-05-26 02:45:47 +0000
committerCharles Davis <cdavis@mines.edu>2011-05-26 02:45:47 +0000
commit006e1c39d0e17370352780ce9ffedda63b66f6bf (patch)
tree78549e51f38cb1a0e879fa707118f36e47a4d9e2 /llvm/lib/MC/MCStreamer.cpp
parent276f231c2f254c02b19a019346379c602ffbf3fa (diff)
downloadbcm5719-llvm-006e1c39d0e17370352780ce9ffedda63b66f6bf.tar.gz
bcm5719-llvm-006e1c39d0e17370352780ce9ffedda63b66f6bf.zip
Test .seh_startchained and .seh_endchained parsing.
Rework how the MCWin64EHUnwindInfo instances are stored. Fix issues with chained unwind areas exposed by the test that were related to this. The ChainedParent field had the wrong address, because when the chained unwind info was added, the addresses shifted around. Now we store the pointers to the structures, which are now allocated from the MC heap. llvm-svn: 132106
Diffstat (limited to 'llvm/lib/MC/MCStreamer.cpp')
-rw-r--r--llvm/lib/MC/MCStreamer.cpp26
1 files changed, 13 insertions, 13 deletions
diff --git a/llvm/lib/MC/MCStreamer.cpp b/llvm/lib/MC/MCStreamer.cpp
index 19aeaafc722..9957a76ba38 100644
--- a/llvm/lib/MC/MCStreamer.cpp
+++ b/llvm/lib/MC/MCStreamer.cpp
@@ -307,8 +307,8 @@ void MCStreamer::EmitCFISameValue(int64_t Register) {
}
void MCStreamer::setCurrentW64UnwindInfo(MCWin64EHUnwindInfo *Frame) {
- W64UnwindInfos.push_back(*Frame);
- CurrentW64UnwindInfo = &W64UnwindInfos.back();
+ W64UnwindInfos.push_back(Frame);
+ CurrentW64UnwindInfo = W64UnwindInfos.back();
}
void MCStreamer::EnsureValidW64UnwindInfo() {
@@ -321,11 +321,11 @@ void MCStreamer::EmitWin64EHStartProc(const MCSymbol *Symbol) {
MCWin64EHUnwindInfo *CurFrame = CurrentW64UnwindInfo;
if (CurFrame && !CurFrame->End)
report_fatal_error("Starting a function before ending the previous one!");
- MCWin64EHUnwindInfo Frame;
- Frame.Begin = getContext().CreateTempSymbol();
- Frame.Function = Symbol;
- EmitLabel(Frame.Begin);
- setCurrentW64UnwindInfo(&Frame);
+ MCWin64EHUnwindInfo *Frame = new (getContext()) MCWin64EHUnwindInfo;
+ Frame->Begin = getContext().CreateTempSymbol();
+ Frame->Function = Symbol;
+ EmitLabel(Frame->Begin);
+ setCurrentW64UnwindInfo(Frame);
}
void MCStreamer::EmitWin64EHEndProc() {
@@ -339,13 +339,13 @@ void MCStreamer::EmitWin64EHEndProc() {
void MCStreamer::EmitWin64EHStartChained() {
EnsureValidW64UnwindInfo();
- MCWin64EHUnwindInfo Frame;
+ MCWin64EHUnwindInfo *Frame = new (getContext()) MCWin64EHUnwindInfo;
MCWin64EHUnwindInfo *CurFrame = CurrentW64UnwindInfo;
- Frame.Begin = getContext().CreateTempSymbol();
- Frame.Function = CurFrame->Function;
- Frame.ChainedParent = CurFrame;
- EmitLabel(Frame.Begin);
- setCurrentW64UnwindInfo(&Frame);
+ Frame->Begin = getContext().CreateTempSymbol();
+ Frame->Function = CurFrame->Function;
+ Frame->ChainedParent = CurFrame;
+ EmitLabel(Frame->Begin);
+ setCurrentW64UnwindInfo(Frame);
}
void MCStreamer::EmitWin64EHEndChained() {
OpenPOWER on IntegriCloud