Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp1418123pxv; Fri, 2 Jul 2021 03:23:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzvhZPAK9d9dI2YHZaxCzq4jo0L/V1sdy7BGdY2P2V+yutNaAVcZqCN3f005Y4VnGV5A0O6 X-Received: by 2002:a17:907:9813:: with SMTP id ji19mr4672822ejc.318.1625221404706; Fri, 02 Jul 2021 03:23:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625221404; cv=none; d=google.com; s=arc-20160816; b=cawthZ6EM0e7lYSDmRfZ7BWhnINEpFk823PeRcHtKlpsuQZyCtWP7QKTZJuqqY0HQI vlDv2E8WzXCI4UD5OkdPcPymh42TolIeB1zN07gaeXkmuZ7H7mgIjuUgWUCppmy5740U YmyphKQy2JZH4G/nO6O0Rk8GWidnUyWHu01zeiAT5GDsfPk6BvZfsSeqgaK1sP7bZp7a 2o2GstNPS+wqhrVNX6saCKgiQmHXPZ9geIyZYhaMeWvvd6Xdnf4wYTpQR/FHa2WTt4xu g+bBdijkhrJr2tlBQo1B+Hj+IcYThHOla5rasgwZF1mPbyhEwqT80J+sLAx7ZckrxbUx CAEg== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=g8bJ8HfVHO7JK0uVvkIQGytzY2BHBOikFKksG7U9LEk=; b=vZGljgYhYAGgyKtgZIJUHPAohwmQEtpDbAy4pupcAphpKxFoWNZkOyEGcGQ+i8L8Cf QL6FZXsKuYUUAnaHnsxT4Okh4lc4jv2EbVp2jTJ/m61SH1QlADPgwFtYH0piIZ/PedEL JTK/uItX5jHDdxivgbonibm3NH45lsQwr0xRA4jquchSyst0pT8FqRIB8WFHUXija8UA fpQ4Anhxoe0tBxWQCNJEJ0N5wuJ1gVV32EEY3Ykx9+yJ9kPyuEPtggVSndXOvAjLKEyU N1BLpqIIXTOoCmhKuqmbVHqg8reUvv26cw3JyyV5YeaN8RSDCxYbnnYhsDBA4xaCG0Ib 1Jvw== ARC-Authentication-Results: i=1; mx.google.com; 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 f29si2716774ejl.493.2021.07.02.03.23.00; Fri, 02 Jul 2021 03:23:24 -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; 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 S231942AbhGBKVN (ORCPT + 99 others); Fri, 2 Jul 2021 06:21:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42016 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231490AbhGBKUn (ORCPT ); Fri, 2 Jul 2021 06:20:43 -0400 Received: from metis.ext.pengutronix.de (metis.ext.pengutronix.de [IPv6:2001:67c:670:201:290:27ff:fe1d:cc33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 91815C061762 for ; Fri, 2 Jul 2021 03:18:11 -0700 (PDT) Received: from dude.hi.pengutronix.de ([2001:67c:670:100:1d::7]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1lzGFH-0005BE-3u; Fri, 02 Jul 2021 12:18:03 +0200 Received: from ore by dude.hi.pengutronix.de with local (Exim 4.92) (envelope-from ) id 1lzGFG-0003fh-1z; Fri, 02 Jul 2021 12:18:02 +0200 From: Oleksij Rempel To: Andrew Lunn , Vivien Didelot , Florian Fainelli , Vladimir Oltean , "David S. Miller" , Jakub Kicinski , Russell King Cc: Oleksij Rempel , Pengutronix Kernel Team , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mips@vger.kernel.org Subject: [PATCH net-next v2 5/6] net: dsa: qca: ar9331: add bridge support Date: Fri, 2 Jul 2021 12:17:50 +0200 Message-Id: <20210702101751.13168-6-o.rempel@pengutronix.de> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210702101751.13168-1-o.rempel@pengutronix.de> References: <20210702101751.13168-1-o.rempel@pengutronix.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2001:67c:670:100:1d::7 X-SA-Exim-Mail-From: ore@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This switch is providing forwarding matrix, with it we can configure individual bridges. Potentially we can configure more than one not VLAN based bridge on this HW. Signed-off-by: Oleksij Rempel Reviewed-by: Florian Fainelli --- drivers/net/dsa/qca/ar9331.c | 53 ++++++++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) diff --git a/drivers/net/dsa/qca/ar9331.c b/drivers/net/dsa/qca/ar9331.c index 2abec323ef14..66456752a436 100644 --- a/drivers/net/dsa/qca/ar9331.c +++ b/drivers/net/dsa/qca/ar9331.c @@ -40,6 +40,7 @@ */ #include +#include #include #include #include @@ -1095,6 +1096,56 @@ static int ar9331_sw_set_ageing_time(struct dsa_switch *ds, val); } +static int ar9331_sw_port_bridge_mod(struct dsa_switch *ds, int port, + struct net_device *br, bool join) +{ + struct ar9331_sw_priv *priv = (struct ar9331_sw_priv *)ds->priv; + struct regmap *regmap = priv->regmap; + int port_mask = BIT(dsa_to_port(ds, port)->cpu_dp->index); + int i, ret; + u32 val; + + for (i = 0; i < ds->num_ports; i++) { + if (dsa_to_port(ds, i)->bridge_dev != br) + continue; + + if (!dsa_is_user_port(ds, port)) + continue; + + val = FIELD_PREP(AR9331_SW_PORT_VLAN_PORT_VID_MEMBER, BIT(port)); + ret = regmap_set_bits(regmap, AR9331_SW_REG_PORT_VLAN(i), val); + if (ret) + goto error; + + if (join && i != port) + port_mask |= BIT(i); + } + + val = FIELD_PREP(AR9331_SW_PORT_VLAN_PORT_VID_MEMBER, port_mask); + ret = regmap_update_bits(regmap, AR9331_SW_REG_PORT_VLAN(port), + AR9331_SW_PORT_VLAN_PORT_VID_MEMBER, val); + if (ret) + goto error; + + return 0; +error: + dev_err(priv->dev, "%s: error: %i\n", __func__, ret); + + return ret; +} + +static int ar9331_sw_port_bridge_join(struct dsa_switch *ds, int port, + struct net_device *br) +{ + return ar9331_sw_port_bridge_mod(ds, port, br, true); +} + +static void ar9331_sw_port_bridge_leave(struct dsa_switch *ds, int port, + struct net_device *br) +{ + ar9331_sw_port_bridge_mod(ds, port, br, false); +} + static const struct dsa_switch_ops ar9331_sw_ops = { .get_tag_protocol = ar9331_sw_get_tag_protocol, .setup = ar9331_sw_setup, @@ -1111,6 +1162,8 @@ static const struct dsa_switch_ops ar9331_sw_ops = { .port_mdb_add = ar9331_sw_port_mdb_add, .port_mdb_del = ar9331_sw_port_mdb_del, .set_ageing_time = ar9331_sw_set_ageing_time, + .port_bridge_join = ar9331_sw_port_bridge_join, + .port_bridge_leave = ar9331_sw_port_bridge_leave, }; static irqreturn_t ar9331_sw_irq(int irq, void *data) -- 2.30.2