commit 7f5a3dad3dce6818d439861aac4e4865241dec9e
parent 3dabeec6b12fbb5764779bb4e233b262a6f2689f
Author: Russ Cox <rsc@swtch.com>
Date: Wed, 9 Jul 2008 13:47:23 -0400
libvx32/Linux: fix 64-bit bug
Diffstat:
1 file changed, 4 insertions(+), 3 deletions(-)
diff --git a/src/libvx32/linux.c b/src/libvx32/linux.c
@@ -129,6 +129,7 @@ static void dumpsigcontext(struct sigcontext *ctx)
#ifdef i386
#define VX32_BELIEVE_EIP (ctx->ds == vs - 8)
+#define ctxeip eip
#else
#define VX32_BELIEVE_EIP (ctx->cs == FLATCODE)
@@ -141,7 +142,7 @@ static void dumpsigcontext(struct sigcontext *ctx)
#define edi rdi
#define esp rsp
#define ebp rbp
-#define eip rip
+#define ctxeip rip
#endif
static void
@@ -177,7 +178,7 @@ int vx32_sighandler(int signo, siginfo_t *si, void *v)
: "=r" (vs));
if(0) vxprint("vx32_sighandler signo=%d eip=%#x esp=%#x vs=%#x\n",
- signo, ctx->eip, ctx->esp, vs);
+ signo, ctx->ctxeip, ctx->esp, vs);
if ((vs & 15) != 15) // 8 (emu), LDT, RPL=3
return 0;
@@ -204,7 +205,7 @@ int vx32_sighandler(int signo, siginfo_t *si, void *v)
// dumpsigcontext(ctx);
if (VX32_BELIEVE_EIP)
- trapeip = ctx->eip;
+ trapeip = ctx->ctxeip;
else
trapeip = 0xffffffff;