X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=mm%2Fslub.c;h=10ab2335e2eaff568eff6a38bb5a9349c591ebc3;hb=7386cad5a5036018d45285e617db8339c31feb2f;hp=35f351f26193a47145cd8bcb7f55ae091331ca97;hpb=12f1ba5a7dac4caf8b4e6ccd6453f0a095e74c7c;p=android-x86%2Fkernel.git diff --git a/mm/slub.c b/mm/slub.c index 35f351f26193..10ab2335e2ea 100644 --- a/mm/slub.c +++ b/mm/slub.c @@ -1818,6 +1818,11 @@ static void *__slab_alloc(struct kmem_cache *s, gfp_t gfpflags, int node, if (unlikely(!node_match(c, node))) goto another_slab; + /* must check again c->freelist in case of cpu migration or IRQ */ + object = c->freelist; + if (object) + goto update_freelist; + stat(s, ALLOC_REFILL); load_freelist: @@ -1827,6 +1832,7 @@ load_freelist: if (kmem_cache_debug(s)) goto debug; +update_freelist: c->freelist = get_freepointer(s, object); page->inuse = page->objects; page->freelist = NULL; @@ -3433,13 +3439,14 @@ struct kmem_cache *kmem_cache_create(const char *name, size_t size, if (kmem_cache_open(s, n, size, align, flags, ctor)) { list_add(&s->list, &slab_caches); + up_write(&slub_lock); if (sysfs_slab_add(s)) { + down_write(&slub_lock); list_del(&s->list); kfree(n); kfree(s); goto err; } - up_write(&slub_lock); return s; } kfree(n);