summaryrefslogtreecommitdiffstats
path: root/sys/amd64
diff options
context:
space:
mode:
authorpeter <peter@FreeBSD.org>2003-05-30 01:02:52 +0000
committerpeter <peter@FreeBSD.org>2003-05-30 01:02:52 +0000
commitdaf35023f114f63a899345482ef7e3a06bf01b2a (patch)
treeac3c4776264d84d0ca504e0bbb02f12e51abd1e0 /sys/amd64
parent089f04e92b4b018894abb3c571d7e2f6fa9fc57a (diff)
downloadFreeBSD-src-daf35023f114f63a899345482ef7e3a06bf01b2a.zip
FreeBSD-src-daf35023f114f63a899345482ef7e3a06bf01b2a.tar.gz
Nasty 'make it compile' port to amd64. Note that it needs some other
wire protocol for the extra registers. I should probably just remove it from here for now since its quite useless. Approved by: re (amd64/* blanket)
Diffstat (limited to 'sys/amd64')
-rw-r--r--sys/amd64/amd64/amd64-gdbstub.c78
1 files changed, 40 insertions, 38 deletions
diff --git a/sys/amd64/amd64/amd64-gdbstub.c b/sys/amd64/amd64/amd64-gdbstub.c
index 0ea0a24..1eae804 100644
--- a/sys/amd64/amd64/amd64-gdbstub.c
+++ b/sys/amd64/amd64/amd64-gdbstub.c
@@ -420,16 +420,16 @@ gdb_handle_exception (db_regs_t *raw_regs, int type, int code)
int addr, length;
char * ptr;
struct i386regs {
- unsigned int eax;
- unsigned int ecx;
- unsigned int edx;
- unsigned int ebx;
- unsigned int esp;
- unsigned int ebp;
- unsigned int esi;
- unsigned int edi;
- unsigned int eip;
- unsigned int eflags;
+ unsigned int rax;
+ unsigned int rcx;
+ unsigned int rdx;
+ unsigned int rbx;
+ unsigned int rsp;
+ unsigned int rbp;
+ unsigned int rsi;
+ unsigned int rdi;
+ unsigned int rip;
+ unsigned int rflags;
unsigned int cs;
unsigned int ss;
unsigned int ds;
@@ -437,23 +437,23 @@ gdb_handle_exception (db_regs_t *raw_regs, int type, int code)
};
struct i386regs registers;
- registers.eax = raw_regs->tf_eax;
- registers.ebx = raw_regs->tf_ebx;
- registers.ecx = raw_regs->tf_ecx;
- registers.edx = raw_regs->tf_edx;
+ registers.rax = raw_regs->tf_rax;
+ registers.rbx = raw_regs->tf_rbx;
+ registers.rcx = raw_regs->tf_rcx;
+ registers.rdx = raw_regs->tf_rdx;
- registers.esp = raw_regs->tf_esp;
- registers.ebp = raw_regs->tf_ebp;
- registers.esi = raw_regs->tf_esi;
- registers.edi = raw_regs->tf_edi;
+ registers.rsp = raw_regs->tf_rsp;
+ registers.rbp = raw_regs->tf_rbp;
+ registers.rsi = raw_regs->tf_rsi;
+ registers.rdi = raw_regs->tf_rdi;
- registers.eip = raw_regs->tf_eip;
- registers.eflags = raw_regs->tf_eflags;
+ registers.rip = raw_regs->tf_rip;
+ registers.rflags = raw_regs->tf_rflags;
registers.cs = raw_regs->tf_cs;
registers.ss = raw_regs->tf_ss;
- registers.ds = raw_regs->tf_ds;
- registers.es = raw_regs->tf_es;
+ registers.ds = 0; /* XXX rds() */
+ registers.es = 0; /* XXX res() */
/* reply to host that an exception has occurred */
sigval = computeSignal (type);
@@ -466,19 +466,19 @@ gdb_handle_exception (db_regs_t *raw_regs, int type, int code)
*ptr++ = hexchars[PC >> 4];
*ptr++ = hexchars[PC & 0xf];
*ptr++ = ':';
- ptr = mem2hex ((vm_offset_t)&registers.eip, ptr, 4);
+ ptr = mem2hex ((vm_offset_t)&registers.rip, ptr, 4);
*ptr++ = ';';
*ptr++ = hexchars[FP >> 4];
*ptr++ = hexchars[FP & 0xf];
*ptr++ = ':';
- ptr = mem2hex ((vm_offset_t)&registers.ebp, ptr, 4);
+ ptr = mem2hex ((vm_offset_t)&registers.rbp, ptr, 4);
*ptr++ = ';';
*ptr++ = hexchars[SP >> 4];
*ptr++ = hexchars[SP & 0xf];
*ptr++ = ':';
- ptr = mem2hex ((vm_offset_t)&registers.esp, ptr, 4);
+ ptr = mem2hex ((vm_offset_t)&registers.rsp, ptr, 4);
*ptr++ = ';';
*ptr++ = 0;
@@ -577,32 +577,34 @@ gdb_handle_exception (db_regs_t *raw_regs, int type, int code)
ptr = &remcomInBuffer[1];
if (hexToInt(&ptr,&addr))
- registers.eip = addr;
+ registers.rip = addr;
/* set the trace bit if we're stepping */
if (remcomInBuffer[0] == 's')
- registers.eflags |= PSL_T;
+ registers.rflags |= PSL_T;
else
- registers.eflags &= ~PSL_T;
+ registers.rflags &= ~PSL_T;
- raw_regs->tf_eax = registers.eax;
- raw_regs->tf_ebx = registers.ebx;
- raw_regs->tf_ecx = registers.ecx;
- raw_regs->tf_edx = registers.edx;
+ raw_regs->tf_rax = registers.rax;
+ raw_regs->tf_rbx = registers.rbx;
+ raw_regs->tf_rcx = registers.rcx;
+ raw_regs->tf_rdx = registers.rdx;
- raw_regs->tf_esp = registers.esp;
- raw_regs->tf_ebp = registers.ebp;
- raw_regs->tf_esi = registers.esi;
- raw_regs->tf_edi = registers.edi;
+ raw_regs->tf_rsp = registers.rsp;
+ raw_regs->tf_rbp = registers.rbp;
+ raw_regs->tf_rsi = registers.rsi;
+ raw_regs->tf_rdi = registers.rdi;
- raw_regs->tf_eip = registers.eip;
- raw_regs->tf_eflags = registers.eflags;
+ raw_regs->tf_rip = registers.rip;
+ raw_regs->tf_rflags = registers.rflags;
raw_regs->tf_cs = registers.cs;
raw_regs->tf_ss = registers.ss;
+#if 0
raw_regs->tf_ds = registers.ds;
raw_regs->tf_es = registers.es;
+#endif
return 0;
} /* switch */
OpenPOWER on IntegriCloud