summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/alpha/alpha/db_interface.c96
1 files changed, 34 insertions, 62 deletions
diff --git a/sys/arch/alpha/alpha/db_interface.c b/sys/arch/alpha/alpha/db_interface.c
index 444b70c42ca..31d3aa988a5 100644
--- a/sys/arch/alpha/alpha/db_interface.c
+++ b/sys/arch/alpha/alpha/db_interface.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: db_interface.c,v 1.2 1997/07/06 17:19:25 niklas Exp $ */
+/* $OpenBSD: db_interface.c,v 1.3 1997/07/08 20:30:02 niklas Exp $ */
/*
* Copyright (c) 1997 Niklas Hallqvist. All rights reserverd.
@@ -13,23 +13,20 @@
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
- * This product includes software developed by the University of
- * California, Berkeley and its contributors.
- * 4. Neither the name of the University nor the names of its contributors
- * may be used to endorse or promote products derived from this software
- * without specific prior written permission.
+ * This product includes software developed by Niklas Hallqvist.
+ * 4. The name of the author may not be used to endorse or promote products
+ * derived from this software without specific prior written permission.
*
- * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+ * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include <sys/types.h>
@@ -55,6 +52,19 @@ void kdbprinttrap __P((int, int));
struct db_variable db_regs[] = {
{ "v0", (long *)&ddb_regs.tf_regs[FRAME_V0], FCN_NULL, },
+ { "a0", (long *)&ddb_regs.tf_regs[FRAME_A0], FCN_NULL, },
+ { "a1", (long *)&ddb_regs.tf_regs[FRAME_A1], FCN_NULL, },
+ { "a2", (long *)&ddb_regs.tf_regs[FRAME_A2], FCN_NULL, },
+ { "a3", (long *)&ddb_regs.tf_regs[FRAME_A3], FCN_NULL, },
+ { "a4", (long *)&ddb_regs.tf_regs[FRAME_A4], FCN_NULL, },
+ { "a5", (long *)&ddb_regs.tf_regs[FRAME_A5], FCN_NULL, },
+ { "s0", (long *)&ddb_regs.tf_regs[FRAME_S0], FCN_NULL, },
+ { "s1", (long *)&ddb_regs.tf_regs[FRAME_S1], FCN_NULL, },
+ { "s2", (long *)&ddb_regs.tf_regs[FRAME_S2], FCN_NULL, },
+ { "s3", (long *)&ddb_regs.tf_regs[FRAME_S3], FCN_NULL, },
+ { "s4", (long *)&ddb_regs.tf_regs[FRAME_S4], FCN_NULL, },
+ { "s5", (long *)&ddb_regs.tf_regs[FRAME_S5], FCN_NULL, },
+ { "s6", (long *)&ddb_regs.tf_regs[FRAME_S6], FCN_NULL, },
{ "t0", (long *)&ddb_regs.tf_regs[FRAME_T0], FCN_NULL, },
{ "t1", (long *)&ddb_regs.tf_regs[FRAME_T1], FCN_NULL, },
{ "t2", (long *)&ddb_regs.tf_regs[FRAME_T2], FCN_NULL, },
@@ -63,30 +73,17 @@ struct db_variable db_regs[] = {
{ "t5", (long *)&ddb_regs.tf_regs[FRAME_T5], FCN_NULL, },
{ "t6", (long *)&ddb_regs.tf_regs[FRAME_T6], FCN_NULL, },
{ "t7", (long *)&ddb_regs.tf_regs[FRAME_T7], FCN_NULL, },
- { "s0", (long *)&ddb_regs.tf_regs[FRAME_S0], FCN_NULL, },
- { "s1", (long *)&ddb_regs.tf_regs[FRAME_S1], FCN_NULL, },
- { "s2", (long *)&ddb_regs.tf_regs[FRAME_S2], FCN_NULL, },
- { "s3", (long *)&ddb_regs.tf_regs[FRAME_S3], FCN_NULL, },
- { "s4", (long *)&ddb_regs.tf_regs[FRAME_S4], FCN_NULL, },
- { "s5", (long *)&ddb_regs.tf_regs[FRAME_S5], FCN_NULL, },
- { "s6", (long *)&ddb_regs.tf_regs[FRAME_S6], FCN_NULL, },
- { "a3", (long *)&ddb_regs.tf_regs[FRAME_A3], FCN_NULL, },
- { "a4", (long *)&ddb_regs.tf_regs[FRAME_A4], FCN_NULL, },
- { "a5", (long *)&ddb_regs.tf_regs[FRAME_A5], FCN_NULL, },
{ "t8", (long *)&ddb_regs.tf_regs[FRAME_T8], FCN_NULL, },
{ "t9", (long *)&ddb_regs.tf_regs[FRAME_T9], FCN_NULL, },
{ "t10", (long *)&ddb_regs.tf_regs[FRAME_T10], FCN_NULL, },
{ "t11", (long *)&ddb_regs.tf_regs[FRAME_T11], FCN_NULL, },
- { "ra", (long *)&ddb_regs.tf_regs[FRAME_RA], FCN_NULL, },
{ "t12", (long *)&ddb_regs.tf_regs[FRAME_T12], FCN_NULL, },
{ "at", (long *)&ddb_regs.tf_regs[FRAME_AT], FCN_NULL, },
- { "sp", (long *)&ddb_regs.tf_regs[FRAME_SP], FCN_NULL, },
- { "ps", (long *)&ddb_regs.tf_regs[FRAME_PS], FCN_NULL, },
- { "pc", (long *)&ddb_regs.tf_regs[FRAME_PC], FCN_NULL, },
{ "gp", (long *)&ddb_regs.tf_regs[FRAME_GP], FCN_NULL, },
- { "a0", (long *)&ddb_regs.tf_regs[FRAME_A0], FCN_NULL, },
- { "a1", (long *)&ddb_regs.tf_regs[FRAME_A1], FCN_NULL, },
- { "a2", (long *)&ddb_regs.tf_regs[FRAME_A2], FCN_NULL, },
+ { "pc", (long *)&ddb_regs.tf_regs[FRAME_PC], FCN_NULL, },
+ { "ps", (long *)&ddb_regs.tf_regs[FRAME_PS], FCN_NULL, },
+ { "ra", (long *)&ddb_regs.tf_regs[FRAME_RA], FCN_NULL, },
+ { "sp", (long *)&ddb_regs.tf_regs[FRAME_SP], FCN_NULL, },
};
struct db_variable *db_eregs = db_regs + sizeof(db_regs)/sizeof(db_regs[0]);
@@ -171,16 +168,9 @@ kdb_trap(type, code, regs)
/* XXX Should switch to kdb`s own stack here. */
+ db_printf("db_regs at %p\n", regs);
ddb_regs = *regs;
-#if 0 /* XXX leave this until later */
- if (KERNELMODE(regs->tf_cs, regs->tf_eflags)) {
- /*
- * Kernel mode - esp and ss not saved
- */
- ddb_regs.tf_esp = (int)&regs->tf_esp; /* kernel stack pointer */
- asm("movw %%ss,%w0" : "=r" (ddb_regs.tf_ss));
- }
-#endif
+ ddb_regs.tf_regs[FRAME_SP] = (u_long)regs + FRAME_SW_SIZE*8;
s = splhigh();
db_active++;
@@ -190,25 +180,7 @@ kdb_trap(type, code, regs)
db_active--;
splx(s);
-#if 0 /* XXX save until later... */
- regs->tf_es = ddb_regs.tf_es;
- regs->tf_ds = ddb_regs.tf_ds;
- regs->tf_edi = ddb_regs.tf_edi;
- regs->tf_esi = ddb_regs.tf_esi;
- regs->tf_ebp = ddb_regs.tf_ebp;
- regs->tf_ebx = ddb_regs.tf_ebx;
- regs->tf_edx = ddb_regs.tf_edx;
- regs->tf_ecx = ddb_regs.tf_ecx;
- regs->tf_eax = ddb_regs.tf_eax;
- regs->tf_eip = ddb_regs.tf_eip;
- regs->tf_cs = ddb_regs.tf_cs;
- regs->tf_eflags = ddb_regs.tf_eflags;
- if (!KERNELMODE(regs->tf_cs, regs->tf_eflags)) {
- /* ring transit - saved esp and ss valid */
- regs->tf_esp = ddb_regs.tf_esp;
- regs->tf_ss = ddb_regs.tf_ss;
- }
-#endif
+ /* XXX set regs from ddb_regs here */
return (1);
}