Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp373500ybb; Fri, 3 Apr 2020 04:29:16 -0700 (PDT) X-Google-Smtp-Source: APiQypLmIGSopmeZ6ia1fdYV+LeVMWJ54YboNGAqCbr7qELB4acwp6z3asnFoCL728sLUSeaq+ds X-Received: by 2002:aca:ebca:: with SMTP id j193mr2505930oih.124.1585913356043; Fri, 03 Apr 2020 04:29:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585913356; cv=none; d=google.com; s=arc-20160816; b=Err6NW3oOmlkmWofaQu0rUfh19TwpLziDyrRqFGS2ntcbFxEhL+BcFwAx1g4FdVD9h oXtsyCB6w5gz6+NBaUJor8UeE7mNidtO48BqoXHys8nyY7cJ1Ev3IA98u4v1WUoOpM/J iravfbYelL4ZWnekvbd7rNJlOwqnFqmcpT4MGLjbAVtm1FLuSQnw5Ge7CKduBKTEXKv8 htYMh9hWIP2EsvUaVhOIpMtiM89Sx4sViMIJifPWuXvALim2WYQJ4z0eDogJCwa0tCeO Fij0TLa1Hx0ockWZ0rbOqnBIFfpe7o8pz2hJ1s/6MAV/KGr/M5+pNM32O+xAdpbdgvES vuFg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding: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=vFXE1v1dpXNsso07ONV8QkrZjI6HvkS+wYQRkAeyH5w=; b=UX1GSWJukQKfR0WPEFjKXRRBbIxl25EeIepRVXevKLoXk6oIolCXNjOnkO8fjlSzTb dU94L07in8YbdxMXx/fa7OMIUrn3fLYJncY34InidSNREpH4MDWOya1j2igL/6GaikTa ynAdOTe+BNfM0mrci15jPreT3/vtSCewvcuFoQaFYqbqopfEqMu4nhiOqjavS5fiYR97 /w3cG38K3q3Xc9wJgbHIR2RFWtM26EeuBZ04ceYUJnA6m63QuHi6C47uJXpuvicEQJl0 nTIILLtQM4W8c8aJJJsv7+t1ro/vkR+wkKOokLR1DpZ8atK043vYD2madtS0Sz3MCX7B AJpg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@fb.com header.s=facebook header.b=YKTjNsZt; 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 a21si4503713otk.277.2020.04.03.04.29.00; Fri, 03 Apr 2020 04:29:16 -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=YKTjNsZt; 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 S2390754AbgDCLTD (ORCPT + 99 others); Fri, 3 Apr 2020 07:19:03 -0400 Received: from mx0a-00082601.pphosted.com ([67.231.145.42]:5400 "EHLO mx0a-00082601.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728023AbgDCLTD (ORCPT ); Fri, 3 Apr 2020 07:19:03 -0400 Received: from pps.filterd (m0044012.ppops.net [127.0.0.1]) by mx0a-00082601.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 033BF6Ro020188 for ; Fri, 3 Apr 2020 04:19:02 -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-transfer-encoding : content-type; s=facebook; bh=vFXE1v1dpXNsso07ONV8QkrZjI6HvkS+wYQRkAeyH5w=; b=YKTjNsZtRPZXqyyfQsUiDPNgUF+gRzzHE1nbzzeV/ETTWDmwEucDLFziBFJJ3tnuqByK VmzixDuzhulmoyNSal4oNuj+TxngC6Qp9UeAYm4bLiufhhAEao03xI4oTsP8rw6JBbAt bR62pWykFm6OtFQJlhaFr0OBdl0MS8y6qDE= Received: from maileast.thefacebook.com ([163.114.130.16]) by mx0a-00082601.pphosted.com with ESMTP id 305upk9tx1-18 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT) for ; Fri, 03 Apr 2020 04:19:02 -0700 Received: from intmgw001.08.frc2.facebook.com (2620:10d:c0a8:1b::d) by mail.thefacebook.com (2620:10d:c0a8:83::7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1847.3; Fri, 3 Apr 2020 04:18:49 -0700 Received: by devbig020.ftw1.facebook.com (Postfix, from userid 179119) id E2A1358C06B4; Fri, 3 Apr 2020 04:18:47 -0700 (PDT) Smtp-Origin-Hostprefix: devbig From: Aslan Bakirov Smtp-Origin-Hostname: devbig020.ftw1.facebook.com To: CC: , , , , , , , Aslan Bakirov , Michal Hocko Smtp-Origin-Cluster: ftw1c07 Subject: [PATCH 2/2] mm: hugetlb: Use node interface of cma Date: Fri, 3 Apr 2020 04:18:12 -0700 Message-ID: <20200403111812.705955-2-aslan@fb.com> X-Mailer: git-send-email 2.24.1 In-Reply-To: <20200403111812.705955-1-aslan@fb.com> References: <20200403111812.705955-1-aslan@fb.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-FB-Internal: Safe Content-Type: text/plain X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.138,18.0.676 definitions=2020-04-03_07:2020-04-02,2020-04-03 signatures=0 X-Proofpoint-Spam-Details: rule=fb_default_notspam policy=fb_default score=0 malwarescore=0 bulkscore=0 mlxscore=0 adultscore=0 impostorscore=0 lowpriorityscore=0 priorityscore=1501 spamscore=0 suspectscore=1 mlxlogscore=999 phishscore=0 clxscore=1015 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2003020000 definitions=main-2004030099 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 Acked-by: Michal Hocko --- mm/hugetlb.c | 34 ++++++---------------------------- 1 file changed, 6 insertions(+), 28 deletions(-) diff --git a/mm/hugetlb.c b/mm/hugetlb.c index b9f0c903c4cf..8fbf11de747b 100644 --- a/mm/hugetlb.c +++ b/mm/hugetlb.c @@ -5573,42 +5573,20 @@ void __init hugetlb_cma_reserve(int order) =20 reserved =3D 0; for_each_node_state(nid, N_ONLINE) { - unsigned long min_pfn =3D 0, max_pfn =3D 0; int res; -#ifdef CONFIG_NUMA - unsigned long start_pfn, end_pfn; - int i; =20 - for_each_mem_pfn_range(i, nid, &start_pfn, &end_pfn, NULL) { - if (!min_pfn) - min_pfn =3D start_pfn; - max_pfn =3D end_pfn; - } -#else - min_pfn =3D min_low_pfn; - max_pfn =3D max_low_pfn; -#endif size =3D min(per_node, hugetlb_cma_size - reserved); size =3D round_up(size, PAGE_SIZE << order); =20 - if (size > ((max_pfn - min_pfn) << PAGE_SHIFT) / 2) { - pr_warn("hugetlb_cma: cma_area is too big, please try less than %lu M= iB\n", - round_down(((max_pfn - min_pfn) << PAGE_SHIFT) * - nr_online_nodes / 2 / SZ_1M, - PAGE_SIZE << order)); - break; - } - - res =3D cma_declare_contiguous(PFN_PHYS(min_pfn), size, - PFN_PHYS(max_pfn), + res =3D 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 =3D PFN_PHYS(min_pfn); - phys_addr_t endpa =3D 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; } =20 --=20 2.24.1