forked from OSchip/llvm-project
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 Charles Davis and Nico Rieck. llvm-svn: 185758
This commit is contained in:
parent
3d90a8f4f9
commit
66bfdb8354
|
@ -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);
|
||||
}
|
||||
|
|
|
@ -64,7 +64,7 @@ static void EmitAbsDifference(MCStreamer &streamer, MCSymbol *lhs,
|
|||
|
||||
static void EmitUnwindCode(MCStreamer &streamer, MCSymbol *begin,
|
||||
MCWin64EHInstruction &inst) {
|
||||
uint8_t b1, b2;
|
||||
uint8_t b2;
|
||||
uint16_t w;
|
||||
b2 = (inst.getOperation() & 0x0F);
|
||||
switch (inst.getOperation()) {
|
||||
|
@ -93,8 +93,7 @@ static void EmitUnwindCode(MCStreamer &streamer, MCSymbol *begin,
|
|||
streamer.EmitIntValue(b2, 1);
|
||||
break;
|
||||
case Win64EH::UOP_SetFPReg:
|
||||
b1 = inst.getOffset() & 0xF0;
|
||||
streamer.EmitIntValue(b1, 1);
|
||||
EmitAbsDifference(streamer, inst.getLabel(), begin);
|
||||
streamer.EmitIntValue(b2, 1);
|
||||
break;
|
||||
case Win64EH::UOP_SaveNonVol:
|
||||
|
|
|
@ -1,7 +1,5 @@
|
|||
// This test checks that the SEH directives emit the correct unwind data.
|
||||
|
||||
// TODO: Expected fail because SET_FPREG has a wrong offset.
|
||||
// XFAIL: *
|
||||
// RUN: llvm-mc -triple x86_64-pc-win32 -filetype=obj %s | llvm-readobj -s -u | FileCheck %s
|
||||
|
||||
// CHECK: Sections [
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
// CHECK-NEXT: Frame register: RBX
|
||||
// CHECK-NEXT: Frame offset: 0
|
||||
// CHECK-NEXT: Unwind Codes:
|
||||
// CHECK-NEXT: 0x00: UOP_SetFPReg
|
||||
// CHECK-NEXT: 0x12: UOP_SetFPReg
|
||||
// CHECK-NEXT: 0x0f: UOP_PushNonVol RBX
|
||||
// CHECK-NEXT: 0x0e: UOP_SaveXMM128 XMM8 [0x0000]
|
||||
// CHECK-NEXT: 0x09: UOP_SaveNonVol RSI [0x0010]
|
||||
|
|
Loading…
Reference in New Issue