summaryrefslogtreecommitdiffstats
path: root/llvm/lib/MC/MCStreamer.cpp
diff options
context:
space:
mode:
authorKai Nacke <kai.nacke@redstar.de>2013-08-27 04:16:16 +0000
committerKai Nacke <kai.nacke@redstar.de>2013-08-27 04:16:16 +0000
commit1b7e4866f41c360b85cfe74d419084550166ec7b (patch)
treeb038bd06b5e195b5a551e27e562aba01ea1e98ad /llvm/lib/MC/MCStreamer.cpp
parentbc839fcd3e7830616ca4e9c687459aab886eb91e (diff)
downloadbcm5719-llvm-1b7e4866f41c360b85cfe74d419084550166ec7b.tar.gz
bcm5719-llvm-1b7e4866f41c360b85cfe74d419084550166ec7b.zip
Fix wrong code offset for unwind code SET_FPREG.
The code offset for unwind code SET_FPREG is wrong because it is set to constant 0. The fix is to do the same as for the other unwind codes: emit a label and later the absolute difference between the label and the begin of the prologue. Also enables the failing test case MC/COFF/seh.s Reviewed by Jim Grosbach, Charles Davis and Nico Rieck. llvm-svn: 189309
Diffstat (limited to 'llvm/lib/MC/MCStreamer.cpp')
-rw-r--r--llvm/lib/MC/MCStreamer.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/llvm/lib/MC/MCStreamer.cpp b/llvm/lib/MC/MCStreamer.cpp
index 6542f42a03b..fb43a4adbda 100644
--- a/llvm/lib/MC/MCStreamer.cpp
+++ b/llvm/lib/MC/MCStreamer.cpp
@@ -470,7 +470,9 @@ void MCStreamer::EmitWin64EHSetFrame(unsigned Register, unsigned Offset) {
report_fatal_error("Frame register and offset already specified!");
if (Offset & 0x0F)
report_fatal_error("Misaligned frame pointer offset!");
- MCWin64EHInstruction Inst(Win64EH::UOP_SetFPReg, 0, Register, Offset);
+ MCSymbol *Label = getContext().CreateTempSymbol();
+ MCWin64EHInstruction Inst(Win64EH::UOP_SetFPReg, Label, Register, Offset);
+ EmitLabel(Label);
CurFrame->LastFrameInst = CurFrame->Instructions.size();
CurFrame->Instructions.push_back(Inst);
}
OpenPOWER on IntegriCloud