aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/notifier.c
diff options
context:
space:
mode:
authorArjan van de Ven <arjan@linux.intel.com>2008-08-15 18:29:38 -0400
committerIngo Molnar <mingo@elte.hu>2008-09-10 03:08:53 -0400
commitab7476cf76e560f0efda2a631a70aabe93009025 (patch)
treed4e843760774d7099692950a6ac49ccdbc8b0d55 /kernel/notifier.c
parentfb822db465bd9fd4208eef1af4490539b236c54e (diff)
debug: add notifier chain debugging, v2
- unbreak ia64 (and powerpc) where function pointers dont point at code but at data (reported by Tony Luck) [ mingo@elte.hu: various cleanups ] Signed-off-by: Arjan van de Ven <arjan@linux.intel.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/notifier.c')
-rw-r--r--kernel/notifier.c10
1 files changed, 1 insertions, 9 deletions
diff --git a/kernel/notifier.c b/kernel/notifier.c
index 143fdd77dbf7..0f39e398ef60 100644
--- a/kernel/notifier.c
+++ b/kernel/notifier.c
@@ -21,10 +21,6 @@ BLOCKING_NOTIFIER_HEAD(reboot_notifier_list);
21static int notifier_chain_register(struct notifier_block **nl, 21static int notifier_chain_register(struct notifier_block **nl,
22 struct notifier_block *n) 22 struct notifier_block *n)
23{ 23{
24 if (!kernel_text_address((unsigned long)n->notifier_call)) {
25 WARN(1, "Invalid notifier registered!");
26 return 0;
27 }
28 while ((*nl) != NULL) { 24 while ((*nl) != NULL) {
29 if (n->priority > (*nl)->priority) 25 if (n->priority > (*nl)->priority)
30 break; 26 break;
@@ -38,10 +34,6 @@ static int notifier_chain_register(struct notifier_block **nl,
38static int notifier_chain_cond_register(struct notifier_block **nl, 34static int notifier_chain_cond_register(struct notifier_block **nl,
39 struct notifier_block *n) 35 struct notifier_block *n)
40{ 36{
41 if (!kernel_text_address((unsigned long)n->notifier_call)) {
42 WARN(1, "Invalid notifier registered!");
43 return 0;
44 }
45 while ((*nl) != NULL) { 37 while ((*nl) != NULL) {
46 if ((*nl) == n) 38 if ((*nl) == n)
47 return 0; 39 return 0;
@@ -92,7 +84,7 @@ static int __kprobes notifier_call_chain(struct notifier_block **nl,
92 next_nb = rcu_dereference(nb->next); 84 next_nb = rcu_dereference(nb->next);
93 85
94#ifdef CONFIG_DEBUG_NOTIFIERS 86#ifdef CONFIG_DEBUG_NOTIFIERS
95 if (!kernel_text_address((unsigned long)nb->notifier_call)) { 87 if (unlikely(!func_ptr_is_kernel_text(nb->notifier_call))) {
96 WARN(1, "Invalid notifier called!"); 88 WARN(1, "Invalid notifier called!");
97 nb = next_nb; 89 nb = next_nb;
98 continue; 90 continue;