Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp753661ybl; Fri, 24 Jan 2020 08:58:26 -0800 (PST) X-Google-Smtp-Source: APXvYqwEROlZ3WpWzr7DDJLMRXBtrFlI56mufirMblpMYGnBPxQYm+NgGcnGXDn4IAYj6QoO7fxJ X-Received: by 2002:aca:1005:: with SMTP id 5mr135588oiq.16.1579885106598; Fri, 24 Jan 2020 08:58:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579885106; cv=none; d=google.com; s=arc-20160816; b=l3kze0QGR6HaNdJouEw/mSfZeB4sbwdhEoB2qwjlD1WznUF8P32tzfknQSB+67NjfH J/QAd4iJ83Tv34Qdd0Yl9T6x5D7DtgU0/j1R9/OwOv6hT43G9pzpNIimSwqIIx0iWZ0X 8z+0tHASLIuhnbkICB7V3RLZcOThhtK+cAeWTsAJ//8IXGVi3fE+RGvp31TrVxOkq83m pEKXT3p1GHu4xgTao/R9L+Sb28g7hKCdKmAzLJRgyUfR7LKblLM0qIDmqpf3jVqNxUQP fBoHzysEPChWPZS8elh6E5jDH5A7/NL2XdpT/cijbSgV7txHFUYt25RgQD9EdAAWV1bv CtKQ== 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=eYvcSs9bhncoDELce4ytRl0LW3ecY//2QDtfIIsN7BQ=; b=tnkJ8xz/iru0zrDgv8mtjVWGrNmGhF/AFo8C2DDnQPy0qfwGlVaTVTwbhzyqnEW50g DInxDsPIPXvG1Zs4M+pow+VAS0EM+APg8t1yzJ6AFMg+5zM5iO152H2iDTlF38yFtgb6 Hgxe1FwyCtcmPP8KaaCbTXhz1SJWKlbLArH0Du32U6f7I8l/dAUBsdmNkESOz/SCwXi8 HDEMPMMs1zdJ6VoEF3BUeOtdI2vMNZjmGeVyaUH3vcZs/t9wtckNFeg5kDlj+QYTWfHr i7Psj9fdKYRdoO8WswhbYXpEBBBjDvQzVmJ6LqhvBVqNo5p4KNAXApw/AkobH5kYJf7y S1Bw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=dfgKBe15; 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 107si1841543oth.14.2020.01.24.08.58.14; Fri, 24 Jan 2020 08:58:26 -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=dfgKBe15; 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 S2389816AbgAXLKF (ORCPT + 99 others); Fri, 24 Jan 2020 06:10:05 -0500 Received: from mail.kernel.org ([198.145.29.99]:45740 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731494AbgAXLKC (ORCPT ); Fri, 24 Jan 2020 06:10:02 -0500 Received: from localhost (ip-213-127-102-57.ip.prioritytelecom.net [213.127.102.57]) (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 0E78220663; Fri, 24 Jan 2020 11:10:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579864201; bh=AJcb+fpv4vT7OwUY85kfR67AG/2ZUu9M8DTVDDCTCds=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=dfgKBe15mw67Ecmbrv24dHR0WEm+Ogm/gCd7O2aTW8sjj2gJIK9zcFXCVFdV66v/+ 3zjTUZDNQOPneCKvZHmJinTalxF6E9Mc6Yj8nIYgCnBLY46rw+ZnvUn1y+ZWIoA2GS Sjg1piRtrlTJbKaXLxCt+rlLy2HwsrAPIUpU+ZuQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Florian Fainelli , "David S. Miller" , Sasha Levin Subject: [PATCH 4.19 200/639] net: dsa: b53: Fix default VLAN ID Date: Fri, 24 Jan 2020 10:26:10 +0100 Message-Id: <20200124093112.105839069@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200124093047.008739095@linuxfoundation.org> References: <20200124093047.008739095@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: Florian Fainelli [ Upstream commit fea83353177a55540c71c140887737c282137aa2 ] We were not consistent in how the default VID of a given port was defined, b53_br_leave() would make sure the VLAN ID would be either 0/1 depending on the switch generation, but b53_configure_vlan(), which is the default configuration would unconditionally set it to 1. The correct value is 1 for 5325/5365 series and 0 otherwise. To avoid repeating that mistake ever again, introduce a helper function: b53_default_pvid() to factor that out. Fixes: 967dd82ffc52 ("net: dsa: b53: Add support for Broadcom RoboSwitch") Signed-off-by: Florian Fainelli Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/dsa/b53/b53_common.c | 29 ++++++++++++++++------------- 1 file changed, 16 insertions(+), 13 deletions(-) diff --git a/drivers/net/dsa/b53/b53_common.c b/drivers/net/dsa/b53/b53_common.c index 2d3a2cb026d26..bceda1e884426 100644 --- a/drivers/net/dsa/b53/b53_common.c +++ b/drivers/net/dsa/b53/b53_common.c @@ -622,15 +622,25 @@ static void b53_enable_mib(struct b53_device *dev) b53_write8(dev, B53_MGMT_PAGE, B53_GLOBAL_CONFIG, gc); } +static u16 b53_default_pvid(struct b53_device *dev) +{ + if (is5325(dev) || is5365(dev)) + return 1; + else + return 0; +} + int b53_configure_vlan(struct dsa_switch *ds) { struct b53_device *dev = ds->priv; struct b53_vlan vl = { 0 }; - int i; + int i, def_vid; + + def_vid = b53_default_pvid(dev); /* clear all vlan entries */ if (is5325(dev) || is5365(dev)) { - for (i = 1; i < dev->num_vlans; i++) + for (i = def_vid; i < dev->num_vlans; i++) b53_set_vlan_entry(dev, i, &vl); } else { b53_do_vlan_op(dev, VTA_CMD_CLEAR); @@ -640,7 +650,7 @@ int b53_configure_vlan(struct dsa_switch *ds) b53_for_each_port(dev, i) b53_write16(dev, B53_VLAN_PAGE, - B53_VLAN_PORT_DEF_TAG(i), 1); + B53_VLAN_PORT_DEF_TAG(i), def_vid); if (!is5325(dev) && !is5365(dev)) b53_set_jumbo(dev, dev->enable_jumbo, false); @@ -1142,12 +1152,8 @@ int b53_vlan_del(struct dsa_switch *ds, int port, vl->members &= ~BIT(port); - if (pvid == vid) { - if (is5325(dev) || is5365(dev)) - pvid = 1; - else - pvid = 0; - } + if (pvid == vid) + pvid = b53_default_pvid(dev); if (untagged && !dsa_is_cpu_port(ds, port)) vl->untag &= ~(BIT(port)); @@ -1460,10 +1466,7 @@ void b53_br_leave(struct dsa_switch *ds, int port, struct net_device *br) b53_write16(dev, B53_PVLAN_PAGE, B53_PVLAN_PORT_MASK(port), pvlan); dev->ports[port].vlan_ctl_mask = pvlan; - if (is5325(dev) || is5365(dev)) - pvid = 1; - else - pvid = 0; + pvid = b53_default_pvid(dev); /* Make this port join all VLANs without VLAN entries */ if (is58xx(dev)) { -- 2.20.1