On May 1, 2015, at 4:58 PM, Greg Kroah-Hartman wrote: > On Fri, May 01, 2015 at 08:52:37PM +0000, Drokin, Oleg wrote: >> >> On May 1, 2015, at 4:49 PM, Greg Kroah-Hartman wrote: >> >>> On Fri, May 01, 2015 at 08:36:05PM +0000, Simmons, James A. wrote: >>>>> We are hopefully going to get rid of OBD_ALLOC_LARGE() as well, though. >>>>> >>>>> It's simple enough to write a function: >>>>> >>>>> void *obd_zalloc(size_t size) >>>>> { >>>>> if (size > 4 * PAGE_CACHE_SIZE) >>>>> return vzalloc(size); >>>>> else >>>>> return kmalloc(size, GFP_NOFS); >>>>> } >>>>> >>>>> Except, huh? Shouldn't we be using GFP_NOFS for the vzalloc() side? >>>>> There was some discussion of that GFP_NOFS was a bit buggy back in 2010 >>>>> (http://marc.info/?l=linux-mm&m=128942194520631&w=4) but the current >>>>> lustre code doesn't try to pass GFP_NOFS. >>>> >>>> The version in the upstream client is out of date. The current macro in the Intel master >>>> Branch is: >>> >>> That's not helpful at all, why do we even have an in-kernel version of >>> this code if you don't do your development in the kernel? >>> >>> Please sync with the kernel tree very soon, or I'm just going to delete >>> this whole thing. This is getting _really_ frustrating. >> >> The patch was submitted. >> But it depends on a symbol that's not exported. >> I was not able to change that. >> http://www.spinics.net/lists/linux-mm/msg83997.html > > But you were given a hint on how to change that :) Well, the hint amounted to "don't do vmalloc if you cannot live with the GFP_KERNEL" allocations. In any case once we unroll the OBD_ALLOC* (esp. the _LARGE ones), it should be possible to go through those cases and adjust GFP flags to less restrictive where possible (right now our macro is way too rigid and does not take gfp flags at all). > Anyway, I'd recommend switching to what ext4 and xfs does, as you point > out in another email in this thread, it looks a lot better overall. Yes, I imagine Julia will include that as the new lustre_kvzalloc() define to be used in all OBD_ALLOC_LARGE instances. I can provide the desired code if necessary (it's actually a bit less than trivial because in some cases we also have that numa-aware node thing). though if we are ok to review that later, then almost a copy of ext4 one would do like this: void *lustre_kvzalloc(size_t size, gfp_t flags) { void *ret; ret = kzalloc(size, flags | __GFP_NOWARN); if (!ret) ret = __vmalloc(size, flags | __GFP_ZERO, PAGE_KERNEL); return ret; } Bye, Oleg _______________________________________________ devel mailing list devel@xxxxxxxxxxxxxxxxxxxxxx http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel