Received: by 2002:a17:90a:1609:0:0:0:0 with SMTP id n9csp2389275pja; Thu, 26 Mar 2020 14:28:22 -0700 (PDT) X-Google-Smtp-Source: ADFU+vu4R9OlddSwTvXdoj+ADa9KmjezfEZel7QXcuIMChbyDJ8++J2T110KYfK3rz62IWzT+VY+ X-Received: by 2002:a9d:6a92:: with SMTP id l18mr6230421otq.252.1585258102244; Thu, 26 Mar 2020 14:28:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585258102; cv=none; d=google.com; s=arc-20160816; b=HjT2Zs5KJAVhw2MXrvIMCumY5TZ61IlPBBsimepiNb4IpzQlNfeZK5yAqxqmrarlko O/MJUW5TPJa3mctOzSCdIsMv6hOJ1IaZ+gkU4qi4RfJJ8PZbtP/R65vG6rt0auBHuY7S B5O5TP8GMMLo0V0mvjQPTCNzHwINUKd0S8IFlsVJp5oSW2UzjLnk3ba028aP/0enxY7c GdczoehxhwkYwZGy9pcxMDczeWxzEnZ0r2q+YqYD97U8akeNL72rqS2NBvMJO9BhRsGh tWw7M8jz2i+Y3RJsbn55jr/k+/I/ss4YAMmoEB8XODDryN5I+wX8OFm7l92pTUfsDhUU yufQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:smtp-origin-cluster:cc:to :smtp-origin-hostname:from:smtp-origin-hostprefix:dkim-signature; bh=ItdNQw/noJ2LMBcAUV/ubfbzHSp3eHum+DlAmoEqdLc=; b=iH9y373KiXBsh/s/S1YkxP90ca+wz69yr72FZhK/OOaROCDkWIRSaUQEx5cVaLWpw0 k//bD7Ixa4rBts9WT+bSyYkCjHVPM/MAoiwLSQEhDOLnb1PmPABX5XaOKgGmX8nsc6dL k2vL20M5xruRcmyN9hVtIEc4Oa596NVeyEHAX/wp2/BXMjaSMkbu3gnYdMWLBRng/6It UnOEiHWUUtK8fWShgBHLI3RvYxv/Dydx1fbe/FRDa816xHG+7Pu+hDJw7uODrXjvAAoZ qupXzWBdG2KPoHwHxiAkWlg3znMTfgl3Qiqx4feNm7w9arPNisrW7gN09NBIav1oBB3i METg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@fb.com header.s=facebook header.b=nmtehlTr; 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=pass (p=NONE sp=NONE dis=NONE) header.from=fb.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id z17si1609793oth.282.2020.03.26.14.28.09; Thu, 26 Mar 2020 14:28: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; dkim=pass header.i=@fb.com header.s=facebook header.b=nmtehlTr; 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=pass (p=NONE sp=NONE dis=NONE) header.from=fb.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727612AbgCZV1b (ORCPT + 99 others); Thu, 26 Mar 2020 17:27:31 -0400 Received: from mx0a-00082601.pphosted.com ([67.231.145.42]:28642 "EHLO mx0a-00082601.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726270AbgCZV1a (ORCPT ); Thu, 26 Mar 2020 17:27:30 -0400 Received: from pps.filterd (m0044010.ppops.net [127.0.0.1]) by mx0a-00082601.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 02QLRDRu005444 for ; Thu, 26 Mar 2020 14:27:29 -0700 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fb.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-type; s=facebook; bh=ItdNQw/noJ2LMBcAUV/ubfbzHSp3eHum+DlAmoEqdLc=; b=nmtehlTr87KQZK4+IS6E58ipvNG2OYYaSN3+YrD+zHNvdz2wDRjqvD71mCgY6XpKdA6L noieTJEMKFCqXqXOY5zOPxD5Rk5blwTmGb07i5QW47+OCVe7j/WKEV8S/jTjGAmEEarB liwZoW9AnO/GZayILcVqgjlSCD48swIPzkk= Received: from mail.thefacebook.com ([163.114.132.120]) by mx0a-00082601.pphosted.com with ESMTP id 2yx2xpas09-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT) for ; Thu, 26 Mar 2020 14:27:29 -0700 Received: from intmgw004.08.frc2.facebook.com (2620:10d:c085:208::f) by mail.thefacebook.com (2620:10d:c085:21d::6) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1847.3; Thu, 26 Mar 2020 14:27:28 -0700 Received: by devbig020.ftw1.facebook.com (Postfix, from userid 179119) id 7ECC858C1E71; Thu, 26 Mar 2020 14:27:28 -0700 (PDT) Smtp-Origin-Hostprefix: devbig From: Aslan Bakirov Smtp-Origin-Hostname: devbig020.ftw1.facebook.com To: CC: , , , , , , , Aslan Bakirov Smtp-Origin-Cluster: ftw1c07 Subject: [PATCH 2/2] mm: hugetlb: Use node interface of cma Date: Thu, 26 Mar 2020 14:27:18 -0700 Message-ID: <20200326212718.3798742-2-aslan@fb.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200326212718.3798742-1-aslan@fb.com> References: <20200326212718.3798742-1-aslan@fb.com> X-FB-Internal: Safe MIME-Version: 1.0 Content-Type: text/plain X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.138,18.0.645 definitions=2020-03-26_13:2020-03-26,2020-03-26 signatures=0 X-Proofpoint-Spam-Details: rule=fb_default_notspam policy=fb_default score=0 suspectscore=1 priorityscore=1501 mlxscore=0 lowpriorityscore=0 mlxlogscore=999 spamscore=0 impostorscore=0 malwarescore=0 clxscore=1015 adultscore=0 bulkscore=0 phishscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2003020000 definitions=main-2003260156 X-FB-Internal: deliver Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org With introduction of numa node interface for CMA, this patch is for using that interface for allocating memory on numa nodes if NUMA is configured. This will be more efficient and cleaner because first, instead of iterating mem range of each numa node, cma_declare_contigueous_nid() will do its own address finding if we pass 0 for both min_pfn and max_pfn, second, it can also handle caseswhere NUMA is not configured by passing NUMA_NO_NODE as an argument. In addition, checking if desired size of memory is available or not, is happening in cma_declare_contiguous_nid() because base and limit will be determined there, since 0(any) for base and 0(any) for limit is passed as argument to the function. Signed-off-by: Aslan Bakirov --- mm/hugetlb.c | 40 +++++++++++----------------------------- 1 file changed, 11 insertions(+), 29 deletions(-) diff --git a/mm/hugetlb.c b/mm/hugetlb.c index b9f0c903c4cf..62989220c4ff 100644 --- a/mm/hugetlb.c +++ b/mm/hugetlb.c @@ -5573,42 +5573,24 @@ void __init hugetlb_cma_reserve(int order) reserved = 0; for_each_node_state(nid, N_ONLINE) { - unsigned long min_pfn = 0, max_pfn = 0; int res; -#ifdef CONFIG_NUMA - unsigned long start_pfn, end_pfn; - int i; - for_each_mem_pfn_range(i, nid, &start_pfn, &end_pfn, NULL) { - if (!min_pfn) - min_pfn = start_pfn; - max_pfn = end_pfn; - } -#else - min_pfn = min_low_pfn; - max_pfn = max_low_pfn; -#endif size = min(per_node, hugetlb_cma_size - reserved); size = round_up(size, PAGE_SIZE << order); - - if (size > ((max_pfn - min_pfn) << PAGE_SHIFT) / 2) { - pr_warn("hugetlb_cma: cma_area is too big, please try less than %lu MiB\n", - round_down(((max_pfn - min_pfn) << PAGE_SHIFT) * - nr_online_nodes / 2 / SZ_1M, - PAGE_SIZE << order)); - break; - } - - res = cma_declare_contiguous(PFN_PHYS(min_pfn), size, - PFN_PHYS(max_pfn), + + +#ifndef CONFIG_NUMA + nid = NUMA_NO_NODE +#endif + res = cma_declare_contiguous_nid(0, size, + 0, PAGE_SIZE << order, 0, false, - "hugetlb", &hugetlb_cma[nid]); + "hugetlb", &hugetlb_cma[nid], nid); + if (res) { - phys_addr_t begpa = PFN_PHYS(min_pfn); - phys_addr_t endpa = PFN_PHYS(max_pfn); - pr_warn("%s: reservation failed: err %d, node %d, [%pap, %pap)\n", - __func__, res, nid, &begpa, &endpa); + pr_warn("%s: reservation failed: err %d, node %d\n", + __func__, res, nid); break; } -- 2.17.1