Keith Owens (on Tue, 27 Feb 2007 00:42:54 +1100) wrote:
>"Zhou, Water" (on Mon, 26 Feb 2007 14:13:24 +0800) wrote:
>>    Entering kdb (current=3D0xc460b550, pid 1125) duo to Breakpoint 
>> @0xc016ca90
>>    kdb> ss
>>
>>    kdb_ss: pt_regs not available
>>
>>I think the problem is because of get_irq_regs() inline function
>>return NULL when the breakpoint is touched. I don't know why ?
>
>Correct, there are a couple of paths that do not call set_irq_regs().
>Could you try this patch, it is against kdb-v4.4-2.6.20-common-4 but
>should apply to 2.6.19 as well.  The patch compiles but I will not be
>able to test it for for several hours.

After testing, this is the correct patch.  It is included in
kdb-v4.4-2.6.20-common-5.

Index: linux/kdb/kdbmain.c
===================================================================
--- linux.orig/kdb/kdbmain.c    2007-02-27 10:51:18.403100729 +1100
+++ linux/kdb/kdbmain.c 2007-02-27 10:44:43.146860775 +1100
@@ -1735,7 +1735,8 @@ kdb(kdb_reason_t reason, int error, stru
        kdb_intstate_t int_state;       /* Interrupt state */
        kdb_reason_t reason2 = reason;
        int result = 0; /* Default is kdb did not handle it */
-       int ss_event;
+       int ss_event, old_regs_saved = 0;
+       struct pt_regs *old_regs = NULL;
        kdb_dbtrap_t db_result=KDB_DB_NOBPT;
        preempt_disable();
        atomic_inc(&kdb_event);
@@ -1748,6 +1749,23 @@ kdb(kdb_reason_t reason, int error, stru
        default:
                break;
        }
+       switch(reason) {
+       case KDB_REASON_ENTER:
+       case KDB_REASON_ENTER_SLAVE:
+       case KDB_REASON_BREAK:
+       case KDB_REASON_DEBUG:
+       case KDB_REASON_OOPS:
+       case KDB_REASON_SWITCH:
+       case KDB_REASON_KEYBOARD:
+       case KDB_REASON_NMI:
+               if (regs && regs != get_irq_regs()) {
+                       old_regs = set_irq_regs(regs);
+                       old_regs_saved = 1;
+               }
+               break;
+       default:
+               break;
+       }
        if (kdb_continue_catastrophic > 2) {
                kdb_printf("kdb_continue_catastrophic is out of range, setting 
to 2\n");
                kdb_continue_catastrophic = 2;
@@ -2060,6 +2078,8 @@ kdb(kdb_reason_t reason, int error, stru
        if (!(KDB_STATE(DOING_SS) || KDB_STATE(SSBPT) || KDB_STATE(RECURSE))) {
                KDB_DEBUG_STATE("kdb 15", result);
                kdb_bp_install_local(regs);
+               if (old_regs_saved)
+                       set_irq_regs(old_regs);
                KDB_STATE_CLEAR(KDB_CONTROL);
        }
 

---------------------------
Use http://oss.sgi.com/ecartis to modify your settings or to unsubscribe.

Reply via email to