Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp541285pxb; Mon, 16 Aug 2021 11:11:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzyvAJV+ThlNH2efZwHmcXoOLVkcj8e3/oulluITCsnizcZlGp8JUNYSDFmgbZVXv6+rBzX X-Received: by 2002:aa7:d147:: with SMTP id r7mr21719693edo.148.1629137504248; Mon, 16 Aug 2021 11:11:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629137504; cv=none; d=google.com; s=arc-20160816; b=c9tKhHBRnw2VkVN0WG7R5Q/1ApmGybAglHX8i1s1BXx59JIHsaBUhLXKf28Jm+qXtw dvlryMBNmsvlR+3Dx7/sOMfs8WvNm1e9i1THOQAxxHuvHh1N6mXRNaz49orFTqxixAvD guxjoINfni0wiHUWBgcMdiNGPR/6DsokJz4WNWauLuBt1MD/VYj3CCEAiX9ZLW5CyaNK c2BErxRStqT5SN9/vB9Kghm46gjf7FSt36CzX83D9IZAKFSEM1nOqIFeBSXnTk3SMe7w FOn5ouBZSzVidMPuwPzhFIglUrVeW20IfGlZzFUhTP1TvJPhmRLovM58s53KA1LT8TtY ZfOw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=XB1c9ILEXbIGeaE3RF5LyGrxlHfkgsii4y9hKMpsOPM=; b=MLdMeEdycOLM7RmiprQXiL6RZhLL3nFm87rcC+wvd+PvbFvJ8bA6MdgIpOWUnVYFKq mSn1KUtqWvLs79lEDu3hAnAZIe9jY4gWg75j/3P9imv+dt9fVJauBXd7Yz32cJrICLF2 7P7oMpi/saBv6UoAt+FziehS1zwryJ0ajxf1tgtDcAtqwW28r0GmD2XH3FwG/JBUFZGq ldkeaLcuB1bBXki9d59FCKR++QYCZb6LstRijRUhMAKDxbQqu8kbP6dacplDT04x2JSJ ZdMZJguI4WSz0B4/3AOBKwSS2105SjOiKUXdBdO67wl/ijoRgAuA11Ogi/SaCvz1QloA jTCQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mind.be header.s=google header.b=VI1nmQkV; 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 b12si10726939edx.494.2021.08.16.11.11.21; Mon, 16 Aug 2021 11:11:44 -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=@mind.be header.s=google header.b=VI1nmQkV; 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 S231390AbhHPSK1 (ORCPT + 99 others); Mon, 16 Aug 2021 14:10:27 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59884 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232764AbhHPSKM (ORCPT ); Mon, 16 Aug 2021 14:10:12 -0400 Received: from mail-ej1-x636.google.com (mail-ej1-x636.google.com [IPv6:2a00:1450:4864:20::636]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1BC2DC061796 for ; Mon, 16 Aug 2021 11:09:26 -0700 (PDT) Received: by mail-ej1-x636.google.com with SMTP id w5so33369791ejq.2 for ; Mon, 16 Aug 2021 11:09:26 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=mind.be; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=XB1c9ILEXbIGeaE3RF5LyGrxlHfkgsii4y9hKMpsOPM=; b=VI1nmQkVG9NF54oMFgNJaqs5PhqOMtqHWzhdyKt7ZAMvAl0yGfSkwqBzm9DlrffV23 bFTG6mfUKjXFNG+jeKYDqnUpo5wpC8LQLgOZiMAclB91e9HEq90AmJe1Iw5wECEbi2fz KP6D7OnyxyBdVA0EvS/foCMdBVcWyQzV+W20KsHYVB9uBEtQ5G8rpabyib+7/n1z5Pwx cyyigDW1h/ctrNXOV9HxGMbF7NQXcMQZLyIoXzwh0q2DBo7QtfOhhq17HvRM5+x/UGUt sDJrW1kp7zyyq2WuMqggLoFNWJCguBYgMsRk6MTax4VzZOnIYxuieH07wCV3xRzljCkB SRlg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=XB1c9ILEXbIGeaE3RF5LyGrxlHfkgsii4y9hKMpsOPM=; b=eNE47ausiy870JJPpKqfWXI0GU/X4XJlQhrGiVvs95k32+xVS6pHOTx0SVmNK/66uO 2INlLngJyQ8/c6HJ8/f79hbT5ghlmxat1rils9jycxIKF1x9rfxL7Y5qFqFO3/Y0KjEs AbOXp8/AxSM1ceVoGneLUcavvJx/98wmrybtZtmTejlhuEg/+d/04urxo8u7PNj6R06T 3w9p6o044rphpYHFGUs2hVBAJAGOZUrCkSKIWZeCTfceP4AFNq8pEHD2cpEkwzjmx3MR QGnrwWsVjrDbF3Qa7jiNHosNwcZleXn4KCcuGGp0HlEcrwF0VmiRnExx5LsuvMhQavSV l/GA== X-Gm-Message-State: AOAM531NwcD28V4oB0lV+ye2WSgn32fUE75MN8qP+7/iDXEHd/9VKwIU 5oYIyHsuWI8sPJByMcWA1zB3kU74gnpJnw== X-Received: by 2002:a17:906:26c1:: with SMTP id u1mr15242796ejc.491.1629137364653; Mon, 16 Aug 2021 11:09:24 -0700 (PDT) Received: from cephalopod (168.7-181-91.adsl-dyn.isp.belgacom.be. [91.181.7.168]) by smtp.gmail.com with ESMTPSA id fl2sm3916370ejc.114.2021.08.16.11.09.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 16 Aug 2021 11:09:24 -0700 (PDT) Date: Mon, 16 Aug 2021 20:09:22 +0200 From: Ben Hutchings To: Greg Kroah-Hartman Cc: linux-kernel@vger.kernel.org, stable@vger.kernel.org, "David S. Miller" , Sasha Levin Subject: [PATCH 5.10 2/5] net: dsa: microchip: ksz8795: Fix PVID tag insertion Message-ID: <20210816180921.GF18930@cephalopod> References: <20210816174905.GD18930@cephalopod> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210816174905.GD18930@cephalopod> User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org commit ef3b02a1d79b691f9a354c4903cf1e6917e315f9 upstream. ksz8795 has never actually enabled PVID tag insertion, and it also programmed the PVID incorrectly. To fix this: * Allow tag insertion to be controlled per ingress port. On most chips, set bit 2 in Global Control 19. On KSZ88x3 this control flag doesn't exist. * When adding a PVID: - Set the appropriate register bits to enable tag insertion on egress at every other port if this was the packet's ingress port. - Mask *out* the VID from the default tag, before or-ing in the new PVID. * When removing a PVID: - Clear the same control bits to disable tag insertion. - Don't update the default tag. This wasn't doing anything useful. Fixes: e66f840c08a2 ("net: dsa: ksz: Add Microchip KSZ8795 DSA driver") Signed-off-by: Ben Hutchings Signed-off-by: David S. Miller [bwh: Backport to 5.10: - Drop the KSZ88x3 cases as those chips are not supported here - Handle VID ranges in ksz8795_port_vlan_del()] Signed-off-by: Ben Hutchings --- drivers/net/dsa/microchip/ksz8795.c | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/drivers/net/dsa/microchip/ksz8795.c b/drivers/net/dsa/microchip/ksz8795.c index 108a14db1f1a..3d36ffff1f4e 100644 --- a/drivers/net/dsa/microchip/ksz8795.c +++ b/drivers/net/dsa/microchip/ksz8795.c @@ -833,9 +833,11 @@ static void ksz8795_port_vlan_add(struct dsa_switch *ds, int port, if (new_pvid) { ksz_pread16(dev, port, REG_PORT_CTRL_VID, &vid); - vid &= 0xfff; + vid &= ~VLAN_VID_MASK; vid |= new_pvid; ksz_pwrite16(dev, port, REG_PORT_CTRL_VID, vid); + + ksz_pwrite8(dev, port, REG_PORT_CTRL_12, 0x0f); } } @@ -844,8 +846,9 @@ static int ksz8795_port_vlan_del(struct dsa_switch *ds, int port, { bool untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED; struct ksz_device *dev = ds->priv; - u16 data, vid, pvid, new_pvid = 0; + u16 data, vid, pvid; u8 fid, member, valid; + bool del_pvid = false; ksz_pread16(dev, port, REG_PORT_CTRL_VID, &pvid); pvid = pvid & 0xFFF; @@ -865,14 +868,14 @@ static int ksz8795_port_vlan_del(struct dsa_switch *ds, int port, } if (pvid == vid) - new_pvid = 1; + del_pvid = true; ksz8795_to_vlan(fid, member, valid, &data); ksz8795_w_vlan_table(dev, vid, data); } - if (new_pvid != pvid) - ksz_pwrite16(dev, port, REG_PORT_CTRL_VID, pvid); + if (del_pvid) + ksz_pwrite8(dev, port, REG_PORT_CTRL_12, 0x00); return 0; } @@ -1085,6 +1088,8 @@ static int ksz8795_setup(struct dsa_switch *ds) ksz_cfg(dev, S_MIRROR_CTRL, SW_MIRROR_RX_TX, false); + ksz_cfg(dev, REG_SW_CTRL_19, SW_INS_TAG_ENABLE, true); + /* set broadcast storm protection 10% rate */ regmap_update_bits(dev->regmap[1], S_REPLACE_VID_CTRL, BROADCAST_STORM_RATE, -- 2.20.1