Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp4350182imd; Mon, 29 Oct 2018 23:57:12 -0700 (PDT) X-Google-Smtp-Source: AJdET5dY8xOk4zhH4JVEpyOLbmpc2LITh4r2J196CEhqeArTUq4xrRwPsgnnrcEBom7GmkAJ17vP X-Received: by 2002:a63:a064:: with SMTP id u36mr16977795pgn.145.1540882632531; Mon, 29 Oct 2018 23:57:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540882632; cv=none; d=google.com; s=arc-20160816; b=lwUpURACsrKLB5QnNjf++hFWDKH/siJ6TjE0vMqcXyeCxcZLfiZpuv7UMSpr7frfR3 xhAlhuMSPhM6xLSPSxea5Or8X1/dSh9FSMNWM92GvJb4ioW2T503r/j9ifoCWE4rF5mq IFzTQt1+HXomsBym8PPogJp4rM2L/xqL5MjQfR4FHd4T2GqIqQ8pIx3JauEjU7e1Fd62 GEtwIejbWpH3c4eJg5GfnfcPqWhiTWJx04qS/sI/ww/HTr05qTcXLbD8h5PlPnxpp+hp BFEdPE4H5bQWze6vQof0BvpAV6RulTiFPIxKy5UIWb2eSNaDS7n3EcLr9sVnP3Vy03oD 2Hgw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :references:in-reply-to:date:cc:to:from:subject:message-id; bh=g+gaudwzXN9oM+XlZM7tuq7fM8Kic8OMiSy3OK1SV2o=; b=O6nMZKu9QEf8Ri51PssVHU4BNV9mhEzIP6MlYlPko+8qx9HohUV7sTKGjKNtAr3/zR 6FPzr6TTA3MDQAEV281ETo2QlVM0B1ALJoA/vBwyu9+4S3Ls0QH8gAOtFvCgl+OIjigB GM/yzB99tmh18gELnmsb/TwoSKVyA1TWJbiMA+tq9hfLL6MB6J9iLMZNrX4mEUsiOdng S2mSCuDrEIl5eB9w7WI49uxLX/BYCrD8aTMlF9t3oY/PHPinWm5a24I6sGJN4pUhJ2MC /JQpfXf4RjKU/T0gVHrBY7d0Fit8a0c0SlO3wW990xWJo/lGYmBI94aWJ3EVYGTLhBt7 HtRw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y18-v6si22657299pgf.476.2018.10.29.23.56.57; Mon, 29 Oct 2018 23:57:12 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727534AbeJ3PsT (ORCPT + 99 others); Tue, 30 Oct 2018 11:48:19 -0400 Received: from mailgw01.mediatek.com ([210.61.82.183]:63313 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1727501AbeJ3PsS (ORCPT ); Tue, 30 Oct 2018 11:48:18 -0400 X-UUID: fce3c53b849b4bad842c84424a684b20-20181030 X-UUID: fce3c53b849b4bad842c84424a684b20-20181030 Received: from mtkcas06.mediatek.inc [(172.21.101.30)] by mailgw01.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 1840357904; Tue, 30 Oct 2018 14:55:53 +0800 Received: from MTKCAS06.mediatek.inc (172.21.101.30) by mtkmbs03n2.mediatek.inc (172.21.101.182) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Tue, 30 Oct 2018 14:55:51 +0800 Received: from [172.21.77.33] (172.21.77.33) by MTKCAS06.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1395.4 via Frontend Transport; Tue, 30 Oct 2018 14:55:51 +0800 Message-ID: <1540882551.23278.12.camel@mtkswgap22> Subject: Re: [PATCH v3] mm/page_owner: use kvmalloc instead of kmalloc From: Miles Chen To: Michal Hocko CC: Andrew Morton , Joe Perches , Matthew Wilcox , , , , , Date: Tue, 30 Oct 2018 14:55:51 +0800 In-Reply-To: <20181030060601.GR32673@dhcp22.suse.cz> References: <1540790176-32339-1-git-send-email-miles.chen@mediatek.com> <20181029080708.GA32673@dhcp22.suse.cz> <20181029081706.GC32673@dhcp22.suse.cz> <1540862950.12374.40.camel@mtkswgap22> <20181030060601.GR32673@dhcp22.suse.cz> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.2.3-0ubuntu6 Content-Transfer-Encoding: 7bit MIME-Version: 1.0 X-TM-SNTS-SMTP: 2E26B09DC99F707EAE83DE70B9D57D6161CD602C3CEB5221A275CD5945312BFA2000:8 X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2018-10-30 at 07:06 +0100, Michal Hocko wrote: > On Tue 30-10-18 09:29:10, Miles Chen wrote: > > On Mon, 2018-10-29 at 09:17 +0100, Michal Hocko wrote: > > > On Mon 29-10-18 09:07:08, Michal Hocko wrote: > > > [...] > > > > Besides that, the following doesn't make much sense to me. It simply > > > > makes no sense to use vmalloc for sub page allocation regardless of > > > > HIGHMEM. > > > > > > OK, it is still early morning here. Now I get the point of the patch. > > > You just want to (ab)use highmeme for smaller requests. I do not like > > > this, to be honest. It causes an internal fragmentation and more > > > importantly the VMALLOC space on 32b where HIGHMEM is enabled (do we > > > have any 64b with HIGHMEM btw?) is quite small to be wasted like that. > > > > > thanks for your comment. It looks like that using vmalloc fallback for > > sub page allocation is not good here. > > > > Your comment gave another idea: > > > > 1. force kbuf to PAGE_SIZE > > 2. allocate a page by alloc_page(GFP_KERNEL | __GFP_HIGHMEM); so we can > > get a highmem page if possible > > 3. use kmap/kunmap pair to create mapping for this page. No vmalloc > > space is used. > > 4. do not change kvmalloc logic. > > If you mean for this particular situation then is this really worth > it? I mean this is a short term allocation for root only so you do not > have to worry about low mem depletion. The 1...3 are applied to print_page_owner(), not in kmalloc() or kvmalloc() logic. It's a real problem when using page_owner. I found this issue recently: I'm not able to read page_owner information during a overnight test. (error: read failed: Out of memory). I replace kmalloc() with vmalloc() and it worked well. > > If you are thiking in more generic terms to allow kmalloc to use highmem > then I am not really sure this will work out. I'm thinking about modify print_page_owner().