Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp2983413ybn; Thu, 26 Sep 2019 22:19:02 -0700 (PDT) X-Google-Smtp-Source: APXvYqyBY5WzX28YFJlF2xOGNGfWuPuuWlMQRGEt39QVxTdCDU80+ZWpQCafRnn6aQ7Ktm9Cu8O/ X-Received: by 2002:a17:906:c822:: with SMTP id dd2mr3949532ejb.165.1569561542251; Thu, 26 Sep 2019 22:19:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569561542; cv=none; d=google.com; s=arc-20160816; b=QTTouDbkY5q6FY4IMEblz96SF18ghBGN+rSXbGZEHci/TsfMNOAMN5PZ9m96nQNIH3 QqyTXIrELbwgr4g4cG+dio6tyny0g7KwsW4ZtUTMhmdQY2jX5C9rf1r2r68zhehnm96P SgXewZrGDVHpY6rrnPfY2VkZAFM8uhMyfwaLW1LAjxbvCsi2cm++trMjAnQ6RK/wrAmR wAYgKFEaw5N90S7AL/SWHIElbgdXg20zGO0X1ln1yv8Lv9hBTO3IXmHyLYZ+w/Y/NyKd YAyfPMOfZznVjGqfc/mFqPHvMx7dflOEWHN7FqvDLImwLEdhfgld/96/scM07IJivupI hLoQ== 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 :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id; bh=QOfyne94wtnWBRxUQknf3hUqRzqxFN8OhPuWQEOSjEQ=; b=fNLMyjilMtzCY8h8waQJaFXWmf5BnIAdobaNQdpdiw/R0UEmIY5zuTsUvnWxCWRgm8 0nf4g+gioMyzmQgVfBgA90eyaynIkX4hlhVNDvCXQhovjPJjmLm8IjrhQ24h+EcDm2N3 /oqSgvtQTvXsopt2kQM3BkHPZ5Vt1RuV0OepsweRZHI2jaAw+GcUBxTO6TdvoPKrDVYn 3+B+fs6iOPELDB9YtSGKULG05xjyFdI198BScyY8BK4N0h9ZLiPmy88wLowc7Jep+ZYU fRbwAJ9t67e9Pd0JRAjdZkUoYMoiZ4Pj5NuVZd3hzpKC0uEnizuGNgMah50l6+YdR8GX ikmg== 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 d17si832096edv.76.2019.09.26.22.18.37; Thu, 26 Sep 2019 22:19:02 -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 S1725939AbfI0FO3 (ORCPT + 99 others); Fri, 27 Sep 2019 01:14:29 -0400 Received: from ushosting.nmnhosting.com ([66.55.73.32]:60298 "EHLO ushosting.nmnhosting.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725268AbfI0FO3 (ORCPT ); Fri, 27 Sep 2019 01:14:29 -0400 Received: from mail2.nmnhosting.com (unknown [202.78.40.170]) by ushosting.nmnhosting.com (Postfix) with ESMTPS id 0C2522DC009C; Fri, 27 Sep 2019 01:14:24 -0400 (EDT) Received: from adsilva.ozlabs.ibm.com (static-82-10.transact.net.au [122.99.82.10] (may be forged)) (authenticated bits=0) by mail2.nmnhosting.com (8.15.2/8.15.2) with ESMTPSA id x8R5E5Gx002542 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=NO); Fri, 27 Sep 2019 15:14:21 +1000 (AEST) (envelope-from alastair@d-silva.org) Message-ID: Subject: Re: [PATCH v4] memory_hotplug: Add a bounds check to __add_pages From: "Alastair D'Silva" To: Oscar Salvador Cc: Andrew Morton , Michal Hocko , David Hildenbrand , Pavel Tatashin , Dan Williams , linux-mm@kvack.org, linux-kernel@vger.kernel.org Date: Fri, 27 Sep 2019 15:14:05 +1000 In-Reply-To: <20190926075307.GB17200@linux> References: <20190926013406.16133-1-alastair@au1.ibm.com> <20190926013406.16133-2-alastair@au1.ibm.com> <20190926075307.GB17200@linux> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.32.4 (3.32.4-1.fc30) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Greylist: Sender succeeded SMTP AUTH, not delayed by milter-greylist-4.6.2 (mail2.nmnhosting.com [10.0.1.20]); Fri, 27 Sep 2019 15:14:22 +1000 (AEST) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 2019-09-26 at 09:53 +0200, Oscar Salvador wrote: > On Thu, Sep 26, 2019 at 11:34:05AM +1000, Alastair D'Silva wrote: > > From: Alastair D'Silva > > > > On PowerPC, the address ranges allocated to OpenCAPI LPC memory > > are allocated from firmware. These address ranges may be higher > > than what older kernels permit, as we increased the maximum > > permissable address in commit 4ffe713b7587 > > ("powerpc/mm: Increase the max addressable memory to 2PB"). It is > > possible that the addressable range may change again in the > > future. > > > > In this scenario, we end up with a bogus section returned from > > __section_nr (see the discussion on the thread "mm: Trigger bug on > > if a section is not found in __section_nr"). > > > > Adding a check here means that we fail early and have an > > opportunity to handle the error gracefully, rather than rumbling > > on and potentially accessing an incorrect section. > > > > Further discussion is also on the thread ("powerpc: Perform a > > bounds > > check in arch_add_memory") > > http://lkml.kernel.org/r/20190827052047.31547-1-alastair@au1.ibm.com > > > > Signed-off-by: Alastair D'Silva > > Reviewed-by: Oscar Salvador > > Just a nit-picking below: > > > --- > > mm/memory_hotplug.c | 20 ++++++++++++++++++++ > > 1 file changed, 20 insertions(+) > > > > diff --git a/mm/memory_hotplug.c b/mm/memory_hotplug.c > > index c73f09913165..212804c0f7f5 100644 > > --- a/mm/memory_hotplug.c > > +++ b/mm/memory_hotplug.c > > @@ -278,6 +278,22 @@ static int check_pfn_span(unsigned long pfn, > > unsigned long nr_pages, > > return 0; > > } > > > > +static int check_hotplug_memory_addressable(unsigned long pfn, > > + unsigned long nr_pages) > > +{ > > + unsigned long max_addr = ((pfn + nr_pages) << PAGE_SHIFT) - 1; > > I would use PFN_PHYS instead: > > unsigned long max_addr = PFN_PHYS(pfn + nr_pages) - 1; > > > + > > + if (max_addr >> MAX_PHYSMEM_BITS) { > > + WARN(1, > > + "Hotplugged memory exceeds maximum addressable > > address, range=%#lx-%#lx, maximum=%#lx\n", > > + pfn << PAGE_SHIFT, max_addr, > > Same here. > > > + (1ul << (MAX_PHYSMEM_BITS + 1)) - 1); > > I would use a local variable to hold this computation. > > > + return -E2BIG; > > + } > > + > > + return 0; Looks like I'll have to do another spin to change that to a ull anyway, so I'll implement those suggestions. -- Alastair D'Silva mob: 0423 762 819 skype: alastair_dsilva Twitter: @EvilDeece blog: http://alastair.d-silva.org