From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-13.6 required=3.0 tests=BAYES_00,DKIM_INVALID, DKIM_SIGNED,FAKE_REPLY_C,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED, USER_AGENT_SANE_1 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id E1AADC4361B for ; Sat, 19 Dec 2020 17:51:56 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 32B482388E for ; Sat, 19 Dec 2020 17:51:55 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 32B482388E Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=roeck-us.net Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 321C76B005C; Sat, 19 Dec 2020 12:51:55 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 2ABF66B005D; Sat, 19 Dec 2020 12:51:55 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 19AD86B0068; Sat, 19 Dec 2020 12:51:55 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0182.hostedemail.com [216.40.44.182]) by kanga.kvack.org (Postfix) with ESMTP id F38516B005C for ; Sat, 19 Dec 2020 12:51:54 -0500 (EST) Received: from smtpin01.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay01.hostedemail.com (Postfix) with ESMTP id B8EFC180AD83B for ; Sat, 19 Dec 2020 17:51:54 +0000 (UTC) X-FDA: 77610774948.01.loss18_5b1693127448 Received: from filter.hostedemail.com (10.5.16.251.rfc1918.com [10.5.16.251]) by smtpin01.hostedemail.com (Postfix) with ESMTP id 8FAB810056552 for ; Sat, 19 Dec 2020 17:51:54 +0000 (UTC) X-HE-Tag: loss18_5b1693127448 X-Filterd-Recvd-Size: 4203 Received: from mail-oi1-f173.google.com (mail-oi1-f173.google.com [209.85.167.173]) by imf38.hostedemail.com (Postfix) with ESMTP for ; Sat, 19 Dec 2020 17:51:54 +0000 (UTC) Received: by mail-oi1-f173.google.com with SMTP id w124so6704151oia.6 for ; Sat, 19 Dec 2020 09:51:53 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:date:from:to:cc:subject:message-id:mime-version :content-disposition:user-agent; bh=Bi9+8PWR8xRsIKhCEM2h2bE5clfk/H11A/Yp12L9OEg=; b=jUN8UuEPAlu4QHUtm9xoZZ67pzyNPhGzGpDj2V6xRqEC6O3ZlaBmHGUCQsTr1uRQau pz6EmwkOmdmXM9uyX//H+T5MK/0+g6LEmbX80m1GomCWr7koxLQ2kONoZ38tPc4X2GHS COdJrIG2ti9YGjuHKFlEuSQaPIRWZoit2fHnA8zaIqwmEU1WL+a7iFCFoKl5tua3q7dJ X7G4c5FFcTEF5XSQa6YDMnRt/hGFrzvyFO00Bp+xF1zq9KBl2HCg5cBeaz+6v4qM26RE 3S4bDPBbQmvnLngkpt60QJFcAwRcfJS8L60PcJDex2ycz+7l29Lk6Wc1eNB4PPzbKFvE h+zg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :mime-version:content-disposition:user-agent; bh=Bi9+8PWR8xRsIKhCEM2h2bE5clfk/H11A/Yp12L9OEg=; b=SrhF5/+ftk03FH8NpO8JqIH/v7HsnpjhZt+6jYJYWxbB0w1P3ztRvmT4HOR1PJboJO GchVAt2t/VfPYFsVWTjnz+46/Ono/+1Ipenc8naqkwuy6PqsMa071R8vz8oOMOE1fuO7 Fu68Bp6I1lBux/+spvVqO8aJwG1I+GBADHEf6rVCIL0MkfN0X4B1oOIW7Y2byvDodHmU HNejOrdHjMTolljxllOmE4lnaXrwqk6Rnqr67b0NMzrq9Yziyur44WO20eLqBXOpZ4Db G5vEH2GVhXTyyGsejEBh/VXS6uE9X9kUc7qZaIBVPVzKEoGGx+kTjXWK4dXzwTnTmGXi p6Fg== X-Gm-Message-State: AOAM533KQI4zbw+DxfoGUOvpp7mXgeRBDxSDDSdN1G2/zDQth3H3PwWx zly07W2CEc5gf1zdxQtGtq8= X-Google-Smtp-Source: ABdhPJzl302HbXKhes494AXjy7KLvhTnVIsw6QClQhMrOYYsnFCPU+SnUD4zmIduRPFM3liguu82tw== X-Received: by 2002:a54:4787:: with SMTP id o7mr6496342oic.113.1608400313506; Sat, 19 Dec 2020 09:51:53 -0800 (PST) Received: from localhost ([2600:1700:e321:62f0:329c:23ff:fee3:9d7c]) by smtp.gmail.com with ESMTPSA id r15sm2498257oie.33.2020.12.19.09.51.52 (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Sat, 19 Dec 2020 09:51:52 -0800 (PST) Date: Sat, 19 Dec 2020 09:51:51 -0800 From: Guenter Roeck To: Kalesh Singh Cc: surenb@google.com, minchan@kernel.org, joelaf@google.com, lokeshgidra@google.com, kernel-team@android.com, Andrew Morton , linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mm: mremap - Fix extent calculation Message-ID: <20201219175151.GA6542@roeck-us.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.9.4 (2018-02-28) X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: On Sat, Dec 19, 2020 at 05:04:33PM +0000, Kalesh Singh wrote: > When `next < old_addr`, `next - old_addr` arithmetic underflows > causing `extent` to be incorrect. > > Make `extent` the smaller of `next - old_addr` or `old_end - old_addr`. > > Reported-by: Guenter Roeck > Signed-off-by: Kalesh Singh This patch fixes the problem I had observed when booting 'parisc' images. Tested-by: Guenter Roeck Guenter > --- > mm/mremap.c | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/mm/mremap.c b/mm/mremap.c > index c5590afe7165..f554320281cc 100644 > --- a/mm/mremap.c > +++ b/mm/mremap.c > @@ -358,7 +358,9 @@ static unsigned long get_extent(enum pgt_entry entry, unsigned long old_addr, > > next = (old_addr + size) & mask; > /* even if next overflowed, extent below will be ok */ > - extent = (next > old_end) ? old_end - old_addr : next - old_addr; > + extent = next - old_addr; > + if (extent > old_end - old_addr) > + extent = old_end - old_addr; > next = (new_addr + size) & mask; > if (extent > next - new_addr) > extent = next - new_addr; > -- > 2.29.2.729.g45daf8777d-goog >