Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp1281503img; Fri, 22 Mar 2019 21:46:22 -0700 (PDT) X-Google-Smtp-Source: APXvYqy1LN29evkB4ptPLc0fIXedDQV9s7ESJbNM6EQPgJMV/n0uvQTASPXht3Vqxd4027epRwu+ X-Received: by 2002:a63:195:: with SMTP id 143mr12515301pgb.54.1553316382476; Fri, 22 Mar 2019 21:46:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553316382; cv=none; d=google.com; s=arc-20160816; b=0R+t25b3dQxUa8MtkkU6qu9AzvjMZUhX1StXytblRfLRCLpHjfju2ogjYj25tsH20C Q+KypEfWKKphMZv88F8X0Lyxy1yfo9muUSW+zFCZxPYoJb+t3DyGWJqPFSks5peVmEl5 ZMzB33U+bwe1XGwRS93957mD08WU8lXERgPFNeEIn958jP3bQxRlm47jFtkLrExvroCw fChbvmeNJ2LtU58Xvn7tbSFKufJTs8KXBtLc7v9oeoKa3TCEaqreB44zpP9PLGYo5T8s tqJ0vt3xCudp3gdideDzP265jhfYTaR4tpf3Kvt2zf1+5wnnFEwN3fl8dFB/8Ovj/EUw FXtQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=kdFWjbNMrgHE4IiWbQnApU5LlKLCfxjq39LREWERgU0=; b=lx4jzk6lpk5SAPSVum3Mzo7ccKPf+0lxnqDM3d7b9tAYJgBX9byHeUpGP1tvjj+cBP QBjETshglCkcRkzD4kRfOI3IL6cvd/C8PzQJuS0//nx1HMd9byn7TvKN63ZivUkWuFkK 3U98ezdwNO5T0bCOAd7XhkUH0sTfPclGP41wV6PrxiDLteFNI0Cw8xxCyuRJUYgWftWs 1fZsQd0wTKOZnZRNlc51DbgYl/j/S4U7/EFvHAh2U2oTEELtIPu66DeEvbcX8mChWizS ZNJbiPp2xNHnq28L9GmnmieoLcdtInDja3n8DMYsY7jIco4ah0QIrUcbVPyMqAcyVbvn KSPw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p24si6976074pfd.288.2019.03.22.21.46.07; Fri, 22 Mar 2019 21:46:22 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727157AbfCWEpO (ORCPT + 99 others); Sat, 23 Mar 2019 00:45:14 -0400 Received: from out30-130.freemail.mail.aliyun.com ([115.124.30.130]:59318 "EHLO out30-130.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725818AbfCWEpJ (ORCPT ); Sat, 23 Mar 2019 00:45:09 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R661e4;CH=green;DM=||false|;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e01424;MF=yang.shi@linux.alibaba.com;NM=1;PH=DS;RN=14;SR=0;TI=SMTPD_---0TNPuxAM_1553316293; Received: from e19h19392.et15sqa.tbsite.net(mailfrom:yang.shi@linux.alibaba.com fp:SMTPD_---0TNPuxAM_1553316293) by smtp.aliyun-inc.com(127.0.0.1); Sat, 23 Mar 2019 12:45:02 +0800 From: Yang Shi To: mhocko@suse.com, mgorman@techsingularity.net, riel@surriel.com, hannes@cmpxchg.org, akpm@linux-foundation.org, dave.hansen@intel.com, keith.busch@intel.com, dan.j.williams@intel.com, fengguang.wu@intel.com, fan.du@intel.com, ying.huang@intel.com Cc: yang.shi@linux.alibaba.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: [PATCH 03/10] mm: mempolicy: promote page to DRAM for MPOL_HYBRID Date: Sat, 23 Mar 2019 12:44:28 +0800 Message-Id: <1553316275-21985-4-git-send-email-yang.shi@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1553316275-21985-1-git-send-email-yang.shi@linux.alibaba.com> References: <1553316275-21985-1-git-send-email-yang.shi@linux.alibaba.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org With MPOL_HYBRID the memory allocation may end up on non-DRAM node, this may be not optimal for performance. Promote pages to DRAM with NUMA balancing for MPOL_HYBRID. If DRAM nodes are specified, migrate to the specified nodes. If no DRAM node is specified, migrate to the local DRAM node. Signed-off-by: Yang Shi --- mm/mempolicy.c | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/mm/mempolicy.c b/mm/mempolicy.c index 7d0a432..87bc691 100644 --- a/mm/mempolicy.c +++ b/mm/mempolicy.c @@ -2339,6 +2339,7 @@ int mpol_misplaced(struct page *page, struct vm_area_struct *vma, unsigned long struct zoneref *z; int curnid = page_to_nid(page); unsigned long pgoff; + nodemask_t nmask; int thiscpu = raw_smp_processor_id(); int thisnid = cpu_to_node(thiscpu); int polnid = NUMA_NO_NODE; @@ -2363,7 +2364,24 @@ int mpol_misplaced(struct page *page, struct vm_area_struct *vma, unsigned long break; case MPOL_HYBRID: - /* Fall through */ + if (node_isset(curnid, pol->v.nodes) && + node_isset(curnid, def_alloc_nodemask)) + /* The page is already on DRAM node */ + goto out; + + /* + * Promote to the DRAM node specified by the policy, or + * the local DRAM node if no DRAM node is specified. + */ + nodes_and(nmask, pol->v.nodes, def_alloc_nodemask); + + z = first_zones_zonelist( + node_zonelist(numa_node_id(), GFP_HIGHUSER), + gfp_zone(GFP_HIGHUSER), + nodes_empty(nmask) ? &def_alloc_nodemask : &nmask); + polnid = z->zone->node; + + break; case MPOL_BIND: -- 1.8.3.1