Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp627981imu; Fri, 11 Jan 2019 06:26:45 -0800 (PST) X-Google-Smtp-Source: ALg8bN5F000jZbs+4Ad53LCL7enQlGgEoa2RNjs9UdfX/RjB7qlck/CFR/tYZ3BC/mIFQ8ONZiUm X-Received: by 2002:a62:e704:: with SMTP id s4mr14981409pfh.124.1547216805017; Fri, 11 Jan 2019 06:26:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547216804; cv=none; d=google.com; s=arc-20160816; b=HrR1v862txLTsuW+yNygEj3vhpmbWugv0MQp0p2XPToAncZ2DgF8zXZ6QnnEX80aqu v44+CKZkCi+3FORs/30QCgCseoL8uoxLzxrXNREP+U5AetXdWAlQXfgG+a0L1gtlh4KU GCrR4P2uK2KTnXIl+dQpby27kffVTSqLpgGfpFzmhavb/ieFmxRGJFzCZI7ZMxrtyU1q qFgN28IPIX1oqSYTpk8ea/RFbwD+IiCgbmogDn6nWkPxXMCABAa3fXh2zIo2Ck1SujOq wu3WsjhYBlzUpKvgrKzWDwRJhq0x4SHxBp4MZLphAF/EBFz3wmWiOSDsPi0g4ftEyN1D 0FBg== 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=zThqVgCpV2LsFA6KMr+ZwHYNZO6LTStxHTwFEE5rUgw=; b=WqRSYNLvnuZM0/qmgVu8pVnPklKnvFkorbweQMSInezviIIxm63rRRWTwXw0EQJ8Md 4zatgV294FJXNjDeP726aoV+x/TWI3aqupD4Ld32T2IdbvQmC4cCp9uUFP5CMJaIzr/I U5Iw/UytNWasZulqDnHxeD5o/3OynUEalNdjayIk0LXm0L6PaY845/4xK9i5I68mx28P oYB/16AGvOR9iVDbaWLalEqcKQ2Ii7Pe95nN+pyjod9dWku3bUzcH8wckxixAY9u6VSl 9o5dKf2Ia/WUWnnT4da+inPBfVACFn8T1YQxIeuUAPSHvM25sccfIzekwuhT0TB6En/1 niyA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=vb6LPGDc; 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 az5si53795091plb.166.2019.01.11.06.26.30; Fri, 11 Jan 2019 06:26:44 -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=vb6LPGDc; 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 S1732499AbfAKOT4 (ORCPT + 99 others); Fri, 11 Jan 2019 09:19:56 -0500 Received: from mail.kernel.org ([198.145.29.99]:37214 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732678AbfAKOTx (ORCPT ); Fri, 11 Jan 2019 09:19:53 -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 5E0EB2177B; Fri, 11 Jan 2019 14:19:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1547216392; bh=eCuwpNxM+JABMsLeSt/OxES9JeKY98ItEDe4IASjESs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=vb6LPGDc2fSqx37xIDSwcsnepz17zs1rr8oxbw79gTJPPgIbOkm8poHmPOBVWcq4x rRqzh0+PjfdI7SJ1Y2f3Oa+6oJTkc/RulEhtqEyPwxw6sgMp/JuPQcF1UrZgg9hQwk bAD/pqgMwTvrLTmNsnZK89FvCEgQryodq11g5PJY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, syzbot+0c1d61e4db7db94102ca@syzkaller.appspotmail.com, Dominique Martinet , Eric Van Hensbergen , Latchesar Ionkov Subject: [PATCH 4.4 82/88] 9p/net: put a lower bound on msize Date: Fri, 11 Jan 2019 15:08:51 +0100 Message-Id: <20190111131059.438585109@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190111131045.137499039@linuxfoundation.org> References: <20190111131045.137499039@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.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Dominique Martinet commit 574d356b7a02c7e1b01a1d9cba8a26b3c2888f45 upstream. If the requested msize is too small (either from command line argument or from the server version reply), we won't get any work done. If it's *really* too small, nothing will work, and this got caught by syzbot recently (on a new kmem_cache_create_usercopy() call) Just set a minimum msize to 4k in both code paths, until someone complains they have a use-case for a smaller msize. We need to check in both mount option and server reply individually because the msize for the first version request would be unchecked with just a global check on clnt->msize. Link: http://lkml.kernel.org/r/1541407968-31350-1-git-send-email-asmadeus@codewreck.org Reported-by: syzbot+0c1d61e4db7db94102ca@syzkaller.appspotmail.com Signed-off-by: Dominique Martinet Cc: Eric Van Hensbergen Cc: Latchesar Ionkov Cc: stable@vger.kernel.org Signed-off-by: Greg Kroah-Hartman --- net/9p/client.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) --- a/net/9p/client.c +++ b/net/9p/client.c @@ -156,6 +156,12 @@ static int parse_opts(char *opts, struct ret = r; continue; } + if (option < 4096) { + p9_debug(P9_DEBUG_ERROR, + "msize should be at least 4k\n"); + ret = -EINVAL; + continue; + } clnt->msize = option; break; case Opt_trans: @@ -972,10 +978,18 @@ static int p9_client_version(struct p9_c else if (!strncmp(version, "9P2000", 6)) c->proto_version = p9_proto_legacy; else { + p9_debug(P9_DEBUG_ERROR, + "server returned an unknown version: %s\n", version); err = -EREMOTEIO; goto error; } + if (msize < 4096) { + p9_debug(P9_DEBUG_ERROR, + "server returned a msize < 4096: %d\n", msize); + err = -EREMOTEIO; + goto error; + } if (msize < c->msize) c->msize = msize; @@ -1040,6 +1054,13 @@ struct p9_client *p9_client_create(const if (clnt->msize > clnt->trans_mod->maxsize) clnt->msize = clnt->trans_mod->maxsize; + if (clnt->msize < 4096) { + p9_debug(P9_DEBUG_ERROR, + "Please specify a msize of at least 4k\n"); + err = -EINVAL; + goto free_client; + } + err = p9_client_version(clnt); if (err) goto close_trans;