diff options
author | Christoph Lameter <cl@linux.com> | 2011-11-23 10:14:38 -0500 |
---|---|---|
committer | Pekka Enberg <penberg@kernel.org> | 2011-11-24 01:44:14 -0500 |
commit | 42d623a8cd08eb93ab221d22cee5a62618895bbf (patch) | |
tree | c2bc80e3b59253f3d4c9e81e608ba59d15a5bf0e /mm | |
parent | 9ada19342b2441f290f0043ed7c562682c8c4ede (diff) |
slub: use irqsafe_cpu_cmpxchg for put_cpu_partial
The cmpxchg must be irq safe. The fallback for this_cpu_cmpxchg only
disables preemption which results in per cpu partial page operation
potentially failing on non x86 platforms.
This patch fixes the following problem reported by Christian Kujau:
I seem to hit it with heavy disk & cpu IO is in progress on this
PowerBook
G4. Full dmesg & .config: http://nerdbynature.de/bits/3.2.0-rc1/oops/
I've enabled some debug options and now it really points to slub.c:2166
http://nerdbynature.de/bits/3.2.0-rc1/oops/oops4m.jpg
With debug options enabled I'm currently in the xmon debugger, not sure
what to make of it yet, I'll try to get something useful out of it :)
Reported-by: Christian Kujau <lists@nerdbynature.de>
Tested-by: Christian Kujau <lists@nerdbynature.de>
Acked-by: Eric Dumazet <eric.dumazet@gmail.com>
Acked-by: David Rientjes <rientjes@google.com>
Signed-off-by: Christoph Lameter <cl@linux.com>
Signed-off-by: Pekka Enberg <penberg@kernel.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/slub.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -1978,7 +1978,7 @@ int put_cpu_partial(struct kmem_cache *s, struct page *page, int drain) | |||
1978 | page->pobjects = pobjects; | 1978 | page->pobjects = pobjects; |
1979 | page->next = oldpage; | 1979 | page->next = oldpage; |
1980 | 1980 | ||
1981 | } while (this_cpu_cmpxchg(s->cpu_slab->partial, oldpage, page) != oldpage); | 1981 | } while (irqsafe_cpu_cmpxchg(s->cpu_slab->partial, oldpage, page) != oldpage); |
1982 | stat(s, CPU_PARTIAL_FREE); | 1982 | stat(s, CPU_PARTIAL_FREE); |
1983 | return pobjects; | 1983 | return pobjects; |
1984 | } | 1984 | } |