On Mon, Jan 21, 2013 at 10:20:38AM -0600, Matt Sealey wrote: > See previous mail to Minchan; local_tlb_flush_kernel_range calls > cpu_tlb.flush_kernel_range on SMP, but a direct function call > ("glue(_TLB, flush_kernel_range)" which resolves to > v7wbi_flush_kernel_range etc. etc.) without CONFIG_SMP. Actually, that's wrong - it's got nothing to do with SMP vs non-SMP. It's more to do with which CPUs are being supported. If they all use one single cache maintanence implementation, then direct calls are used as an optimization. If they require more than one cache maintanence implementation, they are indirect calls. SMP really doesn't come into that decision. So: > >> diff --git a/drivers/staging/zsmalloc/zsmalloc-main.c > >> b/drivers/staging/zsmalloc/zsmalloc-main.c > >> index 09a9d35..ecf75fb 100644 > > > --- a/drivers/staging/zsmalloc/zsmalloc-main.c > >> +++ b/drivers/staging/zsmalloc/zsmalloc-main.c > >> @@ -228,7 +228,7 @@ struct zs_pool { > >> * mapping rather than copying > >> * for object mapping. > >> */ > >> -#if defined(CONFIG_ARM) > >> +#if defined(CONFIG_ARM) && defined(CONFIG_SMP) Would be wrong. _______________________________________________ devel mailing list devel@xxxxxxxxxxxxxxxxxxxxxx http://driverdev.linuxdriverproject.org/mailman/listinfo/devel