Commit 40f01197 authored by Alistair Leslie-Hughes's avatar Alistair Leslie-Hughes Committed by Alexandre Julliard

dbghelp: Support UWOP_EPILOG in unwind.

parent 960bb369
...@@ -209,6 +209,19 @@ static void dump_unwind_info(struct cpu_stack_walk* csw, ULONG64 base, RUNTIME_F ...@@ -209,6 +209,19 @@ static void dump_unwind_info(struct cpu_stack_walk* csw, ULONG64 base, RUNTIME_F
case UWOP_PUSH_MACHFRAME: case UWOP_PUSH_MACHFRAME:
TRACE("PUSH_MACHFRAME %u\n", info->UnwindCode[i].u.OpInfo); TRACE("PUSH_MACHFRAME %u\n", info->UnwindCode[i].u.OpInfo);
break; break;
case UWOP_EPILOG:
if (info->Version == 2)
{
unsigned int offset;
if (info->UnwindCode[i].u.OpInfo)
offset = info->UnwindCode[i].u.CodeOffset;
else
offset = (info->UnwindCode[i+1].u.OpInfo << 8) + info->UnwindCode[i+1].u.CodeOffset;
TRACE("UWOP_EPILOG %u offset %u\n", info->UnwindCode[i].u.OpInfo, offset);
i += 1;
break;
}
/* Fall through */
default: default:
FIXME("unknown code %u\n", info->UnwindCode[i].u.UnwindOp); FIXME("unknown code %u\n", info->UnwindCode[i].u.UnwindOp);
break; break;
...@@ -490,7 +503,7 @@ static BOOL interpret_function_table_entry(struct cpu_stack_walk* csw, ...@@ -490,7 +503,7 @@ static BOOL interpret_function_table_entry(struct cpu_stack_walk* csw,
return FALSE; return FALSE;
} }
if (info->Version != 1) if (info->Version != 1 && info->Version != 2)
{ {
WARN("unknown unwind info version %u at %lx\n", info->Version, base + function->UnwindData); WARN("unknown unwind info version %u at %lx\n", info->Version, base + function->UnwindData);
return FALSE; return FALSE;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment