[PATCH] patch-slab-split-04-drain

Manfred Spraul (manfred@colorfullife.com)
Fri, 04 Oct 2002 20:07:24 +0200


This is a multi-part message in MIME format.
--------------030200040006050006070707
Content-Type: text/plain; charset=us-ascii; format=flowed
Content-Transfer-Encoding: 7bit

part 4:

- spin_lock(); within the smp_call_function callback is now permitted,
remove/cleanup the workaround.

Untested due to lack of SMP test systems, but trivial.

--
	Manfred

--------------030200040006050006070707 Content-Type: text/plain; name="patch-slab-split-04-drain" Content-Transfer-Encoding: 7bit Content-Disposition: inline; filename="patch-slab-split-04-drain"

--- 2.5/mm/slab.c Fri Oct 4 19:05:15 2002 +++ build-2.5/mm/slab.c Fri Oct 4 19:36:13 2002 @@ -917,29 +917,19 @@ static void free_block (kmem_cache_t* cachep, void** objpp, int len); -static void drain_cpu_caches(kmem_cache_t *cachep) +static void do_drain(void *arg) { - ccupdate_struct_t new; - int i; - - memset(&new.new,0,sizeof(new.new)); - - new.cachep = cachep; + kmem_cache_t *cachep = (kmem_cache_t*)arg; + cpucache_t *cc; - down(&cache_chain_sem); - smp_call_function_all_cpus(do_ccupdate_local, (void *)&new); + cc = cc_data(cachep); + free_block(cachep, &cc_entry(cc)[0], cc->avail); + cc->avail = 0; +} - for (i = 0; i < NR_CPUS; i++) { - cpucache_t* ccold = new.new[i]; - if (!ccold || (ccold->avail == 0)) - continue; - local_irq_disable(); - free_block(cachep, cc_entry(ccold), ccold->avail); - local_irq_enable(); - ccold->avail = 0; - } - smp_call_function_all_cpus(do_ccupdate_local, (void *)&new); - up(&cache_chain_sem); +static void drain_cpu_caches(kmem_cache_t *cachep) +{ + smp_call_function_all_cpus(do_drain, cachep); } static int __cache_shrink(kmem_cache_t *cachep)

--------------030200040006050006070707--

- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/