Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp2175819ybg; Fri, 5 Jun 2020 07:27:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJylLK8XysceORUCPMf/x9ErmMaahjUKdnGuwFFyNdxwvSI1slHgH0xU2w5cSQKiMi6VxVDc X-Received: by 2002:a17:906:d1c5:: with SMTP id bs5mr9155093ejb.117.1591367252877; Fri, 05 Jun 2020 07:27:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591367252; cv=none; d=google.com; s=arc-20160816; b=YXCBk9+BdLGjRewdpBvspYw+QLskjxzW0oTL2WnBXtnpUtOyMxaFMvdb/YSDlqMcrq 84Mytm9NNCYOIJ095dz3d4Stre2sm4RrAPY1Lq4gRKYKFrJkxbQrV/AEHclvovHd/DlY XjT6Ns5154FuNjqdqqFde+kKwhtBDRxyWyTnxyEQyHrwdjWK8BNtpdpGeW3qUEuQsThV 8uRdfF4DnUTzPpRayHkjMXuPWeyE537fuBzOdQojPrYgRP1KdM/ooKPr1mYHpYfDZCmk /Zhp4B8uG5uJoL4hnFMgCWef+zGI1DF/db37Deh8E/H2W4loOgl7OvasIx9ifbr01BxK lfYg== 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=kQLHZAq20S36IBS8Ja39HMBxaIRgiyrp3lORmljEm7E=; b=RG8mH1G6UqltchWyu7cN43XUO8dFD2wvFUevriWq3rI18CPy1JF11WVro3PXqUCTOB iMzzHW8mvyn1qDy/WjcrTp/1X58ol9Bz7AvcmFmAukgAYiMsBuyAZ7CiT0X1pQkYS3rL AuJ/YwzP5bMA34Wy8nAU+PC8r0tMqqDqP4NgljrCPh4kmfYlMoLG6Culw1WgqJ/MMhPU jZAz2RIM9T9ijSjd55Ci+rkytJ/Sfeld5Pm4rcFUKRuuVEyk13/jMdiOTefZseKnDCc4 x84JoXe7U2pQiXimLPvVK1OuQj7CnXSqKKGej+sb+eThUE7IQUGYwCT/QTG1GEEEhmYQ cZ7g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=drN2a3kR; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f1si3806961edl.533.2020.06.05.07.27.09; Fri, 05 Jun 2020 07:27:32 -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=@kernel.org header.s=default header.b=drN2a3kR; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728025AbgFEOSE (ORCPT + 99 others); Fri, 5 Jun 2020 10:18:04 -0400 Received: from mail.kernel.org ([198.145.29.99]:48180 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727097AbgFEORw (ORCPT ); Fri, 5 Jun 2020 10:17:52 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.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 EAB57208A9; Fri, 5 Jun 2020 14:17:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1591366671; bh=kT9GL7Y6XK75ZPRKJrNeL+EQ+QvF63CVbQb4WwFxR88=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=drN2a3kRLE5CDemz5FkZUvWyqP8s59BWwZmMyaHYMuYn1op8M40q6Vf8Vz3UdtHD5 so21tL2N3A+2ykAFLqrR+t5r8wDslLP43lcqJRU2DVG3IGtZeRdMpj+lXoY3s5oL/R Qq1wyrQvil0uCBlhHkpya+HwG3WA6nq+pIr94I6E= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, DENG Qingfang , Florian Fainelli , "David S. Miller" Subject: [PATCH 5.6 42/43] net: dsa: mt7530: set CPU port to fallback mode Date: Fri, 5 Jun 2020 16:15:12 +0200 Message-Id: <20200605140154.731458967@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200605140152.493743366@linuxfoundation.org> References: <20200605140152.493743366@linuxfoundation.org> User-Agent: quilt/0.66 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 From: DENG Qingfang commit 38152ea37d8bdaffa22603e0a5b5b86cfa8714c9 upstream. Currently, setting a bridge's self PVID to other value and deleting the default VID 1 renders untagged ports of that VLAN unable to talk to the CPU port: bridge vlan add dev br0 vid 2 pvid untagged self bridge vlan del dev br0 vid 1 self bridge vlan add dev sw0p0 vid 2 pvid untagged bridge vlan del dev sw0p0 vid 1 # br0 cannot send untagged frames out of sw0p0 anymore That is because the CPU port is set to security mode and its PVID is still 1, and untagged frames are dropped due to VLAN member violation. Set the CPU port to fallback mode so untagged frames can pass through. Fixes: 83163f7dca56 ("net: dsa: mediatek: add VLAN support for MT7530") Signed-off-by: DENG Qingfang Reviewed-by: Florian Fainelli Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/dsa/mt7530.c | 11 ++++++++--- drivers/net/dsa/mt7530.h | 6 ++++++ 2 files changed, 14 insertions(+), 3 deletions(-) --- a/drivers/net/dsa/mt7530.c +++ b/drivers/net/dsa/mt7530.c @@ -818,10 +818,15 @@ mt7530_port_set_vlan_aware(struct dsa_sw PCR_MATRIX_MASK, PCR_MATRIX(MT7530_ALL_MEMBERS)); /* Trapped into security mode allows packet forwarding through VLAN - * table lookup. + * table lookup. CPU port is set to fallback mode to let untagged + * frames pass through. */ - mt7530_rmw(priv, MT7530_PCR_P(port), PCR_PORT_VLAN_MASK, - MT7530_PORT_SECURITY_MODE); + if (dsa_is_cpu_port(ds, port)) + mt7530_rmw(priv, MT7530_PCR_P(port), PCR_PORT_VLAN_MASK, + MT7530_PORT_FALLBACK_MODE); + else + mt7530_rmw(priv, MT7530_PCR_P(port), PCR_PORT_VLAN_MASK, + MT7530_PORT_SECURITY_MODE); /* Set the port as a user port which is to be able to recognize VID * from incoming packets before fetching entry within the VLAN table. --- a/drivers/net/dsa/mt7530.h +++ b/drivers/net/dsa/mt7530.h @@ -148,6 +148,12 @@ enum mt7530_port_mode { /* Port Matrix Mode: Frames are forwarded by the PCR_MATRIX members. */ MT7530_PORT_MATRIX_MODE = PORT_VLAN(0), + /* Fallback Mode: Forward received frames with ingress ports that do + * not belong to the VLAN member. Frames whose VID is not listed on + * the VLAN table are forwarded by the PCR_MATRIX members. + */ + MT7530_PORT_FALLBACK_MODE = PORT_VLAN(1), + /* Security Mode: Discard any frame due to ingress membership * violation or VID missed on the VLAN table. */