Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754565AbbLAGgA (ORCPT ); Tue, 1 Dec 2015 01:36:00 -0500 Received: from LGEAMRELO13.lge.com ([156.147.23.53]:52343 "EHLO lgeamrelo13.lge.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750912AbbLAGf7 (ORCPT ); Tue, 1 Dec 2015 01:35:59 -0500 X-Original-SENDERIP: 156.147.1.121 X-Original-MAILFROM: kyeongdon.kim@lge.com X-Original-SENDERIP: 10.168.83.150 X-Original-MAILFROM: kyeongdon.kim@lge.com Subject: Re: Re: [PATCH v3 2/2] zram: try vmalloc() after kmalloc() To: Sergey Senozhatsky , Minchan Kim References: <1448597449-17579-1-git-send-email-sergey.senozhatsky@gmail.com> <20151201051652.GA894@swordfish> Cc: Andrew Morton , linux-kernel@vger.kernel.org, Sergey Senozhatsky From: Kyeongdon Kim Message-ID: <565D3FCD.3060503@lge.com> Date: Tue, 1 Dec 2015 15:35:57 +0900 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:38.0) Gecko/20100101 Thunderbird/38.3.0 MIME-Version: 1.0 In-Reply-To: <20151201051652.GA894@swordfish> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4435 Lines: 140 On 2015-12-01 오후 2:16, Sergey Senozhatsky wrote: > On (12/01/15 13:55), Minchan Kim wrote: > [..] >> To clear my opinion, >> >> lzo_create(gfp_t flags) >> { >> void * ret = kmalloc(LZO1X_MEM_COMPRESS, flags); >> if (!ret) >> ret = vmalloc(LZO1X_MEM_COMPRESS, flasgs | GFP_NOMEMALLOC); >> return ret; >> } > > ah, ok, I see. I've a question. > > we had > kmalloc(f | __GFP_NOMEMALLOC) > __vmalloc(f | __GFP_NOMEMALLOC) > > which produced high failure rates for both kmalloc() and __vmalloc() > > test #1 > >> > > log message : > [..] >> > > [ 352.230608][0] zcomp_lz4_create: 32: ret = (null) >> > > [ 352.230619][0] zcomp_lz4_create: 38: ret = (null) >> > > [ 352.230888][0] zcomp_lz4_create: 32: ret = (null) >> > > [ 352.230902][0] zcomp_lz4_create: 38: ret = (null) >> > > [ 352.231406][0] zcomp_lz4_create: 32: ret = ffffffc002088000 >> > > [ 352.234024][0] zcomp_lz4_create: 32: ret = (null) >> > > [ 352.234060][0] zcomp_lz4_create: 38: ret = (null) >> > > [ 352.234359][0] zcomp_lz4_create: 32: ret = (null) > [..] >> > > [ 352.234384][0] zcomp_lz4_create: 38: ret = (null) >> > > [ 352.234618][0] zcomp_lz4_create: 32: ret = (null) >> > > [ 352.234639][0] zcomp_lz4_create: 38: ret = (null) >> > > [ 352.234667][0] zcomp_lz4_create: 32: ret = (null) >> > > [ 352.235179][0] zcomp_lz4_create: 38: ret = ffffff80016a4000 > > > > Kyeongdon, do I understand correctly, that for the second test you > removed '__GFP_NOMEMALLOC' from both kmalloc() and __vmalloc()? > > iow: > kmalloc(f & ~__GFP_NOMEMALLOC) > vmalloc(f & ~__GFP_NOMEMALLOC) > > test #2 : almost always failing kmalloc() and !NULL __vmalloc() > >> > > log message : >> > > <4>[ 2288.954934][0] KDKIM: zcomp_lz4_create: 24: ret = (null) >> > > <4>[ 2288.954972][0] KDKIM: zcomp_lz4_create: 30: ret = > ffffff800287e000 >> > > .... >> > > <4>[ 2289.092411][0] KDKIM: zcomp_lz4_create: 24: ret = (null) >> > > <4>[ 2289.092546][0] KDKIM: zcomp_lz4_create: 30: ret = > ffffff80028b5000 >> > > .... >> > > <4>[ 2289.135628][0] KDKIM: zcomp_lz4_create: 24: ret = (null) >> > > <4>[ 2289.135642][0] KDKIM: zcomp_lz4_create: 24: ret = (null) >> > > <4>[ 2289.135729][0] KDKIM: zcomp_lz4_create: 30: ret = > ffffff80028be000 >> > > <4>[ 2289.135732][0] KDKIM: zcomp_lz4_create: 30: ret = > ffffff80028c7000 > > > if this is the case (__GFP_NOMEMALLOC removed from both kmalloc and > __vmalloc), > then proposed > > kmalloc(f & ~__GFP_NOMEMALLOC) > __vmalloc(f | __GFP_NOMEMALLOC) > > > can be very close to 'test #1 && test #2': > > kmalloc() fails (as in test #2) > __vmalloc() fails (as in test #1) > > isn't it? > > -ss Let me give you a simple code of it. @test #1 (previous shared log) kmalloc(f | __GFP_NOMEMALLOC) __vmalloc(f | __GFP_NOMEMALLOC) // can find failure both @test #2 (previous shared log) kmalloc(f | __GFP_NOMEMALLOC) __vmalloc(f) // removed '__GFP_NOMEMALLOC' from vmalloc() only, and cannot find failure from vmalloc() And like you said, I made a quick check to see a failure about kmalloc() without the flag : @test #3 kmalloc(f) __vmalloc(f | __GFP_NOMEMALLOC) // removed '__GFP_NOMEMALLOC' from zmalloc() only // and cannot find failure from zmalloc(), but in this case, it's hard to find failure from vmalloc() because of already allocation mostly from zsmalloc() log message (test #3) : <4>[ 186.763605][1] KDKIM: zcomp_lz4_create: 24: ret = ffffffc002030000 <4>[ 186.776652][1] KDKIM: zcomp_lz4_create: 24: ret = ffffffc0020f0000 <4>[ 186.811423][1] KDKIM: zcomp_lz4_create: 24: ret = ffffffc002108000 <4>[ 186.816744][1] KDKIM: zcomp_lz4_create: 24: ret = ffffffc002000000 <4>[ 186.816796][1] KDKIM: zcomp_lz4_create: 24: ret = ffffffc002008000 @test #4 kmalloc(f) __vmalloc(f) // cannot find failure both until now log message (test #4) : <4>[ 641.440468][7] KDKIM: zcomp_lz4_create: 24: ret = ffffffc002190000 <4>[ 922.182980][7] KDKIM: zcomp_lz4_create: 24: ret = ffffffc002208000 <4>[ 923.197593][7] KDKIM: zcomp_lz4_create: 24: ret = ffffffc002020000 <4>[ 939.813499][7] KDKIM: zcomp_lz4_create: 24: ret = ffffffc0020a0000 So,is there another problem if we remove the flag from both sides? Thanks, Kyeongdon Kim -- 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/