Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2673292imj; Mon, 11 Feb 2019 06:50:21 -0800 (PST) X-Google-Smtp-Source: AHgI3IazAZuT2owNuURucGLJ/5PpGtQA9A6+0x1TF5+/uMAD/ubYGquDzSvHbAJubGkaJRByeh6V X-Received: by 2002:a63:b447:: with SMTP id n7mr6953390pgu.401.1549896621332; Mon, 11 Feb 2019 06:50:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549896621; cv=none; d=google.com; s=arc-20160816; b=ZuHcLdy8H3A0HOjY5iIFLUPdylCSJGmrHQqHed5a5m/Oo8TV4wQdzUJz6UkWIYgeET YqzmMoy0tary+vNaaK8iorOxYzF1Mr3FR8d8mejTbRLAsEGz7Q3pGzPhyKOGrtvYIAAX eiH2pENa0O+YC/pkBuo7oUB1KdY8Qe/8QU2l7t+fEJaWJZuyJXB9Jr4LZVj6TklhgN1u QAWYPsp7cBZPa47NSqrD53btJd2V+/HnJ6Mpw64Naf02uArMKGXtKu2rpHXKW3EYG5LP LOmF+eRaqHgQUK0fNBAYVYsNOZeUbfzAM2U13mHQ36a2Vqrag6fGUQNAVLrtggN4Wu+d G01A== 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:message-id:date:subject:cc:to :from:dkim-signature; bh=amTgX2+n3/KQHZYVXC9e9iczdCZW5EEjl7OUGvL37Qc=; b=bJaW0Kx55amCX/mIjXa1GypIdKlG6JiS1m5AmPXDKa2sragssVzN4B4hov8pixuiQR LFYGpREBZvSjCJAZskA6S/KbqbxIl/3mCzGFfpQYFQHCwSctARJ9nfx042HpdHdg4yze 4ph2BOvl83XwrjWbkWMKgSLHzEw0zR2djb76i9gHFEBV8T32jPqurYWB2wSJpH8yfBKe scSL+r/B1wju/Knig4uZXlSRhqZAoRR10IDgSi8sazR9aH4IRuozpKReDvusty1/YkNW cTtQ9F6877dNmRWRLfCSMvn52CGtSe/d7SumXlDtXv+wsF5f8QI4ESxAjgPIrV0svNyL eFHg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Rfzwrqrd; 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 t86si4308767pfa.145.2019.02.11.06.50.05; Mon, 11 Feb 2019 06:50:21 -0800 (PST) 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=@kernel.org header.s=default header.b=Rfzwrqrd; 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 S2387419AbfBKOtF (ORCPT + 99 others); Mon, 11 Feb 2019 09:49:05 -0500 Received: from mail.kernel.org ([198.145.29.99]:34476 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387796AbfBKOtD (ORCPT ); Mon, 11 Feb 2019 09:49:03 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id C8BC5206BA; Mon, 11 Feb 2019 14:49:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1549896542; bh=Lan0ibxyPhGyZx+bnKJmLF5sIxIHRuF8qbhGdc56KGw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Rfzwrqrduhe2299ieyhhJbZoKDR3CbMw8I/kQ6oCpEnVOCh8Kpwgh7b1DLpRcg5Uu dInU8Y2HogZPboys+Kl09Bqv0Vq+mxlZ+3qco8Cel1BnHrBIGgGyJ/sGtMEhC4+Q12 YIAwiuxWU5Tn/4zFx1qT2/RXtTzl5dntSAja6Yqc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Ronnie Sahlberg , Steve French , Sasha Levin Subject: [PATCH 4.19 217/313] cifs: check ntwrk_buf_start for NULL before dereferencing it Date: Mon, 11 Feb 2019 15:18:17 +0100 Message-Id: <20190211141907.637628904@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190211141852.749630980@linuxfoundation.org> References: <20190211141852.749630980@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 59a63e479ce36a3f24444c3a36efe82b78e4a8e0 ] RHBZ: 1021460 There is an issue where when multiple threads open/close the same directory ntwrk_buf_start might end up being NULL, causing the call to smbCalcSize later to oops with a NULL deref. The real bug is why this happens and why this can become NULL for an open cfile, which should not be allowed. This patch tries to avoid a oops until the time when we fix the underlying issue. Signed-off-by: Ronnie Sahlberg Signed-off-by: Steve French Signed-off-by: Sasha Levin --- fs/cifs/readdir.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/fs/cifs/readdir.c b/fs/cifs/readdir.c index e169e1a5fd35..3925a7bfc74d 100644 --- a/fs/cifs/readdir.c +++ b/fs/cifs/readdir.c @@ -655,7 +655,14 @@ find_cifs_entry(const unsigned int xid, struct cifs_tcon *tcon, loff_t pos, /* scan and find it */ int i; char *cur_ent; - char *end_of_smb = cfile->srch_inf.ntwrk_buf_start + + char *end_of_smb; + + if (cfile->srch_inf.ntwrk_buf_start == NULL) { + cifs_dbg(VFS, "ntwrk_buf_start is NULL during readdir\n"); + return -EIO; + } + + end_of_smb = cfile->srch_inf.ntwrk_buf_start + server->ops->calc_smb_size( cfile->srch_inf.ntwrk_buf_start, server); -- 2.19.1