Received: by 10.192.165.148 with SMTP id m20csp2093367imm; Sun, 6 May 2018 06:50:13 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrOcZJ2hGukZorcuv68OvvIpe//0RX4Wh6J5Ebo6mrk8SMjmduJNLLV/i7Q1SrWElq0Km+D X-Received: by 10.98.152.203 with SMTP id d72mr33399781pfk.98.1525614613326; Sun, 06 May 2018 06:50:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525614613; cv=none; d=google.com; s=arc-20160816; b=JB/aYVDzzTRE34TZtqpfIhtBGFjz8D3EL1vLSG9689AEdRpqMGMT7Z7JYAhiUnyrov iy/8r51ykgw0JF5/5ZzmZGKS6nvtrpHWfuFDJMjj1dxIc73zfOBskEVKQImUdoJPWm06 K3eZwwWZTQSCGHko44Bfsp0tZ77pT15+eQ163doTbKPSZzzUlAzYoSgvbPQ3BNRKCYcU qmVpKj4/5OUvMlmQlVjHMVGiORFObJoFbsFVXQsL05Re9ANZLmXDX8RVO1nXwmkf7vpV 0NLecGkGjXjlKwo2+18wVM9Gb45aunrXh94dTaa+kQ/BSjNnEmyLY5Y+JllQRRISVKIW 28PA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature:arc-authentication-results; bh=6/xJf+mK2glVqCP6SCqzlVTWkF53IpE913Is2G+OWtk=; b=dAULCFphKJ3ugO6JktnE5hwYDEmw+cz+q1KwBNguYZJ7tLGdB/k7OJvFGS51Oyhe/g a0oy59Dsciba1BMrx2MPsxh+Opj1s0q2QfCdgmn3twpmZeJAHSjx0d513W3cMMjjsEGD mQyGR4rufV6RWtQo4Rt+kJWrWugKKsAdUu6s1iJLGj5/OVQ/uHhXyjjBCnV67P82eFeJ uDTTXZ4QsP6EadQnc9BZdJEPHnEKRMcJZM28wGw4C4TRuyRd4bcGLIGEKxamqm8b9ghh N0Ue+sIpjXUhPVDwa0oKUJmciV1mpPCdvMZHlKYKs6KCEsnunOZVO3tUbtWrms/jGfNp EtDA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=Gm6yQv0k; 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 d65si21195404pfd.182.2018.05.06.06.49.46; Sun, 06 May 2018 06:50: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; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=Gm6yQv0k; 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 S1751692AbeEFNs3 (ORCPT + 99 others); Sun, 6 May 2018 09:48:29 -0400 Received: from bombadil.infradead.org ([198.137.202.133]:52894 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751230AbeEFNs2 (ORCPT ); Sun, 6 May 2018 09:48:28 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=6/xJf+mK2glVqCP6SCqzlVTWkF53IpE913Is2G+OWtk=; b=Gm6yQv0kx4gRiWWfDzaPVi/uG d3M2Y92A1q8V4qr4+DTMYEva1SOXaTiV7SZxWvn7EbJXtOiz0K2AtKiN3XOEYdbVcv29TwmQBZul0 BSkC8HNn9Zs+A5X91dIFUOWSwuMY7ExZDuLG+OR4GmDR2uJdk4AKBKg0/OW+u1/7goe3e/rkYrTZL mFNyVAHtINASRnCK+rWY4oF/vfFJ2L0nP57DlK3onH2DEP82xd0TWMLiG3JNFgp3+CS6ZkZLKjyzY +zEBYPZDZFlypZW7+B1LbGKsyzKcN4HzD52wjpAH94spGKbJhki3ChOw6UvratCFnp/v0+bQMbsfs Rv+dPrKFA==; Received: from willy by bombadil.infradead.org with local (Exim 4.90_1 #2 (Red Hat Linux)) id 1fFK1P-0004PH-FH; Sun, 06 May 2018 13:48:15 +0000 Date: Sun, 6 May 2018 06:48:14 -0700 From: Matthew Wilcox To: Huaisheng HS1 Ye Cc: Michal Hocko , "akpm@linux-foundation.org" , "linux-mm@kvack.org" , "vbabka@suse.cz" , "mgorman@techsingularity.net" , "pasha.tatashin@oracle.com" , "alexander.levin@verizon.com" , "hannes@cmpxchg.org" , "penguin-kernel@I-love.SAKURA.ne.jp" , "colyli@suse.de" , NingTing Cheng , "linux-kernel@vger.kernel.org" Subject: Re: [External] Re: [PATCH 2/3] include/linux/gfp.h: use unsigned int in gfp_zone Message-ID: <20180506134814.GB7362@bombadil.infradead.org> References: <1525416729-108201-1-git-send-email-yehs1@lenovo.com> <1525416729-108201-3-git-send-email-yehs1@lenovo.com> <20180504133533.GR4535@dhcp22.suse.cz> <20180504154004.GB29829@bombadil.infradead.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.9.2 (2017-12-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, May 06, 2018 at 09:32:15AM +0000, Huaisheng HS1 Ye wrote: > This idea is great, we can replace GFP_ZONE_TABLE and GFP_ZONE_BAD with it. > I have realized it preliminarily based on your code and tested it on a 2 sockets platform. Fortunately, we got a positive test result. Great! > I made some adjustments for __GFP_HIGHMEM, this flag is special than others, because the return result of gfp_zone has two possibilities, which depend on ___GFP_MOVABLE has been enabled or disabled. > When ___GFP_MOVABLE has been enabled, ZONE_MOVABLE shall be returned. When disabled, OPT_ZONE_HIGHMEM shall be used. > > #define __GFP_DMA ((__force gfp_t)OPT_ZONE_DMA ^ ZONE_NORMAL) > #define __GFP_HIGHMEM ((__force gfp_t)ZONE_MOVABLE ^ ZONE_NORMAL) I'm not sure this is right ... Let me think about this a little. > #define __GFP_DMA32 ((__force gfp_t)OPT_ZONE_DMA32 ^ ZONE_NORMAL) > #define __GFP_MOVABLE ((__force gfp_t)___GFP_MOVABLE) /* ZONE_MOVABLE allowed */ > #define GFP_ZONEMASK ((__force gfp_t)___GFP_ZONE_MASK | ___GFP_MOVABLE) > > The present situation is that, based on this change, the bits of flags, __GFP_DMA and __GFP_HIGHMEM and __GFP_DMA32, have been encoded. > That is totally different from existing code, you know in kernel scope, there are many drivers or subsystems use these flags directly to realize bit manipulations like this below, > swiotlb-xen.c (drivers\xen): flags &= ~(__GFP_DMA | __GFP_HIGHMEM); > extent_io.c (fs\btrfs): mask &= ~(__GFP_DMA32|__GFP_HIGHMEM); > > Because of these flags have been encoded, the above operations can cause problem. > I am trying to get a solution to resolve it. Any progress will be reported. These users probably want: flags &= GFP_RECLAIM_MASK;