Received: by 10.213.65.68 with SMTP id h4csp260066imn; Fri, 16 Mar 2018 02:08:27 -0700 (PDT) X-Google-Smtp-Source: AG47ELuhxZf3UaF6gV3LKSZ336uH+6XbWaOvSx2yCKeUlNPkj03mtI2+9x35dmERP+0LgB7tXkya X-Received: by 2002:a17:902:724b:: with SMTP id c11-v6mr1320967pll.352.1521191307381; Fri, 16 Mar 2018 02:08:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521191307; cv=none; d=google.com; s=arc-20160816; b=IGg47HMMJsBuH7M15h0fD9ygJkHCmYmYN5TufU0kFCxNIkSJvvUAw53ssgFL/X55WI 7KeyJaClCXfPGvoxCEI2IJrjKr/ui2UY6sDivqZ5b1OgAVj/0GSF57Hp0SKzHS6bWUT1 tM4yh+bpmfjmQX+govkzgNGYaNKNf6rdnx/n++rVzlhPO1V/NBLzLyexwHWjYCJceqYC cu1tgXYM+ZtrtPK4HPJyUHHFktsUgfIXvccM99riRnjb5f0zA0QOJ8KpF6yJXaDhp5au ca57ROQJZP+9yK2634TxMT64JaBNteTXq+jsDcgOcE5yRb1EbERaM8Z4ru04zYRxY9Ct 3w8A== 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:arc-authentication-results; bh=76k2vtDiSQpNf48Cz0mzWpmEgvisvO00/CdFb3t1cec=; b=jW/AhLpvsF4gxzm1SxX45+At0EHvE7ELYuk8ozDN6IFM3Wuo+L/iXiz1Kg6jz+dK95 Fde3gZkXHywmCfz6wPy+Nl4EEITZzMZJHbecmj5HTgPnwUwsznPM8YqjmqTqnvJcl6gM bANmMr3izB/Ucl6Z9pqHoGD9YVF3cdYZ1u0/5m2ogB2wzQgNydlE/A3df/9tFrkHcEgT We11MtNNvN3D+XpCkd/8xDGiCh84SiBs3awtSUvV507MS7aEmUBAspfpf1OdPZv9O0iy sUDRtzbUwE1/vHZIGJ4wjA8VGOEcxGnP/Se0QzXYFbVD/XW7nvaZY1OUI/kRqMdUfoZP KSrg== 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 k189si4735701pgc.598.2018.03.16.02.08.13; Fri, 16 Mar 2018 02:08:27 -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 S1753427AbeCPJGz (ORCPT + 99 others); Fri, 16 Mar 2018 05:06:55 -0400 Received: from mx2.suse.de ([195.135.220.15]:58050 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751094AbeCPJGt (ORCPT ); Fri, 16 Mar 2018 05:06:49 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (charybdis-ext.suse.de [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id D36ECAEB6; Fri, 16 Mar 2018 09:06:47 +0000 (UTC) Date: Fri, 16 Mar 2018 10:06:47 +0100 From: Michal Hocko To: Jia He Cc: Andrew Morton , linux-mm@kvack.org, Catalin Marinas , Pavel Tatashin , Ard Biesheuvel , AKASHI Takahiro , Gioh Kim , Daniel Vacek , linux-kernel@vger.kernel.org, Jia He Subject: Re: [PATCH] Revert "mm/memblock.c: hardcode the end_pfn being -1" Message-ID: <20180316090647.GC23100@dhcp22.suse.cz> References: <1521168966-5245-1-git-send-email-hejianet@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1521168966-5245-1-git-send-email-hejianet@gmail.com> User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu 15-03-18 19:56:06, Jia He wrote: > This reverts commit 379b03b7fa05f7db521b7732a52692448a3c34fe. > > Commit 864b75f9d6b0 ("mm/page_alloc: fix memmap_init_zone pageblock > alignment") introduced boot hang issues in arm/arm64 machines, so > Ard Biesheuvel reverted in commit 3e04040df6d4. But there is a > preparation patch for commit 864b75f9d6b0. So just revert it for > the sake of caution. Why? Is there anything wrong with this one? > > Signed-off-by: Jia He > --- > mm/memblock.c | 10 +++++----- > 1 file changed, 5 insertions(+), 5 deletions(-) > > diff --git a/mm/memblock.c b/mm/memblock.c > index b6ba6b7..5a9ca2a 100644 > --- a/mm/memblock.c > +++ b/mm/memblock.c > @@ -1107,7 +1107,7 @@ unsigned long __init_memblock memblock_next_valid_pfn(unsigned long pfn, > struct memblock_type *type = &memblock.memory; > unsigned int right = type->cnt; > unsigned int mid, left = 0; > - phys_addr_t addr = PFN_PHYS(++pfn); > + phys_addr_t addr = PFN_PHYS(pfn + 1); > > do { > mid = (right + left) / 2; > @@ -1118,15 +1118,15 @@ unsigned long __init_memblock memblock_next_valid_pfn(unsigned long pfn, > type->regions[mid].size)) > left = mid + 1; > else { > - /* addr is within the region, so pfn is valid */ > - return pfn; > + /* addr is within the region, so pfn + 1 is valid */ > + return min(pfn + 1, max_pfn); > } > } while (left < right); > > if (right == type->cnt) > - return -1UL; > + return max_pfn; > else > - return PHYS_PFN(type->regions[right].base); > + return min(PHYS_PFN(type->regions[right].base), max_pfn); > } > > /** > -- > 2.7.4 > -- Michal Hocko SUSE Labs