提交 b10d22d6 编写于 作者: A Anton Vorontsov 提交者: Jason Wessel

kernel/debug: Make use of KGDB_REASON_NMI

Currently kernel never set KGDB_REASON_NMI. We do now, when we enter
KGDB/KDB from an NMI.

This is not to be confused with kgdb_nmicallback(), NMI callback is
an entry for the slave CPUs during CPUs roundup, but REASON_NMI is the
entry for the master CPU.
Signed-off-by: NAnton Vorontsov <anton.vorontsov@linaro.org>
Signed-off-by: NJason Wessel <jason.wessel@windriver.com>
上级 07cd27bb
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
#include <linux/kdb.h> #include <linux/kdb.h>
#include <linux/kdebug.h> #include <linux/kdebug.h>
#include <linux/export.h> #include <linux/export.h>
#include <linux/hardirq.h>
#include "kdb_private.h" #include "kdb_private.h"
#include "../debug_core.h" #include "../debug_core.h"
...@@ -52,6 +53,9 @@ int kdb_stub(struct kgdb_state *ks) ...@@ -52,6 +53,9 @@ int kdb_stub(struct kgdb_state *ks)
if (atomic_read(&kgdb_setting_breakpoint)) if (atomic_read(&kgdb_setting_breakpoint))
reason = KDB_REASON_KEYBOARD; reason = KDB_REASON_KEYBOARD;
if (in_nmi())
reason = KDB_REASON_NMI;
for (i = 0, bp = kdb_breakpoints; i < KDB_MAXBPT; i++, bp++) { for (i = 0, bp = kdb_breakpoints; i < KDB_MAXBPT; i++, bp++) {
if ((bp->bp_enabled) && (bp->bp_addr == addr)) { if ((bp->bp_enabled) && (bp->bp_addr == addr)) {
reason = KDB_REASON_BREAK; reason = KDB_REASON_BREAK;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册