Received: by 2002:a05:6a10:c7c6:0:0:0:0 with SMTP id h6csp1613311pxy; Mon, 2 Aug 2021 06:13:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzoCES+XdSNExj7QoDn1fIdYG6EZ1D4bszb1uTsQhyw8/UCh2ucnYrVu//0KI3yjgiviOtM X-Received: by 2002:a5e:8f0d:: with SMTP id c13mr1343746iok.57.1627910031049; Mon, 02 Aug 2021 06:13:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627910031; cv=none; d=google.com; s=arc-20160816; b=hI7E2gtM4cXEDmKqFRFHGdzXiaT5HjemlqGAezyADLTRcqnmwsdGp/AmHEO7w/r76S kZF75n8xfAva0t5I3cTv2uCPWIZtpg9ljKSi7dNLPUFUR3qmL5uQBECqMKeI1lJNnf0R OX4GX5JHO31vX1d4ZxUrFtJXy177PkRo9V4PlamNZ7aGF9zzoV8gnV/tZwa2Je+8ciVz 7t5hPY/gk/A/8U9SNSM9ZYWTs42pKZhhQvILM0ljXtE1Y3ThGZ+219dp3oL5Vb0oSvWV MWu2OvDnYOAmlUa5o5Cs3fwDQ1GJkdW2KW6ZtA1u6se9R4YrNNxZFuKrmcVAzac2msaz k3rw== 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=2M5lkZTmBtLgRh6GDrReJmUqJEiinyxLrRI3RfCq+Eo=; b=AgHNrp2gKT6F6xDmphmCpfU1Bi8S9DeVNyszcE9EHuq2vGBZ79S5tOI0+pNjaxwauU y+LP0zOqyjFKdZJGIt73Ys51v0uXYKh7QW+2mG/bMk3s8veRs37yOdm3hudokP7mhXzR TehYsbhauK6vzoWOxckKLqnCkTYBNoVpafLVJm0d8Ek6UFqxcQwx82kxcHajY4DKE+18 8zHDxBdGj39uVOPXUaEFZZ58jloRProfKIo/n2p03QwF1cK1IxLA2HCqWsVDB4innDQ6 zv62xxR58PfXG+tY+IXdDnA/nkDxJKpzN7ubw5SeIjLroJm8Ksz6gMDX/nh4wncvoyC9 C9lw== 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 d131si17693246iog.11.2021.08.02.06.13.40; Mon, 02 Aug 2021 06:13:51 -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 S234027AbhHBNLX (ORCPT + 99 others); Mon, 2 Aug 2021 09:11:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57304 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233907AbhHBNK7 (ORCPT ); Mon, 2 Aug 2021 09:10:59 -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 C9162C0613D5 for ; Mon, 2 Aug 2021 06:10:49 -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 1mAXiK-0003Md-OZ; Mon, 02 Aug 2021 15:10:40 +0200 Received: from ore by dude.hi.pengutronix.de with local (Exim 4.92) (envelope-from ) id 1mAXiJ-00008b-K5; Mon, 02 Aug 2021 15:10:39 +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 v3 5/6] net: dsa: qca: ar9331: add bridge support Date: Mon, 2 Aug 2021 15:10:36 +0200 Message-Id: <20210802131037.32326-6-o.rempel@pengutronix.de> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210802131037.32326-1-o.rempel@pengutronix.de> References: <20210802131037.32326-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 d726d2f223ea..a0324fed2136 100644 --- a/drivers/net/dsa/qca/ar9331.c +++ b/drivers/net/dsa/qca/ar9331.c @@ -40,6 +40,7 @@ */ #include +#include #include #include #include @@ -1093,6 +1094,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, @@ -1109,6 +1160,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