Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1973937pxb; Fri, 5 Mar 2021 04:31:48 -0800 (PST) X-Google-Smtp-Source: ABdhPJzJhaWeUvZF7xdv461yImEJIkhnnHHogOqQEqhkVW/FaMT+fqcm/rb3CacstGPNJz8+IkOF X-Received: by 2002:aa7:d492:: with SMTP id b18mr8759962edr.381.1614947507935; Fri, 05 Mar 2021 04:31:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614947507; cv=none; d=google.com; s=arc-20160816; b=Gz7VKm6efrAnHuAvhnGUEqqPDYuxjI/makpNtkjWRAQ5MxzQXcm6V54jPM6vUpSkCZ +B6nd2TM7bgjFBJz/mv15Doph/gb3+e83sDFRaZqQNIbEua8truBHR9Z8SN/iqfGPWb4 OetzvAMc3jG08fbKEhIHWq1Jy+7ICcmgI565lLaEIQdo+B6HOMtolsTdy/XQGr3mOgkq O5QjVzBmj88xY2+G8q+Yf/Pyo1wCb67YyO9I7YhwauKvPuJUcB2cB3tx1gVo4BYvVely zuLWsdbmxeApKL7prDQ/PPQmLeB5Kqg/MFWCUriwNOF1pn8d7oMelFpfMIWOmdGOjTWd sUEw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=bVHpUnWSG+Jz6auNq0RZMuzccHzBj7KjsgQ5qS9C/3g=; b=e+hfNbo79bs1A3mUfE4Wppvai9APkprC7GgGRDJGaVLFFpVV43wW5kxgkLZCJjBlK7 MmAke02n49gSyFGJF6WJJLJt6RmSKf3XT8R666lpaxikVHBt5lRFO5AU66jlJBO0c99F U5Dz36wzvHGQUx+EwU4jKPQZICPVR8bbfyftDy1MfaCE1HJetzKq+ZNLt+tMn/N6zTeG gFkwgeLqs0PHVnP16c5/dRc83sdm6/+j/p3IjJl+G1WVta6YUYEa4+b8nzWyHrWQCewp taN26urrXWT/zeNnlyWOWP+NCrNjp4P9T6yBB7f3bDHxyK5URGjzaLvxntnBFK+udUJ2 VYew== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=mDWYwH7N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l14si1270025eji.711.2021.03.05.04.31.24; Fri, 05 Mar 2021 04:31:47 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=mDWYwH7N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232122AbhCEM3M (ORCPT + 99 others); Fri, 5 Mar 2021 07:29:12 -0500 Received: from mail.kernel.org ([198.145.29.99]:37644 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232030AbhCEM2s (ORCPT ); Fri, 5 Mar 2021 07:28:48 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id CA04A65019; Fri, 5 Mar 2021 12:28:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1614947327; bh=9Rkd35JWqDdnI/d/KvbRUpgIk0pHtpga6C2IoiqExHg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=mDWYwH7NuebgTGgGcDQ/g2vLD7CLj1dMJJvF6svys6xYH/EIYFZ9NFsn0GpGPxCu+ 4QByPM9J36dy1go0hLap9tlsoEISZwO8whkQz7AMsBx33u0fR/91/sRo7FfARD9jCP 6XcqX8nU6uLQEa0Rtht5XR20st6KMs2Gc67vGNGo= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, wenxu , Marcelo Ricardo Leitner , Jakub Kicinski , "David S. Miller" Subject: [PATCH 5.10 026/102] net/sched: cls_flower: Reject invalid ct_state flags rules Date: Fri, 5 Mar 2021 13:20:45 +0100 Message-Id: <20210305120904.565063218@linuxfoundation.org> X-Mailer: git-send-email 2.30.1 In-Reply-To: <20210305120903.276489876@linuxfoundation.org> References: <20210305120903.276489876@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: wenxu commit 1bcc51ac0731aab1b109b2cd5c3d495f1884e5ca upstream. Reject the unsupported and invalid ct_state flags of cls flower rules. Fixes: e0ace68af2ac ("net/sched: cls_flower: Add matching on conntrack info") Signed-off-by: wenxu Reviewed-by: Marcelo Ricardo Leitner Reviewed-by: Jakub Kicinski Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- include/uapi/linux/pkt_cls.h | 2 ++ net/sched/cls_flower.c | 39 +++++++++++++++++++++++++++++++++++++-- 2 files changed, 39 insertions(+), 2 deletions(-) --- a/include/uapi/linux/pkt_cls.h +++ b/include/uapi/linux/pkt_cls.h @@ -591,6 +591,8 @@ enum { TCA_FLOWER_KEY_CT_FLAGS_ESTABLISHED = 1 << 1, /* Part of an existing connection. */ TCA_FLOWER_KEY_CT_FLAGS_RELATED = 1 << 2, /* Related to an established connection. */ TCA_FLOWER_KEY_CT_FLAGS_TRACKED = 1 << 3, /* Conntrack has occurred. */ + + __TCA_FLOWER_KEY_CT_FLAGS_MAX, }; enum { --- a/net/sched/cls_flower.c +++ b/net/sched/cls_flower.c @@ -30,6 +30,11 @@ #include +#define TCA_FLOWER_KEY_CT_FLAGS_MAX \ + ((__TCA_FLOWER_KEY_CT_FLAGS_MAX - 1) << 1) +#define TCA_FLOWER_KEY_CT_FLAGS_MASK \ + (TCA_FLOWER_KEY_CT_FLAGS_MAX - 1) + struct fl_flow_key { struct flow_dissector_key_meta meta; struct flow_dissector_key_control control; @@ -686,8 +691,10 @@ static const struct nla_policy fl_policy [TCA_FLOWER_KEY_ENC_IP_TTL_MASK] = { .type = NLA_U8 }, [TCA_FLOWER_KEY_ENC_OPTS] = { .type = NLA_NESTED }, [TCA_FLOWER_KEY_ENC_OPTS_MASK] = { .type = NLA_NESTED }, - [TCA_FLOWER_KEY_CT_STATE] = { .type = NLA_U16 }, - [TCA_FLOWER_KEY_CT_STATE_MASK] = { .type = NLA_U16 }, + [TCA_FLOWER_KEY_CT_STATE] = + NLA_POLICY_MASK(NLA_U16, TCA_FLOWER_KEY_CT_FLAGS_MASK), + [TCA_FLOWER_KEY_CT_STATE_MASK] = + NLA_POLICY_MASK(NLA_U16, TCA_FLOWER_KEY_CT_FLAGS_MASK), [TCA_FLOWER_KEY_CT_ZONE] = { .type = NLA_U16 }, [TCA_FLOWER_KEY_CT_ZONE_MASK] = { .type = NLA_U16 }, [TCA_FLOWER_KEY_CT_MARK] = { .type = NLA_U32 }, @@ -1390,12 +1397,33 @@ static int fl_set_enc_opt(struct nlattr return 0; } +static int fl_validate_ct_state(u16 state, struct nlattr *tb, + struct netlink_ext_ack *extack) +{ + if (state && !(state & TCA_FLOWER_KEY_CT_FLAGS_TRACKED)) { + NL_SET_ERR_MSG_ATTR(extack, tb, + "no trk, so no other flag can be set"); + return -EINVAL; + } + + if (state & TCA_FLOWER_KEY_CT_FLAGS_NEW && + state & TCA_FLOWER_KEY_CT_FLAGS_ESTABLISHED) { + NL_SET_ERR_MSG_ATTR(extack, tb, + "new and est are mutually exclusive"); + return -EINVAL; + } + + return 0; +} + static int fl_set_key_ct(struct nlattr **tb, struct flow_dissector_key_ct *key, struct flow_dissector_key_ct *mask, struct netlink_ext_ack *extack) { if (tb[TCA_FLOWER_KEY_CT_STATE]) { + int err; + if (!IS_ENABLED(CONFIG_NF_CONNTRACK)) { NL_SET_ERR_MSG(extack, "Conntrack isn't enabled"); return -EOPNOTSUPP; @@ -1403,6 +1431,13 @@ static int fl_set_key_ct(struct nlattr * fl_set_key_val(tb, &key->ct_state, TCA_FLOWER_KEY_CT_STATE, &mask->ct_state, TCA_FLOWER_KEY_CT_STATE_MASK, sizeof(key->ct_state)); + + err = fl_validate_ct_state(mask->ct_state, + tb[TCA_FLOWER_KEY_CT_STATE_MASK], + extack); + if (err) + return err; + } if (tb[TCA_FLOWER_KEY_CT_ZONE]) { if (!IS_ENABLED(CONFIG_NF_CONNTRACK_ZONES)) {