Introduced by commit:
module.c: commit 6b588c18f8dacfa6d7957c33c5ff832096e752d3
This patch should be queued for the stable branch, for kernels 2.6.29.x to
2.6.33.x.
(tested on 2.6.33.1 x86_64)
Signed-off-by: Mathieu Desnoyers <mathieu....@efficios.com>
CC: Randy Dunlap <randy....@oracle.com>
CC: Eric Dumazet <da...@cosmosbay.com>
CC: Rusty Russell <ru...@rustcorp.com.au>
CC: Peter Zijlstra <a.p.zi...@chello.nl>
CC: Tejun Heo <t...@kernel.org>
CC: Ingo Molnar <mi...@elte.hu>
CC: Andrew Morton <ak...@linux-foundation.org>
CC: Linus Torvalds <torv...@linux-foundation.org>
CC: Greg Kroah-Hartman <gre...@suse.de>
CC: Steven Rostedt <ros...@goodmis.org>
CC: stable <sta...@kernel.org>
---
kernel/module.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
Index: linux-2.6-lttng/kernel/module.c
===================================================================
--- linux-2.6-lttng.orig/kernel/module.c 2010-03-29 23:47:05.000000000 -0400
+++ linux-2.6-lttng/kernel/module.c 2010-03-29 23:47:27.000000000 -0400
@@ -412,7 +412,7 @@ static void percpu_modcopy(void *pcpudes
int cpu;
for_each_possible_cpu(cpu)
- memcpy(pcpudest + per_cpu_offset(cpu), from, size);
+ memcpy(per_cpu_ptr(pcpudest, cpu), from, size);
}
#else /* ... !CONFIG_SMP */
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majo...@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
It's actually needed for mainline too (2.6.34-rc2).
Thanks,
Mathieu
Then all you need to do is submit it for mainline with a
"Cc: sta...@kernel.org" as you did below. It will then automatically be
added to the stable queue when Linus pulls it.
-- Steve
>
> Thanks,
>
> Mathieu
>
> >
> > Signed-off-by: Mathieu Desnoyers <mathieu....@efficios.com>
> > CC: Randy Dunlap <randy....@oracle.com>
> > CC: Eric Dumazet <da...@cosmosbay.com>
> > CC: Rusty Russell <ru...@rustcorp.com.au>
> > CC: Peter Zijlstra <a.p.zi...@chello.nl>
> > CC: Tejun Heo <t...@kernel.org>
> > CC: Ingo Molnar <mi...@elte.hu>
> > CC: Andrew Morton <ak...@linux-foundation.org>
> > CC: Linus Torvalds <torv...@linux-foundation.org>
> > CC: Greg Kroah-Hartman <gre...@suse.de>
> > CC: Steven Rostedt <ros...@goodmis.org>
> > CC: stable <sta...@kernel.org>
> > ---
> > kernel/module.c | 2 +-
> > 1 file changed, 1 insertion(+), 1 deletion(-)
> >
> >
--
Introduced by commit:
module.c: commit 6b588c18f8dacfa6d7957c33c5ff832096e752d3
It applies to mainline as of 2.6.34-rc2. This patch should be queued for the
stable branch, for kernels 2.6.29.x to 2.6.33.x.
(based on 2.6.33.1, also applies to 2.6.34-rc2 -tip)
Signed-off-by: Mathieu Desnoyers <mathieu....@efficios.com>
CC: Randy Dunlap <randy....@oracle.com>
CC: Eric Dumazet <da...@cosmosbay.com>
CC: Rusty Russell <ru...@rustcorp.com.au>
CC: Peter Zijlstra <a.p.zi...@chello.nl>
CC: Tejun Heo <t...@kernel.org>
CC: Ingo Molnar <mi...@elte.hu>
CC: Andrew Morton <ak...@linux-foundation.org>
CC: Linus Torvalds <torv...@linux-foundation.org>
CC: Greg Kroah-Hartman <gre...@suse.de>
CC: Steven Rostedt <ros...@goodmis.org>
CC: stable <sta...@kernel.org>
---
kernel/module.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
Index: linux-2.6-lttng/kernel/module.c
===================================================================
--- linux-2.6-lttng.orig/kernel/module.c 2010-03-29 23:47:05.000000000 -0400
+++ linux-2.6-lttng/kernel/module.c 2010-03-29 23:47:27.000000000 -0400
@@ -412,7 +412,7 @@ static void percpu_modcopy(void *pcpudes
int cpu;
for_each_possible_cpu(cpu)
- memcpy(pcpudest + per_cpu_offset(cpu), from, size);
+ memcpy(per_cpu_ptr(pcpudest, cpu), from, size);
}
#else /* ... !CONFIG_SMP */
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
OK, thanks for the info.
Mathieu
>
> -- Steve
>
> >
> > Thanks,
> >
> > Mathieu
> >
> > >
> > > Signed-off-by: Mathieu Desnoyers <mathieu....@efficios.com>
> > > CC: Randy Dunlap <randy....@oracle.com>
> > > CC: Eric Dumazet <da...@cosmosbay.com>
> > > CC: Rusty Russell <ru...@rustcorp.com.au>
> > > CC: Peter Zijlstra <a.p.zi...@chello.nl>
> > > CC: Tejun Heo <t...@kernel.org>
> > > CC: Ingo Molnar <mi...@elte.hu>
> > > CC: Andrew Morton <ak...@linux-foundation.org>
> > > CC: Linus Torvalds <torv...@linux-foundation.org>
> > > CC: Greg Kroah-Hartman <gre...@suse.de>
> > > CC: Steven Rostedt <ros...@goodmis.org>
> > > CC: stable <sta...@kernel.org>
> > > ---
> > > kernel/module.c | 2 +-
> > > 1 file changed, 1 insertion(+), 1 deletion(-)
> > >
> > >
>
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
> Should use per_cpu_ptr() to obfuscate the per cpu pointers (RELOC_HIDE is needed
> for per cpu pointers).
>
> Introduced by commit:
>
> module.c: commit 6b588c18f8dacfa6d7957c33c5ff832096e752d3
>
> It applies to mainline as of 2.6.34-rc2. This patch should be queued for the
> stable branch, for kernels 2.6.29.x to 2.6.33.x.
> (based on 2.6.33.1, also applies to 2.6.34-rc2 -tip)
Why do you beleive this should be backported to -stable? What are the
user-visible effects of this change?
As for the user-visible impact of this specific patch, I guess nobody noticed
any problem because we've been lucky enough that the compiler did not generate
the inappropriate optimization pattern there.
This inappropriate use of per_cpu_ptr() elsewhere (in __module_ref_addr() from
module.h) caused a NULL pointer exception on Randy's machine.
So either we consider that the code is better left untouched, or we apply this
patch to module.c in order to prevent compiler optimizations from subtly
breaking the generated assembly with specific configurations of the current or
future versions of the compiler. At that level, it becomes a policy question
about what should go in -stable, for which I will defer to Greg and you. I would
perfectly understand if you consider that it does not belong to -stable, because
there is no perceived user impact so far.
Thanks,
Mathieu
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
Acked-by: Tejun Heo <t...@kernel.org>
Thanks.
--
tejun
> > Why do you beleive this should be backported to -stable? What are the
> > user-visible effects of this change?
> >
>
> As for the user-visible impact of this specific patch, I guess nobody noticed
> any problem because we've been lucky enough that the compiler did not generate
> the inappropriate optimization pattern there.
>
> This inappropriate use of per_cpu_ptr() elsewhere (in __module_ref_addr() from
> module.h) caused a NULL pointer exception on Randy's machine.
>
> So either we consider that the code is better left untouched, or we apply this
> patch to module.c in order to prevent compiler optimizations from subtly
> breaking the generated assembly with specific configurations of the current or
> future versions of the compiler. At that level, it becomes a policy question
> about what should go in -stable, for which I will defer to Greg and you. I would
> perfectly understand if you consider that it does not belong to -stable, because
> there is no perceived user impact so far.
I don't know. A possible "NULL pointer dereference" seems to me to be a
pretty big user visible impact.
I guess the question is, what's the risk of adding this change?
-- Steve
AFAICS, the risk is fairly low. per_cpu_ptr(pcpudest, cpu) is
SHIFT_PERCPU_PTR((ptr), per_cpu_offset((cpu))) which is just a fancy
way of saying "typeof(ptr)((unsigned long)(ptr) + per_cpu_offset(cpu))"
with enough obfuscation to prevent gcc from optimizing it incorrectly.
Thanks.
--
tejun
And I need to wait until it goes into Linus's tree before it can be
applied to the stable tree. This hasn't happened yet, right?
thanks,
greg k-h
Same here, for module.c fix. Feel free to choose between this fix or the
corresponding refactoring from Tejun.
modules fix incorrect percpu usage
Should use per_cpu_ptr() to obfuscate the per cpu pointers (RELOC_HIDE is needed
for per cpu pointers).
Introduced by commit:
module.c: commit 6b588c18f8dacfa6d7957c33c5ff832096e752d3
This patch should be queued for the stable branch, for kernels 2.6.29.x to
2.6.33.x. (tested on 2.6.33.1 x86_64)
Mainline does not need this fix, as commit
259354deaaf03d49a02dbb9975d6ec2a54675672 fixed the problem by refactoring.
Signed-off-by: Mathieu Desnoyers <mathieu....@efficios.com>
CC: Randy Dunlap <randy....@oracle.com>
CC: Eric Dumazet <da...@cosmosbay.com>
CC: Rusty Russell <ru...@rustcorp.com.au>
CC: Peter Zijlstra <a.p.zi...@chello.nl>
CC: Tejun Heo <t...@kernel.org>
CC: Ingo Molnar <mi...@elte.hu>
CC: Andrew Morton <ak...@linux-foundation.org>
CC: Linus Torvalds <torv...@linux-foundation.org>
CC: Greg Kroah-Hartman <gre...@suse.de>
CC: Steven Rostedt <ros...@goodmis.org>
CC: stable <sta...@kernel.org>
---
kernel/module.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
Index: linux.trees.git/kernel/module.c
===================================================================
--- linux.trees.git.orig/kernel/module.c 2010-03-27 11:27:23.000000000 -0400
+++ linux.trees.git/kernel/module.c 2010-03-30 09:48:41.000000000 -0400
@@ -405,7 +405,7 @@ static void percpu_modcopy(void *pcpudes
int cpu;
for_each_possible_cpu(cpu)
- memcpy(pcpudest + per_cpu_offset(cpu), from, size);
+ memcpy(per_cpu_ptr(pcpudest, cpu), from, size);
}
#else /* ... !CONFIG_SMP */
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
Thanks, I took this one.
greg k-h
On 04/20/2010 04:34 PM, Mathieu Desnoyers wrote:
> Same here, for module.c fix. Feel free to choose between this fix or the
> corresponding refactoring from Tejun.
Please take this one for -stable. I don't think the percpu
refactoring is worthwhile to backport to -stable. It only affects
debug feature and the worst outcome is spurious warning messages.
Thanks.
--
tejun