mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-03-31 19:45:21 +00:00
SLUB: do proper locking during dma slab creation
We modify the kmalloc_cache_dma[] array without proper locking. Do the proper locking and undo the dma cache creation if another processor has already created it. Signed-off-by: Christoph Lameter <clameter@sgi.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
2e443fd003
commit
dfce8648d6
1 changed files with 9 additions and 2 deletions
11
mm/slub.c
11
mm/slub.c
|
@ -2301,8 +2301,15 @@ static noinline struct kmem_cache *dma_kmalloc_cache(int index, gfp_t flags)
|
||||||
text = kasprintf(flags & ~SLUB_DMA, "kmalloc_dma-%d",
|
text = kasprintf(flags & ~SLUB_DMA, "kmalloc_dma-%d",
|
||||||
(unsigned int)realsize);
|
(unsigned int)realsize);
|
||||||
s = create_kmalloc_cache(x, text, realsize, flags);
|
s = create_kmalloc_cache(x, text, realsize, flags);
|
||||||
kmalloc_caches_dma[index] = s;
|
down_write(&slub_lock);
|
||||||
return s;
|
if (!kmalloc_caches_dma[index]) {
|
||||||
|
kmalloc_caches_dma[index] = s;
|
||||||
|
up_write(&slub_lock);
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
up_write(&slub_lock);
|
||||||
|
kmem_cache_destroy(s);
|
||||||
|
return kmalloc_caches_dma[index];
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue