Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp104208imu; Wed, 21 Nov 2018 16:13:19 -0800 (PST) X-Google-Smtp-Source: AJdET5fSedmvUTe/QZCa3BnJt/68AkT8PCFvz1zj8bRgznQ/c65INwOzwOP3375V1lDJV6KG7Q9Z X-Received: by 2002:a62:7504:: with SMTP id q4mr8892199pfc.180.1542845599263; Wed, 21 Nov 2018 16:13:19 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542845599; cv=none; d=google.com; s=arc-20160816; b=ZEz8knwdbBLmYdZlctEoFbgDG75vZZ8p1msnoSnipQswxgt1CX8eDFjABoV9WOxlD+ l8qMnk6360/L14/XRbnHnuL8h2oIWZmtAg0W03oxPrfCNOz3dRB9j2YJoM9x069vvEnJ Crox2Vl/N7UGfkrhfzO7iY1QyfdKfdqccKeVDuhF1xUfqDOEblUKkP/pBpTP8iwTFnU8 n11HT6pXC29jYiu7fuZ1NsB9zGO+AU1dlDsI2S+WIJVLBYtIEaAXjRQnZjUFFHG2A/V9 h+FHYqeZyiNJpYYIL++bPVasCJBo/3bSHX1Bma6WlRT97QAV1S7ktVyW0ctg0ZI0lWxc +6gQ== 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=/kqEcGdSq5m9WtmXrzgRSllubTZFUFHaR5Ngak7V1Ps=; b=xaWIsz6wM7Yi+c3u6ZASATbka9UvGzAa9awSg53yhXzWIAG/8xw2ior13dEj/WiMPB ZmWlEX0yvabD9OSXXX7UrI0N5Veb5RhnBFUvkmPvSHvfkHcn4yNOxNc9CuQBfUzheRFx e/U5rfCnL7NELdHPbaB4q2VTd48Pv0JIUitSMiCoyGH3zRcUkci4EXk9xKTiyMxa/HHp xgJZJ2tGZfua6Fnnysd5AUZyBp1v6rAZPGqAjKUxw2HZn+ovNQcxrnRIl2NYbncC5e2d NS4V0MnHREjgQCwzbxIfGUvpFpm6vHlxQq9ySd3GmjxrT7Xb4IT36N7alS94qOxS+37r yUQQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=OfV2zS3B; 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 s84si30973935pgs.306.2018.11.21.16.13.04; Wed, 21 Nov 2018 16:13:19 -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=OfV2zS3B; 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 S2388460AbeKVFpF (ORCPT + 99 others); Thu, 22 Nov 2018 00:45:05 -0500 Received: from mail.kernel.org ([198.145.29.99]:39788 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730870AbeKVFpE (ORCPT ); Thu, 22 Nov 2018 00:45:04 -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 810CF206BB; Wed, 21 Nov 2018 19:09:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542827372; bh=86hevK6/n3zvLlSkKYo1XhyqQyqoT2UHNyzneMinCrU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=OfV2zS3BcLmYG0+CR28QOXr3iwrgN19O8Y6N9KTwVXy6Gybvm6VAUurXT7ggnegzY UahYgkUKDEoFadx6x9e2/pjV56I/YZuJppDFvhL7xdN6wmVinNZ8GQTva30wTj4GRn 4AhCchcLnGfLiNh50V11PKQ1wN4CTxYqIHP9mcrc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Ying Xu , Xin Long , "David S. Miller" Subject: [PATCH 4.14 06/21] sctp: not allow to set asoc prsctp_enable by sockopt Date: Wed, 21 Nov 2018 20:06:50 +0100 Message-Id: <20181121183422.353248315@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181121183422.103826775@linuxfoundation.org> References: <20181121183422.103826775@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review 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.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Xin Long [ Upstream commit cc3ccf26f0649089b3a34a2781977755ea36e72c ] As rfc7496#section4.5 says about SCTP_PR_SUPPORTED: This socket option allows the enabling or disabling of the negotiation of PR-SCTP support for future associations. For existing associations, it allows one to query whether or not PR-SCTP support was negotiated on a particular association. It means only sctp sock's prsctp_enable can be set. Note that for the limitation of SCTP_{CURRENT|ALL}_ASSOC, we will add it when introducing SCTP_{FUTURE|CURRENT|ALL}_ASSOC for linux sctp in another patchset. v1->v2: - drop the params.assoc_id check as Neil suggested. Fixes: 28aa4c26fce2 ("sctp: add SCTP_PR_SUPPORTED on sctp sockopt") Reported-by: Ying Xu Signed-off-by: Xin Long Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- net/sctp/socket.c | 26 +++++--------------------- 1 file changed, 5 insertions(+), 21 deletions(-) --- a/net/sctp/socket.c +++ b/net/sctp/socket.c @@ -3750,32 +3750,16 @@ static int sctp_setsockopt_pr_supported( unsigned int optlen) { struct sctp_assoc_value params; - struct sctp_association *asoc; - int retval = -EINVAL; if (optlen != sizeof(params)) - goto out; + return -EINVAL; - if (copy_from_user(¶ms, optval, optlen)) { - retval = -EFAULT; - goto out; - } + if (copy_from_user(¶ms, optval, optlen)) + return -EFAULT; - asoc = sctp_id2assoc(sk, params.assoc_id); - if (asoc) { - asoc->prsctp_enable = !!params.assoc_value; - } else if (!params.assoc_id) { - struct sctp_sock *sp = sctp_sk(sk); + sctp_sk(sk)->ep->prsctp_enable = !!params.assoc_value; - sp->ep->prsctp_enable = !!params.assoc_value; - } else { - goto out; - } - - retval = 0; - -out: - return retval; + return 0; } static int sctp_setsockopt_default_prinfo(struct sock *sk,