From owner-p4-projects@FreeBSD.ORG Fri May 30 20:10:37 2003 Return-Path: Delivered-To: p4-projects@freebsd.org Received: by hub.freebsd.org (Postfix, from userid 32767) id 9956937B404; Fri, 30 May 2003 20:10:36 -0700 (PDT) Delivered-To: perforce@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id DFF0037B404 for ; Fri, 30 May 2003 20:10:35 -0700 (PDT) Received: from repoman.freebsd.org (repoman.freebsd.org [216.136.204.115]) by mx1.FreeBSD.org (Postfix) with ESMTP id 8594443FB1 for ; Fri, 30 May 2003 20:10:35 -0700 (PDT) (envelope-from jmallett@freebsd.org) Received: from repoman.freebsd.org (localhost [127.0.0.1]) by repoman.freebsd.org (8.12.6/8.12.6) with ESMTP id h4V3AZ0U097122 for ; Fri, 30 May 2003 20:10:35 -0700 (PDT) (envelope-from jmallett@freebsd.org) Received: (from perforce@localhost) by repoman.freebsd.org (8.12.6/8.12.6/Submit) id h4V3AZSZ097119 for perforce@freebsd.org; Fri, 30 May 2003 20:10:35 -0700 (PDT) Date: Fri, 30 May 2003 20:10:35 -0700 (PDT) Message-Id: <200305310310.h4V3AZSZ097119@repoman.freebsd.org> X-Authentication-Warning: repoman.freebsd.org: perforce set sender to jmallett@freebsd.org using -f From: Juli Mallett To: Perforce Change Reviews Subject: PERFORCE change 32147 for review X-BeenThere: p4-projects@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: p4 projects tree changes List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 31 May 2003 03:10:38 -0000 http://perforce.freebsd.org/chv.cgi?CH=32147 Change 32147 by jmallett@jmallett_dalek on 2003/05/30 20:10:08 Set up the auxillary frame for DDB. Affected files ... .. //depot/projects/mips/sys/mips/mips/exception.S#3 edit Differences ... ==== //depot/projects/mips/sys/mips/mips/exception.S#3 (text+ko) ==== @@ -9,6 +9,8 @@ * $FreeBSD$ */ +#include "opt_ddb.h" + #include #include @@ -41,7 +43,18 @@ j exception_save_registers move k1, sp 1: + /* + * A generic exception may result in DDB being invoked. If we + * are using the kernel debugger, then set up is auxillary + * frame, so it has a full one. + */ +#if DDB + jal save_kdbaux + nop +#endif /* DDB */ + + /* * Call trap() with arguments: * trapframe, cause, badvaddr. * @@ -214,3 +227,31 @@ jr k0 nop END(exception_save_registers) + +#if DDB +/* + * Save the kdbaux structure for DDB. + */ +ENTRY(save_kdbaux) + /* + * If we are using the kernel debugger, store registers that + * the compiler normally saves in the place where it expects + * to find them, to form a full frame. + */ + dla k0, kdbaux + sd s0, 0x00(k0) + sd s1, 0x08(k0) + sd s2, 0x10(k0) + sd s3, 0x18(k0) + sd s4, 0x20(k0) + sd s5, 0x28(k0) + sd s6, 0x30(k0) + sd s7, 0x38(k0) + sd sp, 0x40(k0) + sd s8, 0x48(k0) + sd gp, 0x50(k0) + + jr ra + nop +END(save_kdbaux) +#endif /* DDB */