aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorPaul E. McKenney <paulmck@us.ibm.com>2005-09-06 18:16:35 -0400
committerLinus Torvalds <torvalds@g5.osdl.org>2005-09-07 19:57:19 -0400
commit19306059cd7fedaf96b4b0260a9a8a45e513c857 (patch)
tree7c32d59c1a5830689d5f85a7f81e89e48d1097ae /arch
parentfe21773d655c2c64641ec2cef499289ea175c817 (diff)
[PATCH] NMI: Update NMI users of RCU to use new API
Uses of RCU for dynamically changeable NMI handlers need to use the new rcu_dereference() and rcu_assign_pointer() facilities. This change makes it clear that these uses are safe from a memory-barrier viewpoint, but the main purpose is to document exactly what operations are being protected by RCU. This has been tested on x86 and x86-64, which are the only architectures affected by this change. Signed-off-by: <paulmck@us.ibm.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch')
-rw-r--r--arch/i386/kernel/traps.c4
-rw-r--r--arch/x86_64/kernel/nmi.c4
2 files changed, 4 insertions, 4 deletions
diff --git a/arch/i386/kernel/traps.c b/arch/i386/kernel/traps.c
index 54629bb5893a..029bf94cda7d 100644
--- a/arch/i386/kernel/traps.c
+++ b/arch/i386/kernel/traps.c
@@ -657,7 +657,7 @@ fastcall void do_nmi(struct pt_regs * regs, long error_code)
657 657
658 ++nmi_count(cpu); 658 ++nmi_count(cpu);
659 659
660 if (!nmi_callback(regs, cpu)) 660 if (!rcu_dereference(nmi_callback)(regs, cpu))
661 default_do_nmi(regs); 661 default_do_nmi(regs);
662 662
663 nmi_exit(); 663 nmi_exit();
@@ -665,7 +665,7 @@ fastcall void do_nmi(struct pt_regs * regs, long error_code)
665 665
666void set_nmi_callback(nmi_callback_t callback) 666void set_nmi_callback(nmi_callback_t callback)
667{ 667{
668 nmi_callback = callback; 668 rcu_assign_pointer(nmi_callback, callback);
669} 669}
670EXPORT_SYMBOL_GPL(set_nmi_callback); 670EXPORT_SYMBOL_GPL(set_nmi_callback);
671 671
diff --git a/arch/x86_64/kernel/nmi.c b/arch/x86_64/kernel/nmi.c
index 84cae81fff8b..caf164959e19 100644
--- a/arch/x86_64/kernel/nmi.c
+++ b/arch/x86_64/kernel/nmi.c
@@ -524,14 +524,14 @@ asmlinkage void do_nmi(struct pt_regs * regs, long error_code)
524 524
525 nmi_enter(); 525 nmi_enter();
526 add_pda(__nmi_count,1); 526 add_pda(__nmi_count,1);
527 if (!nmi_callback(regs, cpu)) 527 if (!rcu_dereference(nmi_callback)(regs, cpu))
528 default_do_nmi(regs); 528 default_do_nmi(regs);
529 nmi_exit(); 529 nmi_exit();
530} 530}
531 531
532void set_nmi_callback(nmi_callback_t callback) 532void set_nmi_callback(nmi_callback_t callback)
533{ 533{
534 nmi_callback = callback; 534 rcu_assign_pointer(nmi_callback, callback);
535} 535}
536 536
537void unset_nmi_callback(void) 537void unset_nmi_callback(void)