Received: by 10.223.164.221 with SMTP id h29csp1758380wrb; Thu, 2 Nov 2017 00:00:05 -0700 (PDT) X-Google-Smtp-Source: ABhQp+TEMWLFSRwGFW3Zj4kj4fNWMqKDp1nHz1JFW8KrOeHFe/FDFuveUQVcg4OuKZn/w0Qqbh29 X-Received: by 10.98.87.207 with SMTP id i76mr2727453pfj.134.1509606005036; Thu, 02 Nov 2017 00:00:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1509606004; cv=none; d=google.com; s=arc-20160816; b=WuUX1nYsuVUW8do+HMqAWEvqUGvaPySsf3BkohNFsu2CDX1WTIyuYJbwB5yWYhleAm RDA3dceLzQiJuosObDtS9dgvC9Qds33Tm5nexg6Na1G34bv5JmpnR31v0XQLDVu/cIeQ qelZf/aPCaFc1VySsYcE45WYMOq9nZO7BZ0q96sghyc4ZDY8pHnQ5t1cRc1MnkplfgFa SKPIpBwwt5q8Npn3cMhmMmejoz0tG3DjhghAOWsnYEz8RgRuMpVKVpFgoZg3GmlRFiGq wM5a1vjO6ltouKCXsOsmh0Nqji9E4B4Mq5AlU1ykp44mRlrFVA1K3jBSBHRWvAp4vvaZ OCcw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:mime-version:user-agent:date :message-id:from:references:to:subject:arc-authentication-results; bh=RJH+UYrvG51O1jWcfUg409sGj8/LHbjpLJYptF2c6co=; b=elV+WQT8b8Y9yeEhlyDX1a/bu2MSkwpd+NBz5Voy80AU2GFyqGG8nj4TPgbSMpJSyO e0VAUezy3gauTcCXc8l/YfczNY+L9iyCnj8u1A3ExqzKk73MHHxtczdrtqufix5zOTLX pi8NoE6njBT4hhcmFqwkhGBDqiMzSPx56pSFzqqeRuyOIfSe9WlEg/FjMEjgMDB/Cu1U M0l48fjs5DSLCDtoOOvRBVY238H/srUh/8gQaMPVqAenmqkwhugUlpfsjPuYjEcAv4cb zpkhssoomEO9UKZ7t0xUHqjEVKyNWBDlBBuGmofel6SwJopprf1FsaXEQ8ubFDFqRMTX Dvmw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m27si2896777pgn.59.2017.11.01.23.59.51; Thu, 02 Nov 2017 00:00:04 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754513AbdKBG7P (ORCPT + 99 others); Thu, 2 Nov 2017 02:59:15 -0400 Received: from youngberry.canonical.com ([91.189.89.112]:54690 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750883AbdKBG7N (ORCPT ); Thu, 2 Nov 2017 02:59:13 -0400 Received: from mail-wm0-f70.google.com ([74.125.82.70]) by youngberry.canonical.com with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.76) (envelope-from ) id 1eA9T6-000330-Js for linux-kernel@vger.kernel.org; Thu, 02 Nov 2017 06:59:12 +0000 Received: by mail-wm0-f70.google.com with SMTP id e75so2403203wmi.22 for ; Wed, 01 Nov 2017 23:59:12 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to; bh=RJH+UYrvG51O1jWcfUg409sGj8/LHbjpLJYptF2c6co=; b=R+NqiecxUedhKdaWGtWAajXDF8SvMw2XhnBRT3SZlAEB1Kge8ezvcuUKlEqy9m66ni mXp+SOgECB1ShzjF9ZUY8lVUUuVCBfUXgikG2xnMJls/2YoUeiTzX0R5M6fErGCsCidM 8VE1qIUws4OOntp4p1FWtguXi6B2JlD+GkCTivd8i66SC56piRyqyE1RwPMJ6SU8qTdq sF/RxI5HWdovNHxmy3dr3w3IJK+KbGiEdTmjwVbzJ9tZuCEMj7+pEKhKoorlQjpEeAUn auMpaG2y4pSWSXKsLwvggQg3ry6vhXPU01KL7PqnGTyKi23n+Ykg/C1qQOVslcs67y+X KmkQ== X-Gm-Message-State: AMCzsaX5Tr3sGU2FUMpVEEDhGF/iyZLyCL6gfvQ4YBrpn8U7IZzhoG36 3GQMsccHgnAUa/6aaVc+cnZ6nPP/TNFtqYygxpPQV27HLw15wUq9EN/sbVFjkJsZHbcIx/vzLOv F7dACA1SX3LNFqpVPhEn8ss4ASCj2zzUeBIftqfMkjw== X-Received: by 10.80.163.228 with SMTP id t33mr3206241edb.248.1509605952085; Wed, 01 Nov 2017 23:59:12 -0700 (PDT) X-Received: by 10.80.163.228 with SMTP id t33mr3206232edb.248.1509605951886; Wed, 01 Nov 2017 23:59:11 -0700 (PDT) Received: from [192.168.1.99] (adsl-84-227-115-101.adslplus.ch. [84.227.115.101]) by smtp.gmail.com with ESMTPSA id p45sm2642595edc.30.2017.11.01.23.59.10 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 01 Nov 2017 23:59:11 -0700 (PDT) Subject: Re: [Jfs-discussion] [PATCH] jfs: Add missing NULL pointer check in __get_metapage To: Dave Kleikamp , jfs-discussion@lists.sourceforge.net, linux-kernel@vger.kernel.org References: <20171004082441.2405-1-juerg.haefliger@canonical.com> <1dbf4a54-968f-0ca7-da96-e262c653fecb@canonical.com> From: Juerg Haefliger Message-ID: <778bc3d1-4bf4-ed83-3cc3-19d6efb5cceb@canonical.com> Date: Thu, 2 Nov 2017 07:59:09 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.4.0 MIME-Version: 1.0 In-Reply-To: Content-Type: multipart/signed; micalg=pgp-sha256; protocol="application/pgp-signature"; boundary="spMKUtu6qeU420WaSXuXI6WIeTBJu5ej1" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is an OpenPGP/MIME signed message (RFC 4880 and 3156) --spMKUtu6qeU420WaSXuXI6WIeTBJu5ej1 Content-Type: multipart/mixed; boundary="LWfRjL3iqIQT1ebG5cu4PFg0bcalL6GMx"; protected-headers="v1" From: Juerg Haefliger To: Dave Kleikamp , jfs-discussion@lists.sourceforge.net, linux-kernel@vger.kernel.org Message-ID: <778bc3d1-4bf4-ed83-3cc3-19d6efb5cceb@canonical.com> Subject: Re: [Jfs-discussion] [PATCH] jfs: Add missing NULL pointer check in __get_metapage References: <20171004082441.2405-1-juerg.haefliger@canonical.com> <1dbf4a54-968f-0ca7-da96-e262c653fecb@canonical.com> In-Reply-To: --LWfRjL3iqIQT1ebG5cu4PFg0bcalL6GMx Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: quoted-printable On 10/30/2017 11:13 PM, Dave Kleikamp wrote: > On 10/25/2017 02:50 AM, Juerg Haefliger wrote: >> Is this a patch you might consider? >=20 > Sorry it's taken me so long to respond. >=20 > I don't think this is the right fix. A failed allocation will still > result in a null pointer dereference by the caller, __get_metapage(). I= > think the check needs to be put there. Like this: >=20 > --- a/fs/jfs/jfs_metapage.c > +++ b/fs/jfs/jfs_metapage.c > @@ -663,6 +663,8 @@ struct metapage *__get_metapage(struct inode *inode= , > unsigned long lblock, > } else { > INCREMENT(mpStat.pagealloc); > mp =3D alloc_metapage(GFP_NOFS); > + if (!mp) > + goto unlock; > mp->page =3D page; > mp->sb =3D inode->i_sb; > mp->flag =3D 0; I don't understand. This is part of the patch that I sent. >=20 > Furthermore, it looks like all the callers of __get_metapage() check fo= r > a null return, so I'm not sure we need to handle the error at this > point. I might have to look a bit harder at that, since there are many > callers. I don't understand this either :-) Yes, the callers do check for a null pointer but things blow up (in __get_metapage) before that check without the above fix. =2E..Juerg >=20 > Thanks, > Shaggy >=20 >> >> Thanks >> ...Juerg >> >> >> On 10/04/2017 10:24 AM, Juerg Haefliger wrote: >>> alloc_metapage can return a NULL pointer so check for that. And also = emit >>> an error message if that happens. >>> >>> Signed-off-by: Juerg Haefliger >>> --- >>> fs/jfs/jfs_metapage.c | 20 +++++++++++++------- >>> 1 file changed, 13 insertions(+), 7 deletions(-) >>> >>> diff --git a/fs/jfs/jfs_metapage.c b/fs/jfs/jfs_metapage.c >>> index 1c4b9ad4d7ab..00f21af66872 100644 >>> --- a/fs/jfs/jfs_metapage.c >>> +++ b/fs/jfs/jfs_metapage.c >>> @@ -187,14 +187,18 @@ static inline struct metapage *alloc_metapage(g= fp_t gfp_mask) >>> { >>> struct metapage *mp =3D mempool_alloc(metapage_mempool, gfp_mask); >>> =20 >>> - if (mp) { >>> - mp->lid =3D 0; >>> - mp->lsn =3D 0; >>> - mp->data =3D NULL; >>> - mp->clsn =3D 0; >>> - mp->log =3D NULL; >>> - init_waitqueue_head(&mp->wait); >>> + if (!mp) { >>> + jfs_err("mempool_alloc failed!\n"); >>> + return NULL; >>> } >>> + >>> + mp->lid =3D 0; >>> + mp->lsn =3D 0; >>> + mp->data =3D NULL; >>> + mp->clsn =3D 0; >>> + mp->log =3D NULL; >>> + init_waitqueue_head(&mp->wait); >>> + >>> return mp; >>> } >>> =20 >>> @@ -663,6 +667,8 @@ struct metapage *__get_metapage(struct inode *ino= de, unsigned long lblock, >>> } else { >>> INCREMENT(mpStat.pagealloc); >>> mp =3D alloc_metapage(GFP_NOFS); >>> + if (!mp) >>> + goto unlock; >>> mp->page =3D page; >>> mp->sb =3D inode->i_sb; >>> mp->flag =3D 0; >>> --LWfRjL3iqIQT1ebG5cu4PFg0bcalL6GMx-- --spMKUtu6qeU420WaSXuXI6WIeTBJu5ej1 Content-Type: application/pgp-signature; name="signature.asc" Content-Description: OpenPGP digital signature Content-Disposition: attachment; filename="signature.asc" -----BEGIN PGP SIGNATURE----- iQI7BAEBCAAlBQJZ+sI9HhxqdWVyZy5oYWVmbGlnZXJAY2Fub25pY2FsLmNvbQAK CRB1TDqW+fi0jMVgD/wOQQVeGi4AK5VgmDyIOJFMILf3ifAgOFTGDtIxZWFyf/fH 5V1yMkofSQL4KC+YbhXiBjKeElnVgZLQpQkaqI9qfaarGeZIdml6MWg7QVJrxo6Y qtrsttAiDFRePkAy11FTLvzwLGS31WmPGWXcHdGW7pL7h4SdqB0ylSoyEIgReFsh jYEt95zMwpC+n9EkTMWYkuFaJqr07WlHEDz2yVw7yIbmGbOS1mi09YL5HnWh8UZU fpIJKVw/UFKkcO2cVFJ1IZW2CGVZfboiNFoAMN2BmTr8aBv/Q7l9woOdlcRrKXZW l2Gas3uLsmOPri4LWQtKKJW4rG7Qpc3l/AVcJ8H6oDaVz5NYoDvQ3+j1C9HMJaoy eEihkJlFiqurxcRXA+p0xXB0WE8NtfY6sVIc/VGTEGOOH1fytlQjhNAjn1Xy4YWB aP1Nr/L32aCH2xwGwEvER4wnCSfOpdj94+3ZbGFUiB0+NHxIbui69cH00CEEwzkg qF4DXD1llbcvXZeTddqkZq3axPBRaaQPM9i7mKwbax9YgUKtBe45gHduD2A0icx2 P+iW5wcVnY93w4umYmOjrrb7Jq4NjWj1KcQm4r47YV0WxNW4seTZ2vfpZ9es41Z9 0m9Zs5sZs3KWY7EsGF5iuBuQkHVu+Alc91XOq6kJQprFrhJjllB3sMUbZ0MHMw== =k8UF -----END PGP SIGNATURE----- --spMKUtu6qeU420WaSXuXI6WIeTBJu5ej1-- From 1582724118592429827@xxx Mon Oct 30 22:42:21 +0000 2017 X-GM-THRID: 1580314796840603396 X-Gmail-Labels: Inbox,Category Forums