Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp319943pxb; Mon, 16 Aug 2021 06:15:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyzVNC37C/D3x5tYFUJNbZdY57mjFALL+7MVQycCnuWVSQqy4dHNpqqOBG6u0lrmoLjg/E5 X-Received: by 2002:a05:600c:214f:: with SMTP id v15mr9527689wml.132.1629119710948; Mon, 16 Aug 2021 06:15:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629119710; cv=none; d=google.com; s=arc-20160816; b=lCwgTcBhW9SQabA6eRW2Mj2WQGzG+oacNdglwpcHgz2oYTkLXgaOXvD2oS5aNA/gPd VsOilzo/f89Gd3nxm90Q8xjY+n4TIbKjXIGAljqP/L8Bx577I5Ckg06HrHnAgUvklVmo KhGltqUydtZXVpBlKVNRjVN05XSqSB7tdskal5FWUMCUclqx8iC+1rvxdHAYTmwKUXcN AuinSddW3WI7ZLrwFSEtPiUmXVuYrTiC0M2L9zmuNrmA9Tm6WE7W3dD29uyQi5CNdSS+ q3ov6V+HRrBbxlNqpOT/I6maaTncQb8Gkk57hRsiRDiMnC6Or13/PxOl1nBtazYjwlyE pXxw== 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=RjEqtJCfQO8pN7QEmd8M2FDGggnVD3Iez1Ix1RsytkA=; b=oFFG4rdYseRATsNbfRExRDlND1jhtjOtyIilo2qkdbelw7d64q8bdnIcF7sC0vTwdp tljmRTa8fx/UxCokRlG3cSUf1uOoqTNq3v1slkF9nJWTYM/Om2Xvqc2V/ZNp+nYG6iUh UHnyDujp+HHyapCVE8xxuJ/P1JmgY1DkD0L0Ut61GX4r7/LFGXa4+q4zr4tTmdxHUGJm zN63h6QQavgsWc+8oAcIranRBHaj/l5RM2NiknPrUc2/ssTdIHpHdwyNZ8vG0cNBWB47 5cdhAHg3tu7kV2iU3IbTV7OAhhpyjEWyTgfbxdqiTwPY06Sg+z8hMtN+i5JixAy7qUlI PzQA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="k/Sxqfm0"; 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 u14si10740197ejy.78.2021.08.16.06.14.47; Mon, 16 Aug 2021 06:15:10 -0700 (PDT) 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="k/Sxqfm0"; 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 S238011AbhHPNM6 (ORCPT + 99 others); Mon, 16 Aug 2021 09:12:58 -0400 Received: from mail.kernel.org ([198.145.29.99]:58932 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239012AbhHPNJB (ORCPT ); Mon, 16 Aug 2021 09:09:01 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 66A7E632C3; Mon, 16 Aug 2021 13:07:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1629119255; bh=V/WhJbzrPXjuDuEawFMTTqb+96dWQ+sePGwyMm4HOfA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=k/Sxqfm00CW/+PQ2R+fELVznDdXFA0DSq3BTbnHdCLkAtyzln8G6OzqTK/lGkteAt wsaPa7Ha56e/Khrlk7ctMhh5Fd/KhEinAoMa6Kwe88becaUtOVkcC9YVy+5+fqlW7q IV3QmxPQOfJ0IQGfuGJnFW/uJlyIHEzEKMATQY10= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Ben Hutchings , "David S. Miller" , Sasha Levin Subject: [PATCH 5.10 52/96] net: dsa: microchip: ksz8795: Fix VLAN filtering Date: Mon, 16 Aug 2021 15:02:02 +0200 Message-Id: <20210816125436.688497376@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210816125434.948010115@linuxfoundation.org> References: <20210816125434.948010115@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: Ben Hutchings [ Upstream commit 164844135a3f215d3018ee9d6875336beb942413 ] Currently ksz8_port_vlan_filtering() sets or clears the VLAN Enable hardware flag. That controls discarding of packets with a VID that has not been enabled for any port on the switch. Since it is a global flag, set the dsa_switch::vlan_filtering_is_global flag so that the DSA core understands this can't be controlled per port. When VLAN filtering is enabled, the switch should also discard packets with a VID that's not enabled on the ingress port. Set or clear each external port's VLAN Ingress Filter flag in ksz8_port_vlan_filtering() to make that happen. Fixes: e66f840c08a2 ("net: dsa: ksz: Add Microchip KSZ8795 DSA driver") Signed-off-by: Ben Hutchings Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/dsa/microchip/ksz8795.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/drivers/net/dsa/microchip/ksz8795.c b/drivers/net/dsa/microchip/ksz8795.c index 1e101ab56cea..108a14db1f1a 100644 --- a/drivers/net/dsa/microchip/ksz8795.c +++ b/drivers/net/dsa/microchip/ksz8795.c @@ -790,8 +790,14 @@ static int ksz8795_port_vlan_filtering(struct dsa_switch *ds, int port, if (switchdev_trans_ph_prepare(trans)) return 0; + /* Discard packets with VID not enabled on the switch */ ksz_cfg(dev, S_MIRROR_CTRL, SW_VLAN_ENABLE, flag); + /* Discard packets with VID not enabled on the ingress port */ + for (port = 0; port < dev->phy_port_cnt; ++port) + ksz_port_cfg(dev, port, REG_PORT_CTRL_2, PORT_INGRESS_FILTER, + flag); + return 0; } @@ -1266,6 +1272,11 @@ static int ksz8795_switch_init(struct ksz_device *dev) /* set the real number of ports */ dev->ds->num_ports = dev->port_cnt + 1; + /* VLAN filtering is partly controlled by the global VLAN + * Enable flag + */ + dev->ds->vlan_filtering_is_global = true; + return 0; } -- 2.30.2