diff options
author | Li Zefan <lizf@cn.fujitsu.com> | 2010-03-23 22:57:43 -0400 |
---|---|---|
committer | Steven Rostedt <rostedt@goodmis.org> | 2010-03-31 22:56:58 -0400 |
commit | ae832d1e03ac9bf09fb8a07fb37908ab40c7cd0e (patch) | |
tree | cf754c5242e66aa0349559af880db5fa29af6f2a /include/linux/module.h | |
parent | 50354a8a28d0c91695a2d6d25b5a821bfe557a07 (diff) |
tracing: Remove side effect from module tracepoints that caused a GPF
Remove the @refcnt argument, because it has side-effects, and arguments with
side-effects are not skipped by the jump over disabled instrumentation and are
executed even when the tracepoint is disabled.
This was also causing a GPF as found by Randy Dunlap:
Subject: 2.6.33 GP fault only when built with tracing
LKML-Reference: <4BA2B69D.3000309@oracle.com>
Note, the current 2.6.34-rc has a fix for the actual cause of the GPF,
but this fixes one of its triggers.
Tested-by: Randy Dunlap <randy.dunlap@oracle.com>
Acked-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Signed-off-by: Li Zefan <lizf@cn.fujitsu.com>
LKML-Reference: <4BA97FA7.6040406@cn.fujitsu.com>
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'include/linux/module.h')
-rw-r--r-- | include/linux/module.h | 6 |
1 files changed, 2 insertions, 4 deletions
diff --git a/include/linux/module.h b/include/linux/module.h index 5e869ffd34aa..393ec39b580a 100644 --- a/include/linux/module.h +++ b/include/linux/module.h | |||
@@ -460,8 +460,7 @@ static inline void __module_get(struct module *module) | |||
460 | if (module) { | 460 | if (module) { |
461 | preempt_disable(); | 461 | preempt_disable(); |
462 | __this_cpu_inc(module->refptr->count); | 462 | __this_cpu_inc(module->refptr->count); |
463 | trace_module_get(module, _THIS_IP_, | 463 | trace_module_get(module, _THIS_IP_); |
464 | __this_cpu_read(module->refptr->count)); | ||
465 | preempt_enable(); | 464 | preempt_enable(); |
466 | } | 465 | } |
467 | } | 466 | } |
@@ -475,8 +474,7 @@ static inline int try_module_get(struct module *module) | |||
475 | 474 | ||
476 | if (likely(module_is_live(module))) { | 475 | if (likely(module_is_live(module))) { |
477 | __this_cpu_inc(module->refptr->count); | 476 | __this_cpu_inc(module->refptr->count); |
478 | trace_module_get(module, _THIS_IP_, | 477 | trace_module_get(module, _THIS_IP_); |
479 | __this_cpu_read(module->refptr->count)); | ||
480 | } | 478 | } |
481 | else | 479 | else |
482 | ret = 0; | 480 | ret = 0; |