Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp335732pxb; Mon, 16 Aug 2021 06:35:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwdxpwvVWlkXwkQZe1eScfWQuQwi0MrUrvA5l+ZpEMlIPmxFW/gc+7hASHDpQfULXCT/efb X-Received: by 2002:a17:906:eb53:: with SMTP id mc19mr15995197ejb.22.1629120916511; Mon, 16 Aug 2021 06:35:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629120916; cv=none; d=google.com; s=arc-20160816; b=vXdlOHqbS6ciHBErZLS8Qmdi5/ObQ+VfoCBKpsbQJ8WKE+FUrtoTIwoxHySmV3R6LM eI3HlQwhU9vXk7yirY4/BrnH/lWfqwTVvG/o5j+VqQ50G2E1RZ/ne5MU1kwnjnnagPZI n3NB3Ct+1z+F0xWo8Ji/1iepeY8bpwL/OqjlDWs9YahfTgl0EVnB+yIMI5tX/tGz8vzG nYVrIYq8C07WvQqASn7YnkvSSnjoumIp+Vo5y4XaJ9xqAb1jobX9f3atnMDRrTsxkmME RAe0FZ7gpUJQdBsze2tZz7CCZE194iT9VJ0HqQMQWLA/3X37UBqN9A826OFxCgNvCVig zeyw== 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=5Hm51iAQBloiTiw6Kv1YVBr3z2jDnqVVZ6w2zfSnC3o=; b=FjD766HW4g22n5/5+P6x++tckaY/3Ra0JTjvQryyv2zKEpgIMsaHpTlUrWn66Uo9wb xTPRmUWGUEWgs5/o34NqSoX4OIg6MnMxwUyydCNJMlqGCDpd2PXRqyXTMzqnequMHmjU OL2VHd18hvW3i37ah3laJyxwQrnQ9OCfNBa37cy2dOK9trtHf2dkQyhwGMZGRZolY0bx 2ukFCgNiLDCFs8w7gTybWUr6l/3Hp7bVr00GKE+pFnNUDkK1015rGZwG/odfmnuexFKF 5WPT5IcOOn6SOaHdTZz19h10QxfyhbiZVthiXQJHwvxkiSlqT0v3Z+BeG4awERrXnwCU G/0g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=QJNSKDEX; 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 d19si10524260edp.134.2021.08.16.06.34.54; Mon, 16 Aug 2021 06:35:16 -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=QJNSKDEX; 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 S238504AbhHPNaZ (ORCPT + 99 others); Mon, 16 Aug 2021 09:30:25 -0400 Received: from mail.kernel.org ([198.145.29.99]:44514 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240612AbhHPNT4 (ORCPT ); Mon, 16 Aug 2021 09:19:56 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id BEFA663316; Mon, 16 Aug 2021 13:15:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1629119704; bh=WCWSREiGsdTCRgU1r9ypj7YAPXjgrjO6iWSzadKqA1U=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=QJNSKDEX1SRhxaWDc1XRTXyf+D4/+YtFeicrvb1DNujL55k9689nfhR60P6kvmpb9 ZUj7I3NVYedv38jQviHQ2V4ZY82u56ApTYrRH8ZgqhkkB0MJzoZHXR5vaVT7Drc+hc 8kYEfO4elkOQxr1wpb8uSyvxOMuGLSOuMhKhbns0= 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.13 097/151] net: dsa: microchip: ksz8795: Dont use phy_port_cnt in VLAN table lookup Date: Mon, 16 Aug 2021 15:02:07 +0200 Message-Id: <20210816125447.269935960@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210816125444.082226187@linuxfoundation.org> References: <20210816125444.082226187@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 411d466d94a6b16a20c8b552e403b7e8ce2397a2 ] The magic number 4 in VLAN table lookup was the number of entries we can read and write at once. Using phy_port_cnt here doesn't make sense and presumably broke VLAN filtering for 3-port switches. Change it back to 4. Fixes: 4ce2a984abd8 ("net: dsa: microchip: ksz8795: use phy_port_cnt ...") Signed-off-by: Ben Hutchings Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/dsa/microchip/ksz8795.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/net/dsa/microchip/ksz8795.c b/drivers/net/dsa/microchip/ksz8795.c index 8e2a8103d590..8eb9a45c98cf 100644 --- a/drivers/net/dsa/microchip/ksz8795.c +++ b/drivers/net/dsa/microchip/ksz8795.c @@ -684,8 +684,8 @@ static void ksz8_r_vlan_entries(struct ksz_device *dev, u16 addr) shifts = ksz8->shifts; ksz8_r_table(dev, TABLE_VLAN, addr, &data); - addr *= dev->phy_port_cnt; - for (i = 0; i < dev->phy_port_cnt; i++) { + addr *= 4; + for (i = 0; i < 4; i++) { dev->vlan_cache[addr + i].table[0] = (u16)data; data >>= shifts[VLAN_TABLE]; } @@ -699,7 +699,7 @@ static void ksz8_r_vlan_table(struct ksz_device *dev, u16 vid, u16 *vlan) u64 buf; data = (u16 *)&buf; - addr = vid / dev->phy_port_cnt; + addr = vid / 4; index = vid & 3; ksz8_r_table(dev, TABLE_VLAN, addr, &buf); *vlan = data[index]; @@ -713,7 +713,7 @@ static void ksz8_w_vlan_table(struct ksz_device *dev, u16 vid, u16 vlan) u64 buf; data = (u16 *)&buf; - addr = vid / dev->phy_port_cnt; + addr = vid / 4; index = vid & 3; ksz8_r_table(dev, TABLE_VLAN, addr, &buf); data[index] = vlan; -- 2.30.2