Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp4114241imd; Mon, 29 Oct 2018 18:30:13 -0700 (PDT) X-Google-Smtp-Source: AJdET5egVSjTdVBOxQxLYiU6wkox+AW7Lbj5egMKuG7Lo1nNeEpvWc2mVbiWGj2Z+qedJ1t2r3bO X-Received: by 2002:a63:588:: with SMTP id 130mr15906176pgf.273.1540863013067; Mon, 29 Oct 2018 18:30:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540863013; cv=none; d=google.com; s=arc-20160816; b=QqVqljaUIxCy7rqNVbDe9IbHG/Ld9qt7pMvLnSj9Ol7UOwstsKAyIA4uzHZ5nd+cex LAVKvs6C9UWiayThh7S7mfNkBKFbqXvzILnDnmq/UPqyKk6ddQl6tFJL0I25umxkC9rU h8qmpXuybW/luzPWeR9S+3sKgFC6blsvB4tx+M6ZfQbLvNPJIy0AfMTHouPVAvmVAHfZ cpC/ucjZ93IQ8zn0u+FncHTpknWT8XYMFW84HUuQhLAbQ3VdacpaVFykp725domj3YS0 lb5PgLjK4RiaAc2Bmd5MRZn3GJhYTUeRxyp5kUePAADkcpkZRodNSOzyCRgUp2GlhSYf 8j+g== 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=20wvSkGq7ozmPw73RO//UFgVRZuH9lKOI1L0c3c1wL0=; b=ZkYOeJCBCl/Y91qnIlLCiXUJra996Ti/WY+znsyCyn1fEQSF9aujS9E7U9qN3BL3Bn at22RmRi4b2hL9jHvivD2Yv7Ik0qeHJz42mLk8udZ3WNfDwpZkzITb/9RgbNMgsoPZdr Hq09RcX3vUn4JZXfz8RfTioYw4k7DkwoFIsUsqMQJDYfiB9gZ3XY2JhApvSHB1wnM5/w 8gfdk/Iv461FM2AfCk0ZatJ9kZmfQdXpFCtIIHyFM811vYiS8+odWtI12xzuU9A41klX vvXhMl8NuWEHkY6bS/GdvS9sgZCmqH4YSXDhf5FzElSX/YhFiXMVx0Bv/F6/elbmdWKP YS7Q== 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 l11-v6si21028063plt.216.2018.10.29.18.29.54; Mon, 29 Oct 2018 18:30:13 -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 S1726087AbeJ3KUv (ORCPT + 99 others); Tue, 30 Oct 2018 06:20:51 -0400 Received: from mailgw02.mediatek.com ([210.61.82.184]:35479 "EHLO mailgw02.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1725902AbeJ3KUv (ORCPT ); Tue, 30 Oct 2018 06:20:51 -0400 X-UUID: bf4319f52ccb49e6a55b67a58e6a52da-20181030 X-UUID: bf4319f52ccb49e6a55b67a58e6a52da-20181030 Received: from mtkcas09.mediatek.inc [(172.21.101.178)] by mailgw02.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 1095696761; Tue, 30 Oct 2018 09:29:12 +0800 Received: from mtkcas07.mediatek.inc (172.21.101.84) by mtkmbs03n2.mediatek.inc (172.21.101.182) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Tue, 30 Oct 2018 09:29:10 +0800 Received: from [172.21.77.33] (172.21.77.33) by mtkcas07.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1395.4 via Frontend Transport; Tue, 30 Oct 2018 09:29:10 +0800 Message-ID: <1540862950.12374.40.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 09:29:10 +0800 In-Reply-To: <20181029081706.GC32673@dhcp22.suse.cz> References: <1540790176-32339-1-git-send-email-miles.chen@mediatek.com> <20181029080708.GA32673@dhcp22.suse.cz> <20181029081706.GC32673@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: E2CBA49B416C4E3BC132CB3C34AA7BF195474575720F322FAF6EEBF393DA96F42000:8 X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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. > In any case such a changes should come with some numbers and as a > separate patch for sure. > > > > diff --git a/mm/util.c b/mm/util.c > > > index 8bf08b5b5760..7b1c59b9bfbf 100644 > > > --- a/mm/util.c > > > +++ b/mm/util.c > > > @@ -416,10 +416,10 @@ void *kvmalloc_node(size_t size, gfp_t flags, int node) > > > ret = kmalloc_node(size, kmalloc_flags, node); > > > > > > /* > > > - * It doesn't really make sense to fallback to vmalloc for sub page > > > - * requests > > > + * It only makes sense to fallback to vmalloc for sub page > > > + * requests if we might be able to allocate highmem pages. > > > */ > > > - if (ret || size <= PAGE_SIZE) > > > + if (ret || (!IS_ENABLED(CONFIG_HIGHMEM) && size <= PAGE_SIZE)) > > > return ret; > > > > > > return __vmalloc_node_flags_caller(size, node, flags, > > > -- > > > 2.18.0 > > > > > > > -- > > Michal Hocko > > SUSE Labs >