From patchwork Wed Aug 4 13:54:29 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Vladimir Oltean X-Patchwork-Id: 492104 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id B8F61C4320A for ; Wed, 4 Aug 2021 13:55:12 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 9D6A660EE9 for ; Wed, 4 Aug 2021 13:55:12 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238502AbhHDNzY (ORCPT ); Wed, 4 Aug 2021 09:55:24 -0400 Received: from mail-db8eur05on2061.outbound.protection.outlook.com ([40.107.20.61]:28896 "EHLO EUR05-DB8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S238461AbhHDNzX (ORCPT ); Wed, 4 Aug 2021 09:55:23 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=EPr7Hc9BWgIXosP+ThVg8lh0Zpowi33nZMKxMSELaqTRb8DGroWBwwtSzYx4TUNr8LEiYSuzMJ1bxBnacGM1l0VU3DscHX2ZcxfQwO6lOH0d/ZoQeu+yZMeL6BQueYi1u57ve4Maxon7YcKePJlbn5i4CxWVZkrxXN7gi2rmNFpBUxZIiLr70i2ZnG2Uz8Q0YqZss4FM6UYTE/SBeoajXvoavRPsY8uCxEFpjVLT80qjrlfphfAdfZJKMZaLCJljnylDtq45WYDxZA3fH+t+TGZkY/jgY8tW5FpOsl0m38uBu8R4Uuijfxk1mVEzi8ir2eXVZgqh95vqtPJB32WckQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=bUJQTskF/PxUROiNR9u0KutptxhC7rr7ejtMqyblQE4=; b=fW2GNsNJk+UWuYMP4tDUxAXaw+wBpWJX4il4I+86H2HEZ70rbpa7SNibcI2RRJhhZeh0tzjReoHS8q/O9bNZTxoz+yfxAVfdIw/BZ6IRi/CV+z/52R1gZSuPpHQvS5HveOKKO7JkJjebpucU0Jmf16qmHfY1RTW8AqW20RKOQsfK8fXZXrde3393/pZmJC7qarmkN5oXMsVyL5+dmJgVR/n3Sx68ygI0dBEliaA2AkQLh7Kvi6UBoBq6n4Aenxu3k4IaMRlnAizRSA/rQQRgXtQZzf8EqnfMmQ2aEWjaRNbSIUBU189vFah15znt1/4Z7MkofrOZPQDsjuzgSicXrQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=bUJQTskF/PxUROiNR9u0KutptxhC7rr7ejtMqyblQE4=; b=IFtZDEoeIVc7gQYvSlxYlsjLDS6OmKGNt72hHICT55GjrTI6UEo3I+XOMfcVDkcExqbty/lukiHv2a+g6NT5SsZUJR3ZJaP+HtLesmpMVdMjhctX3NwHRt2bdBNH8nzHBJA/I7GYxBLzjhhm8B2GeqvrnXfrEPLhZZlEcf+sdXI= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none; vger.kernel.org; dmarc=none action=none header.from=nxp.com; Received: from VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) by VI1PR0401MB2687.eurprd04.prod.outlook.com (2603:10a6:800:57::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15; Wed, 4 Aug 2021 13:55:08 +0000 Received: from VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0]) by VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0%2]) with mapi id 15.20.4373.027; Wed, 4 Aug 2021 13:55:08 +0000 From: Vladimir Oltean To: netdev@vger.kernel.org, Jakub Kicinski , "David S. Miller" Cc: Andrew Lunn , Florian Fainelli , Vivien Didelot , Vladimir Oltean Subject: [PATCH v3 net-next 1/8] net: dsa: rename teardown_default_cpu to teardown_cpu_ports Date: Wed, 4 Aug 2021 16:54:29 +0300 Message-Id: <20210804135436.1741856-2-vladimir.oltean@nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210804135436.1741856-1-vladimir.oltean@nxp.com> References: <20210804135436.1741856-1-vladimir.oltean@nxp.com> X-ClientProxiedBy: AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) To VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (188.25.144.60) by AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15 via Frontend Transport; Wed, 4 Aug 2021 13:55:07 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 0fa91385-c017-492f-eec8-08d9574f784b X-MS-TrafficTypeDiagnostic: VI1PR0401MB2687: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:6430; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: IOCqKXWJOMpB870XjlUTvmvHKBy7ya52+IZoiA+JRGXNCPNwVNt97uq4PIiIU6A38O4OBAMzjC2dLH6xZ+bku6XaUM81z/Au7F7LcLTRNBZqxRVXoBvIEjwiK4BiL6bMMYBMadUWh2L1qUG3ob5YLbI6/5r4voRTGZS5wEemgXaYCHN4AvfDelW4LVWuS02WQfI5e8nvIBE4TMI2cPzfRAE/S+v1/Is4q6AZ5/qk+pvpNZI15YP9LxItZbDE6M47Isswc8Dt3N4plnk00cPdImrxd1KTqew/zFcTBgDZd17ilUV2BVGX97CI9fObC9iEqLes3eBlAeBXNd2mlv4vydEob5HpznGEDt54yzR3KCKS5s9mqFQu5oLGrjytm+V3HgPW+T11avyN9+Eg/SeQ+gD6DbxklViPVuqmHKwGxS7aRdDAuDayLG2ACQ8c/k4fYXqylpntuGC26AqqRApoEckUOChN5+u01kf7BTxhdLH0p+tlAjHh70E3KyLJJZLdhDqjfnHr9KOZ/OqhjIPRAlCenHqmlg7nPX5QKWyhxU2+un/Ix3SWmrHITv6EJj9RfMeoyvuMwkOUO+3gqD1b5tg3B8Y5ddgPe7lV+8IIKERfRWejAjlUVDV9UvDbq5UGPsVOFyu/urvIvxfCuMaOyOaUSGHp2RM835MXubpcTw1mRY2nz+nHagAIwN7USEqp13/nE3TQVCsVErPnYP1dPw== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:VI1PR04MB5136.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(136003)(366004)(396003)(376002)(39860400002)(6666004)(6486002)(5660300002)(478600001)(66946007)(1076003)(66476007)(4326008)(66556008)(54906003)(26005)(44832011)(38350700002)(86362001)(2616005)(52116002)(8676002)(6506007)(2906002)(36756003)(110136005)(83380400001)(38100700002)(956004)(6512007)(316002)(8936002)(186003); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: PzGOb5fXcqspL2uw125Cul8i0xnB2neAvowIwFQTroyYkznRAY+9gTak0oXRqISGHXeH/Q6sGp7uJAdAiCm0xFCcTaeflsYavDoAxWD2a4gjeVQpfzfbhwpieHWLPHRw+3lA6/5UKEzwXhvkDiX+jzCybNDVuZE6/rUvL1eIRFLLbcoWWFn1KE285V2mNbNdwoXturGsH7JRKcGJ5FUrm28wiqUsEU3ZS6UgOkdnWpCtONYFmRohRAz7Ep+HhYs5FaU/bBT6P5w07Kh6oFEmvrPsfYhgn7pJMdNUllgDwWHorNsruuEUrLcwgvLFDTwxBJY948oAdfJ64hcUqJMd7RpAV6aCD1grIoDW/Qq0JJm2Whn8Zybd+2sRzCD3sZaiHzKOZEAYOo2spUyQFZmc93fEYmozZeF2XCnsVPMOJMcrhcAyymo2gUuv8IXaPG72ka368pbAFNGK3RKzjeMoevnnsLbxy3sQqmTG7DmWW3XNfy5p2E0tr024E5RR7QKS44YkK7d5KsB7qkls8RiQ+BczERHKlLHmCDdddy+yBfgyP0An6CDhKD9EbEiubvAfKvPt1S/rib9aWq1zP5NRQbpITLiAe1e5R7v4Jx2W5xHk5luDJIajjbUeI3uIIcg7ExSsPwqVHF4jVD2xCWztWO7F36UvIq/ITg8SJCoKLClIWPBdsk1n+pLOgsG+sA5m6Lh+r4llfilv53msv3xotLlQKokfTLrctm8rirstP1qBqu/fuFrEdidLHoGfYsziUcPW6hNerFy3QguDibRcyyxSbFUvbPh544NH/xqODbRq8KVT9Ik/zbIKGrQggKZyVi7aRftpVkLOAYOxvvIJHlJHjpueMCoCHesmHo2T9/bv2ITPhzW3x7iYIJS7/sFFQnRLRLpX4q0fkBg9zu88Bi+g2j+lrxDAU7ScL7qm57PjhTYG7teejMrnMBLVFAFtyyE+yw3FGlLARFCK+H+HdVibqjlS9dNMG+KtJAWzuxoOGeYwXfkrETXUw9rhviQGh/rQqE7HPPQVQbKURYXsFRR/FcyAnr2uvIvlBspoo9F+82KGy/AsHFaNn4FIUymb4uhfjFtTIsaM0s19VMGD0n4ygOq5GbvZAKW5v6BRNTOgbGZQYQdjzIRqUOyAbJTK5OHwGWV0JAwAc25h/XwRnGFutaP0tiFBNISsRF/c80Vmcrs2Lm0MgfqJRWaNn7y4P3CeXw7ohjgqjoGwBWjyvKCBBjG8srq3Z14x3vjIULfw3kiQ6Z4W9VOwwhZg0q1qPF+bCpwFENrPR5fG5Gp9VD7hXKeJIH/fdqQnO389X6Ggqj31qP6dNwBCZplWUc6q X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 0fa91385-c017-492f-eec8-08d9574f784b X-MS-Exchange-CrossTenant-AuthSource: VI1PR04MB5136.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Aug 2021 13:55:08.3410 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: JPBVCRQsqRx1kRZTy2G3vapCkJBHoW82e3PNgto1jko4pkNWkuU4H1ywoQpJnLYWp4CpDd1RVEgbyKefnEGRzQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0401MB2687 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org There is nothing specific to having a default CPU port to what dsa_tree_teardown_default_cpu() does. Even with multiple CPU ports, it would do the same thing: iterate through the ports of this switch tree and reset the ->cpu_dp pointer to NULL. So rename it accordingly. Signed-off-by: Vladimir Oltean --- net/dsa/dsa2.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/net/dsa/dsa2.c b/net/dsa/dsa2.c index c7fa85fb3086..4f1aab6cf964 100644 --- a/net/dsa/dsa2.c +++ b/net/dsa/dsa2.c @@ -329,7 +329,7 @@ static int dsa_tree_setup_default_cpu(struct dsa_switch_tree *dst) return 0; } -static void dsa_tree_teardown_default_cpu(struct dsa_switch_tree *dst) +static void dsa_tree_teardown_cpu_ports(struct dsa_switch_tree *dst) { struct dsa_port *dp; @@ -927,7 +927,7 @@ static int dsa_tree_setup(struct dsa_switch_tree *dst) err = dsa_tree_setup_switches(dst); if (err) - goto teardown_default_cpu; + goto teardown_cpu_ports; err = dsa_tree_setup_master(dst); if (err) @@ -947,8 +947,8 @@ static int dsa_tree_setup(struct dsa_switch_tree *dst) dsa_tree_teardown_master(dst); teardown_switches: dsa_tree_teardown_switches(dst); -teardown_default_cpu: - dsa_tree_teardown_default_cpu(dst); +teardown_cpu_ports: + dsa_tree_teardown_cpu_ports(dst); return err; } @@ -966,7 +966,7 @@ static void dsa_tree_teardown(struct dsa_switch_tree *dst) dsa_tree_teardown_switches(dst); - dsa_tree_teardown_default_cpu(dst); + dsa_tree_teardown_cpu_ports(dst); list_for_each_entry_safe(dl, next, &dst->rtable, list) { list_del(&dl->list); From patchwork Wed Aug 4 13:54:30 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Vladimir Oltean X-Patchwork-Id: 492752 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 7B6C5C4338F for ; Wed, 4 Aug 2021 13:55:14 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 54FAC60EE5 for ; Wed, 4 Aug 2021 13:55:14 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238510AbhHDNzZ (ORCPT ); Wed, 4 Aug 2021 09:55:25 -0400 Received: from mail-db8eur05on2061.outbound.protection.outlook.com ([40.107.20.61]:28896 "EHLO EUR05-DB8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S238480AbhHDNzX (ORCPT ); Wed, 4 Aug 2021 09:55:23 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=YPFPDJMb2GY5hhERcDWnyQoPj6RbPyhdJ2v8BqMPlhmURd1lRM3bNI4OmEQ/lwvr/qrI4qER/wmlZaWpYpgsIy4G/DHFGq1e0ZKV7kGNLUGEGzcE0TrWHkzQdZkagRAZm2GYoDPOi+Pd+oX1S2zOAQCV2bklhV8zbE0DKbWD8N+dfb947dQ9tQmU6PVM7BETj6XWSraaoKj8pMPXUGGfnyxtaIoCSVY7npfuR/EBeGmKdPSdzHb+kJmEQhsZzVLK6uRD4kHdQi6sRLHO8SJ7OxVl/Yt+Ir2OK4eX4otzX11z9tO13ndA5mAvMbVkj2ClypHT18qmCaimLM2/gVOLKQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=KiJmFmMYJsZ9bUIo921mVVDZtkXXOj2DhC3Iy290hC8=; b=G6TX9aTpZoP4NrM2BN8uZDIres30ElA0gWW9Y41rSTRFkyuME997sr50BD09myHFAz0n7i0H6zZ7mFkxVAElOLK0HRVq68EoTit4Dj0oStqFajnGagL45DrD44bQVmI6BxV+c6AOFtLQ2o9QhQUbqlVEVJ5GLo1DntuctekBVu0WeSXtdAnPGHtNk3SanNVG4IyQDuBkim2GzrZlWF9vPVDjd6X3zo+K6gimZUa0sYmB7XyLqfdrd0nxqmNCrhHUeu8bx8epz9GlCZgzYx2OFM+/bwQM6lASBCf+8VxwC8obqZNvTXtfAjntpBwsO/b39I3MbCjJL7zDr7kPJ6A1dQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=KiJmFmMYJsZ9bUIo921mVVDZtkXXOj2DhC3Iy290hC8=; b=orNLNWZjCyG1Zhy/dCrNrxLF9D1LiJGtj/53EiF85bA1+Ze9KH/WLiQgQ6WwAVvG7YQtwbKmKCgAWuOFxxrAW/mEgYgLtqhWP22o3ziPcuKaGR0rAAkAy4B2RSlM+r7lZ/2l4eMwmK+27S5hYyWpbIopBPu7MlXf3RqJhaDOjF4= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none; vger.kernel.org; dmarc=none action=none header.from=nxp.com; Received: from VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) by VI1PR0401MB2687.eurprd04.prod.outlook.com (2603:10a6:800:57::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15; Wed, 4 Aug 2021 13:55:09 +0000 Received: from VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0]) by VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0%2]) with mapi id 15.20.4373.027; Wed, 4 Aug 2021 13:55:09 +0000 From: Vladimir Oltean To: netdev@vger.kernel.org, Jakub Kicinski , "David S. Miller" Cc: Andrew Lunn , Florian Fainelli , Vivien Didelot , Vladimir Oltean Subject: [PATCH v3 net-next 2/8] net: dsa: give preference to local CPU ports Date: Wed, 4 Aug 2021 16:54:30 +0300 Message-Id: <20210804135436.1741856-3-vladimir.oltean@nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210804135436.1741856-1-vladimir.oltean@nxp.com> References: <20210804135436.1741856-1-vladimir.oltean@nxp.com> X-ClientProxiedBy: AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) To VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (188.25.144.60) by AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15 via Frontend Transport; Wed, 4 Aug 2021 13:55:08 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: c6cd462f-b5f4-4dd0-6f59-08d9574f78db X-MS-TrafficTypeDiagnostic: VI1PR0401MB2687: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:10000; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: zFR8xRhlk6tNjIU+N3t0PA7ODTPp3VxYvdhSceRW1s9JasIGF5VMPhLrH/IUdbsyJ5GPEj1D2ocakVuPtlgD+GLyZLUM172cIhJyzz/HWVSXq2I9Td+yPUOnmqgFeEkp16VVfLN1MwpWKhl5yi9Ote29ccz00WsOxmg8ZIwpN7KWMV9tpkm+8eDsSaxU7j7vCZd/66MZmThcnVJte1HVyo5y+SUW54VWh/Yn9ecsOhk64KNtqdw4wdgGzz1YguLhxN358NEIVp25fqF842RlFlOij13TFDCGf/A/bSRb3v9yzlhsxS7zcyO3E1gJ8Ll8DjQWiHrJS1CoOWFl+L7WrSOuRJW+GHCUKTdmli9s5U3bLIz3jgozGf7gKWzKBWcNKmtbXGFMbxngxGSbaEcIkTetblWivrEobKFB8Qh9YjgTe95ap+qsRJpgUw5lRx6iwBuG3gG01c/qST+ef+BMiWCNG1l3hawD4Y9y5khbY8GMbIyqJvOCNKOKFgETP8oqVHKiwN9x2M+8vEQsvNs7mdNixkgmW/k2klnfOXvRLK6yTcLow8DaB2aPcr39T20AmDe0NzB5fpJcb7ffuOtPmfSVJ4xl5cuhPXCbeChlsxgRaHTsgXBM0EGd8ytKmOaUxk1KXis8c+2zH9qCz/1IHiWgd6ECEnrQu9SvM/b1sTdki/x1WDaxVdWirTAZBJaCn5SR/G80Cd5JI8d2ZrZAXA== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:VI1PR04MB5136.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(136003)(366004)(396003)(376002)(39860400002)(6666004)(6486002)(5660300002)(478600001)(66946007)(1076003)(66476007)(4326008)(66556008)(54906003)(26005)(44832011)(38350700002)(86362001)(2616005)(52116002)(8676002)(6506007)(2906002)(36756003)(110136005)(83380400001)(38100700002)(956004)(6512007)(316002)(8936002)(186003); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: Fn7bkNxfZESRy0Qa3HdMVhEl9lj305zsY9b2r4V+OB7uU2fxDv/rNQOKt0sRcxNceIUq8//t86wHM9CyzdmBFwTXPStb1WLKjmuJCFzPOVby2CUrE0pBnEWveFaj+7zuxsh710fEtvyoc5uHUPJQoEjV29LqB+9m1YAQIgkCosSONwnrJQx3aUg9XprQZnEsiZUG0k8g4wUTwWi5lree4EtaaNx+yw3rOVxl5trQZGJJ/fNY5HaY40nijg7Jsx/x9I/MPwWb6LsBKPYavU3dyQDFJrg2og6ZZrmEzzneFPnL/0cxp7Bnxkj5U83C1ZGqik++ZpScM2Qvrwy/B/hmIgGKFBIFpuBx3JQoH6m9yDlAnnnexq0M61Sg1l2qa1BqXjVK3P56cUrQIanGU+t1zIzCQBv5pVVG/PodXT8FIR10EgoVu1yq0YFhb9sD2TIMnc7F3Pyo7ahdFOnAja+Xt/2TaomNgKhSxWw+/FKNQa7wmbfHeOOIsf+wF92Sld5HS5tpSF8jlD8PqqmIPdC6GhjOt8w234l3t3RSTZ7Bno6t53M91E/37tiAWHYUuYh/RIK/kuguIcCYPXZB9SuxqNI/oBXQffe8T/ZiQPIKS+uDvrZ6C+LiCK2j7pBVJTVJVgzcgn2zKmMbvb4dfAOjPT+6zBGLJ2SRNAP9dcJADVRyoitvocsyYNlM0FUhONg+xyrBU5YQY4d1G12AFt6Dv3eQ9HLx05QECBwyA0t+wRza49S2/WBcpsem3RTDas/yBEwfmnU8CEH9mZLz0KUEmmg26bnVi29mfeDby7MxK0TgDSeDbjRGBRQCyU8V+RG6k+105jWYJVQ5iCqqTu6tgZwP25gV/iAwRXtYVfXGtJuyl7JqbDMqvKypkQndYNuSFu8e1/jcIaMrcdx6qXq0pD+VIGDF2po/gA2s2UB9LaWreimyJoPJtD+6C7kY6fQg1imlhgSE4IQpBWdK3kvyYsOb6a0hbNvhptguGECSKENBDIbF/fcJzQduFPo9imShnHvM358pd1xaVYNL1yQMEladIUjMdMrvOuJp/q6m0KuUYxPmKKxM2J8jIQrvwicc3X3hBSntm8ReR/ofZBWnpNMmfmBLCgYnrzr3fao0TCrRpy42o5H5ZE2plhzqAfhq9+zh0VkNw5t5mTcXXwDPY10zgKR6BRTLA7Yweg42bTN+lY/IYSvUS0I7Q2b4peNU5J6onSfk95NFHc7717KGNH/Yljg25KA+kfd9E+7/xoKLlR3omObZ8fGOPobqY41jHTwEpBMZM7msixby0cPUyvx9z+fhKcIAxSlURNhXSeGH2l+h3AHeTExn3ckKAIvy X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: c6cd462f-b5f4-4dd0-6f59-08d9574f78db X-MS-Exchange-CrossTenant-AuthSource: VI1PR04MB5136.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Aug 2021 13:55:09.2954 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: OiaqDiXhBB3NN8nOL59Hd6uBDlHnoT6GNuM23+rwnnPi2n8mUMdCW3U5HFiLSE24QqkqZBL0Aau5KwmZFOyu5Q== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0401MB2687 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Be there an "H" switch topology, where there are 2 switches connected as follows: eth0 eth1 | | CPU port CPU port | DSA link | sw0p0 sw0p1 sw0p2 sw0p3 sw0p4 -------- sw1p4 sw1p3 sw1p2 sw1p1 sw1p0 | | | | | | user user user user user user port port port port port port basically one where each switch has its own CPU port for termination, but there is also a DSA link in case packets need to be forwarded in hardware between one switch and another. DSA insists to see this as a daisy chain topology, basically registering all network interfaces as sw0p0@eth0, ... sw1p0@eth0 and disregarding eth1 as a valid DSA master. This is only half the story, since when asked using dsa_port_is_cpu(), DSA will respond that sw1p1 is a CPU port, however one which has no dp->cpu_dp pointing to it. So sw1p1 is enabled, but not used. Furthermore, be there a driver for switches which support only one upstream port. This driver iterates through its ports and checks using dsa_is_upstream_port() whether the current port is an upstream one. For switch 1, two ports pass the "is upstream port" checks: - sw1p4 is an upstream port because it is a routing port towards the dedicated CPU port assigned using dsa_tree_setup_default_cpu() - sw1p1 is also an upstream port because it is a CPU port, albeit one that is disabled. This is because dsa_upstream_port() returns: if (!cpu_dp) return port; which means that if @dp does not have a ->cpu_dp pointer (which is a characteristic of CPU ports themselves as well as unused ports), then @dp is its own upstream port. So the driver for switch 1 rightfully says: I have two upstream ports, but I don't support multiple upstream ports! So let me error out, I don't know which one to choose and what to do with the other one. Generally I am against enforcing any default policy in the kernel in terms of user to CPU port assignment (like round robin or such) but this case is different. To solve the conundrum, one would have to: - Disable sw1p1 in the device tree or mark it as "not a CPU port" in order to comply with DSA's view of this topology as a daisy chain, where the termination traffic from switch 1 must pass through switch 0. This is counter-productive because it wastes 1Gbps of termination throughput in switch 1. - Disable the DSA link between sw0p4 and sw1p4 and do software forwarding between switch 0 and 1, and basically treat the switches as part of disjoint switch trees. This is counter-productive because it wastes 1Gbps of autonomous forwarding throughput between switch 0 and 1. - Treat sw0p4 and sw1p4 as user ports instead of DSA links. This could work, but it makes cross-chip bridging impossible. In this setup we would need to have 2 separate bridges, br0 spanning the ports of switch 0, and br1 spanning the ports of switch 1, and the "DSA links treated as user ports" sw0p4 (part of br0) and sw1p4 (part of br1) are the gateway ports between one bridge and another. This is hard to manage from a user's perspective, who wants to have a unified view of the switching fabric and the ability to transparently add ports to the same bridge. VLANs would also need to be explicitly managed by the user on these gateway ports. So it seems that the only reasonable thing to do is to make DSA prefer CPU ports that are local to the switch. Meaning that by default, the user and DSA ports of switch 0 will get assigned to the CPU port from switch 0 (sw0p1) and the user and DSA ports of switch 1 will get assigned to the CPU port from switch 1. The way this solves the problem is that sw1p4 is no longer an upstream port as far as switch 1 is concerned (it no longer views sw0p1 as its dedicated CPU port). So here we are, the first multi-CPU port that DSA supports is also perhaps the most uneventful one: the individual switches don't support multiple CPUs, however the DSA switch tree as a whole does have multiple CPU ports. No user space assignment of user ports to CPU ports is desirable, necessary, or possible. Ports that do not have a local CPU port (say there was an extra switch hanging off of sw0p0) default to the standard implementation of getting assigned to the first CPU port of the DSA switch tree. Is that good enough? Probably not (if the downstream switch was hanging off of switch 1, we would most certainly prefer its CPU port to be sw1p1), but in order to support that use case too, we would need to traverse the dst->rtable in search of an optimum dedicated CPU port, one that has the smallest number of hops between dp->ds and dp->cpu_dp->ds. At the moment, the DSA routing table structure does not keep the number of hops between dl->dp and dl->link_dp, and while it is probably deducible, there is zero justification to write that code now. Let's hope DSA will never have to support that use case. Signed-off-by: Vladimir Oltean --- v2->v3: make dsa_tree_setup_cpu_ports() not reassign the dp->cpu_dp if already present, which makes each port get assigned to the first CPU port. This coincides with the previous behavior of dsa_tree_setup_default_cpu(). net/dsa/dsa2.c | 42 +++++++++++++++++++++++++++++++++++++++--- 1 file changed, 39 insertions(+), 3 deletions(-) diff --git a/net/dsa/dsa2.c b/net/dsa/dsa2.c index 4f1aab6cf964..a4c525f1cb17 100644 --- a/net/dsa/dsa2.c +++ b/net/dsa/dsa2.c @@ -311,6 +311,9 @@ static struct dsa_port *dsa_tree_find_first_cpu(struct dsa_switch_tree *dst) return NULL; } +/* Assign the default CPU port (the first one in the tree) to all ports of the + * fabric which don't already have one as part of their own switch. + */ static int dsa_tree_setup_default_cpu(struct dsa_switch_tree *dst) { struct dsa_port *cpu_dp, *dp; @@ -321,14 +324,47 @@ static int dsa_tree_setup_default_cpu(struct dsa_switch_tree *dst) return -EINVAL; } - /* Assign the default CPU port to all ports of the fabric */ - list_for_each_entry(dp, &dst->ports, list) + list_for_each_entry(dp, &dst->ports, list) { + if (dp->cpu_dp) + continue; + if (dsa_port_is_user(dp) || dsa_port_is_dsa(dp)) dp->cpu_dp = cpu_dp; + } return 0; } +/* Perform initial assignment of CPU ports to user ports and DSA links in the + * fabric, giving preference to CPU ports local to each switch. Default to + * using the first CPU port in the switch tree if the port does not have a CPU + * port local to this switch. + */ +static int dsa_tree_setup_cpu_ports(struct dsa_switch_tree *dst) +{ + struct dsa_port *cpu_dp, *dp; + + list_for_each_entry(cpu_dp, &dst->ports, list) { + if (!dsa_port_is_cpu(cpu_dp)) + continue; + + list_for_each_entry(dp, &dst->ports, list) { + /* Prefer a local CPU port */ + if (dp->ds != cpu_dp->ds) + continue; + + /* Prefer the first local CPU port found */ + if (dp->cpu_dp) + continue; + + if (dsa_port_is_user(dp) || dsa_port_is_dsa(dp)) + dp->cpu_dp = cpu_dp; + } + } + + return dsa_tree_setup_default_cpu(dst); +} + static void dsa_tree_teardown_cpu_ports(struct dsa_switch_tree *dst) { struct dsa_port *dp; @@ -921,7 +957,7 @@ static int dsa_tree_setup(struct dsa_switch_tree *dst) if (!complete) return 0; - err = dsa_tree_setup_default_cpu(dst); + err = dsa_tree_setup_cpu_ports(dst); if (err) return err; From patchwork Wed Aug 4 13:54:31 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Vladimir Oltean X-Patchwork-Id: 492103 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 73573C4338F for ; Wed, 4 Aug 2021 13:55:20 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 5AB6960EE9 for ; Wed, 4 Aug 2021 13:55:20 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237778AbhHDNzc (ORCPT ); Wed, 4 Aug 2021 09:55:32 -0400 Received: from mail-db8eur05on2061.outbound.protection.outlook.com ([40.107.20.61]:28896 "EHLO EUR05-DB8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S238488AbhHDNzY (ORCPT ); Wed, 4 Aug 2021 09:55:24 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=DHBdujPe0kyt29coDbXNrXEiYzzdfpdomxiQhVWp62hUAdY99wt9HyCS4pDYZdnhEVE23nEQMfZQhtQ4/lZOJeo/kolGDXAZJxl6VC/Us+hP9K9xdWKfvP5FlRSBizw3hilPQYQkO0QeX2VGlk5oN8ccJdKysQ2ge1UcHqBrlMNxmgEttBR9gpUCr3HPJTr0AKIzoYjQnAOYkVLYe88dIftJLaUx6KT6onQKdbSDPYYzcMTLbOM2nxc2RbP1hbMeI8OxXU0dXNYrEZ0fJuZ6SaQ54qwbTaHF6waZGn6OhaXSMkvl6OBUMGF8ruCcy+R+U+C4MJThLJHJBg1mujyLzg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=amoeNrWJ4532H2p7QkiIVWJGcprWXA9ktT8T2gaXz0o=; b=dqKAvB+94rPFKnV7Gy8akUNsZiTdMlHcg5LhsA/6ggVbEAhg1aDdSYGN7EXSNJMoYUgn8vTF49PcosUH+gTBYqeFhxmkQ5+5sGYswbTsaViuRcvQyWDtg3H3nmwBX1FBJLxGV7BFss/1KNC80QV9TdT7C2iXh8Vx0cLV3QwYfeajdUz7hf3YSoFIovbHCZZlp9TmKD/yZuJHDTd/odMwUwpHkgAuNv2oNjr4K5bB8DuJFx/5pRWfaiGObpWWSEiZCO3noOpYbn/CCZj9LU/WTPL9jLHPFJUo/CzouUSSzv2QLJ5g8Xzvwsn03Zd6csfrdmd6YyO6lDx6/DA0BAtFHw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=amoeNrWJ4532H2p7QkiIVWJGcprWXA9ktT8T2gaXz0o=; b=IR+/+520PTEGLbySITJBxEQI0zOEwUX7RVPk7I+37jdHBAn0ZBjJWPZSNs/O7hpQhD3XCQUUIQbcJ8sHhW9QDqHh4D0WEeYiO0b5HlIDuZ2zLh/eJqM6D4fbT6kqXy2NJ2WpQOvxPIm/+QizZxHfq1suCejlUYI0vIcOAhXkbkY= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none; vger.kernel.org; dmarc=none action=none header.from=nxp.com; Received: from VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) by VI1PR0401MB2687.eurprd04.prod.outlook.com (2603:10a6:800:57::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15; Wed, 4 Aug 2021 13:55:10 +0000 Received: from VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0]) by VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0%2]) with mapi id 15.20.4373.027; Wed, 4 Aug 2021 13:55:10 +0000 From: Vladimir Oltean To: netdev@vger.kernel.org, Jakub Kicinski , "David S. Miller" Cc: Andrew Lunn , Florian Fainelli , Vivien Didelot , Vladimir Oltean Subject: [PATCH v3 net-next 3/8] net: dsa: sja1105: configure the cascade ports based on topology Date: Wed, 4 Aug 2021 16:54:31 +0300 Message-Id: <20210804135436.1741856-4-vladimir.oltean@nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210804135436.1741856-1-vladimir.oltean@nxp.com> References: <20210804135436.1741856-1-vladimir.oltean@nxp.com> X-ClientProxiedBy: AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) To VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (188.25.144.60) by AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15 via Frontend Transport; Wed, 4 Aug 2021 13:55:09 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: e6097801-f3aa-4817-4ad0-08d9574f796e X-MS-TrafficTypeDiagnostic: VI1PR0401MB2687: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:9508; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: wIh1oOXg3KlwYHe5uTPS5Pi5HsJC2JMBaVm+r8v/Z1iBKx+12Q/TkD5FoHRT5YNec+h3cwXG1SLJ9uI4ryv3w7s2pPesK9Pq8v4I4SvDfbOab9BOcO1E7Npm+Oq8zGYOfpCpXdIYapq1PCQB32cPnfZ3NLda8u1jmMdtXWi82j21rWY0YCaDPM/XYOl+CwVrdPY9ZWa5Hu69g/JthI0M4leukDZ38GRhor14PRrqdL87wXbf6X3J3UDGfz/boPVXkgOVVFrlwwIS0R5flNhEz29QdhV5t2B9rSRu2ReBMamZAyxV3GDywVbSr7k84aqCI88SFzE69pTC7PcXZYLUcsb+O2lQV2E4KoCUhqAVoPCvVzEvicTm6OuRz8B0XgamVGHU8Wvj4SZpw/aAwpHWJHBnwqzN9xmbBGiHD4TKzgmoZjUHURskU3n6mNcwFq2qyH4FZSrY82N529L3UPKKCHZxICFnrY9m6opEaP/TfuIdhqfXQ8dweiLXRIlscgBRlW92ZDxYZ0sfZ4+3O35xeSSdS9p0cdd36gDuOsaTVGKa5IpnUZ0gsGtDCvqQV3zdzRK24WvvtptrUrHBvTyo/CJoNdk13qh4JIOMKTab6jBpGVbjXm8Ax3crXhYSv+ZecV9WCK9dbb/5wu3NXqN3dKnzJvtp08M7uirY1OXC0o0MteSGXZd1aCRltoaaEfSO X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:VI1PR04MB5136.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(136003)(366004)(396003)(376002)(39860400002)(6666004)(6486002)(5660300002)(478600001)(66946007)(1076003)(66476007)(4326008)(66556008)(54906003)(26005)(44832011)(38350700002)(86362001)(2616005)(52116002)(8676002)(6506007)(2906002)(36756003)(110136005)(83380400001)(38100700002)(956004)(6512007)(316002)(8936002)(186003); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: PnV73DwaRU4Kg6O0RkAbeGZIm3TSVHDzTRdMI/4/Cv9RKaXAUOeaJc5D/42dVkzV1ShV3ZAnhNev1ZfO3rhWmpQtVBthRYMyqMcvL8/snvvv9PbEhu2DLK6FOkLD5E07uABV6OXcOfmI0dc433eHdVfPyG28BiwvOqCkzaDEPMB3hOA7ev3T165RwOIaNyuXAhhJ4Xr1UWIHt6bYVVdfLmUrsz47ZTF4oHn/huHtAS7sgSZGc/fnMbEdEoGeFA8mKRGIxm4vePrxqGrIlBG+QwnY29J/z9mKH4jGAHb6yxnmKJbRhkPlEFLkR15qJh8zlYl/uog1h0muYXPBxWgVaPeAc1afZxBkaoyvGZWMA7hT48G3uNkQvwwMqqWwZ5JEN1SunkTmN+bS7opz75VwpOw5pBSWR+Ka9DmpKoGwlRXU3uuBxAW0p8x1mMB7Xcg6pLZF3CRAUK+9ykS9Xwb5j8UAUFjxMN3sV7UYRokBk/OVK339dzOzf8q3701QUBiwNDdjlHs0DYO/Gy48G6EZWAueg89LheXYDJB0zx0InXq417i8pLK0GP3wVG6Jr15ZQp7itnGxN471ht1a46so5QPSaicFnvKFJ8sgaOPgavZQOWDS3ZQon2UCmEyixY9DlZOXMRkdAWP6iVXNdrL4WXIGPUB/0yk8dnoI2bY4xgYWvCBLPmeyCnPXGsc25cuBAlXadOrou93YDgQuvMlcnrm/V+Zt2v8QOUlK+wjZzAQqv6I5N43cYgya5Bsqzwnjm20U0KVZb8AhxzZpgNcAJqBk38/P5n9QaHO9Lu2VG8jkdOGnJurEozdVnODRIKt/Ueq6Q9c6C41uJjnRyiODYgfxCLozL7LiymehcbhYesxroCV6DXCHI4IOw2mn5qI0XUEhCDg2pTT2TdGN0xIoKijTu6VmgaDatd9Okl6HP2X1+/a1+4YOKV5uuGF2ejKwDiv/Cm45vcPljk06flXuv11G93ZzfRr1ejWipOx5Bf5K7UAPqSDJp9WXfOvgicN7xyTNMmcljB6VrWRqkt1GDUyVaWPuEpMB1zaux8H1pF6OImVGbbqWR3Vjps63ACGkB2jPhRiVlY/WKJACKlz4K/7j69f67Bewc7aEMe00B6qJYhUaQHiEQTe8BpEvTkJ4Vqq6IT2WtVs0r/o+9QpNuUpZ/Yk7gJbfStip1wkCeGhnPijUFFGLbhzHbYa+lxr17liab3Zkf3U9QwrWOe/M5geF0O8w2qbfVHPYbs3l8xAOrlWFtTGwUSZNCQP4mNexPOWMkS7MytzDlDNpTuqX3yEAd6YWFjMmSgA0k3EF/fQwicr04fM+fgnt60HxKZmw X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: e6097801-f3aa-4817-4ad0-08d9574f796e X-MS-Exchange-CrossTenant-AuthSource: VI1PR04MB5136.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Aug 2021 13:55:10.2499 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: yxrrOpsU1KpdGvaE1eTu8Y4U0JH2GZ62RIQZjPwbw6SdtlPZgrACb4DfimmRd38qo8RGKFRIr7zQkc5oWE0NKg== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0401MB2687 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org The sja1105 switch family has a feature called "cascade ports" which can be used in topologies where multiple SJA1105/SJA1110 switches are daisy chained. Upstream switches set this bit for the DSA link towards the downstream switches. This is used when the upstream switch receives a control packet (PTP, STP) from a downstream switch, because if the source port for a control packet is marked as a cascade port, then the source port, switch ID and RX timestamp will not be taken again on the upstream switch, it is assumed that this has already been done by the downstream switch (the leaf port in the tree) and that the CPU has everything it needs to decode the information from this packet. We need to distinguish between an upstream-facing DSA link and a downstream-facing DSA link, because the upstream-facing DSA links are "host ports" for the SJA1105/SJA1110 switches, and the downstream-facing DSA links are "cascade ports". Note that SJA1105 supports a single cascade port, so only daisy chain topologies work. With SJA1110, there can be more complex topologies such as: eth0 | host port | sw0p0 sw0p1 sw0p2 sw0p3 sw0p4 | | | | cascade cascade user user port port port port | | | | | | | host | port | | | sw1p0 sw1p1 sw1p2 sw1p3 sw1p4 | | | | | | user user user user host port port port port port | sw2p0 sw2p1 sw2p2 sw2p3 sw2p4 | | | | user user user user port port port port Signed-off-by: Vladimir Oltean --- drivers/net/dsa/sja1105/sja1105_main.c | 97 +++++++++++++++++++------- 1 file changed, 70 insertions(+), 27 deletions(-) diff --git a/drivers/net/dsa/sja1105/sja1105_main.c b/drivers/net/dsa/sja1105/sja1105_main.c index 5ab1676a7448..74cd5bf7abc6 100644 --- a/drivers/net/dsa/sja1105/sja1105_main.c +++ b/drivers/net/dsa/sja1105/sja1105_main.c @@ -688,6 +688,72 @@ static void sja1110_select_tdmaconfigidx(struct sja1105_private *priv) general_params->tdmaconfigidx = tdmaconfigidx; } +static int sja1105_init_topology(struct sja1105_private *priv, + struct sja1105_general_params_entry *general_params) +{ + struct dsa_switch *ds = priv->ds; + int port; + + /* The host port is the destination for traffic matching mac_fltres1 + * and mac_fltres0 on all ports except itself. Default to an invalid + * value. + */ + general_params->host_port = ds->num_ports; + + /* Link-local traffic received on casc_port will be forwarded + * to host_port without embedding the source port and device ID + * info in the destination MAC address, and no RX timestamps will be + * taken either (presumably because it is a cascaded port and a + * downstream SJA switch already did that). + * To disable the feature, we need to do different things depending on + * switch generation. On SJA1105 we need to set an invalid port, while + * on SJA1110 which support multiple cascaded ports, this field is a + * bitmask so it must be left zero. + */ + if (!priv->info->multiple_cascade_ports) + general_params->casc_port = ds->num_ports; + + for (port = 0; port < ds->num_ports; port++) { + bool is_upstream = dsa_is_upstream_port(ds, port); + bool is_dsa_link = dsa_is_dsa_port(ds, port); + + /* Upstream ports can be dedicated CPU ports or + * upstream-facing DSA links + */ + if (is_upstream) { + if (general_params->host_port == ds->num_ports) { + general_params->host_port = port; + } else { + dev_err(ds->dev, + "Port %llu is already a host port, configuring %d as one too is not supported\n", + general_params->host_port, port); + return -EINVAL; + } + } + + /* Cascade ports are downstream-facing DSA links */ + if (is_dsa_link && !is_upstream) { + if (priv->info->multiple_cascade_ports) { + general_params->casc_port |= BIT(port); + } else if (general_params->casc_port == ds->num_ports) { + general_params->casc_port = port; + } else { + dev_err(ds->dev, + "Port %llu is already a cascade port, configuring %d as one too is not supported\n", + general_params->casc_port, port); + return -EINVAL; + } + } + } + + if (general_params->host_port == ds->num_ports) { + dev_err(ds->dev, "No host port configured\n"); + return -EINVAL; + } + + return 0; +} + static int sja1105_init_general_params(struct sja1105_private *priv) { struct sja1105_general_params_entry default_general_params = { @@ -706,12 +772,6 @@ static int sja1105_init_general_params(struct sja1105_private *priv) .mac_flt0 = SJA1105_LINKLOCAL_FILTER_B_MASK, .incl_srcpt0 = false, .send_meta0 = false, - /* The destination for traffic matching mac_fltres1 and - * mac_fltres0 on all ports except host_port. Such traffic - * receieved on host_port itself would be dropped, except - * by installing a temporary 'management route' - */ - .host_port = priv->ds->num_ports, /* Default to an invalid value */ .mirr_port = priv->ds->num_ports, /* No TTEthernet */ @@ -731,16 +791,12 @@ static int sja1105_init_general_params(struct sja1105_private *priv) .header_type = ETH_P_SJA1110, }; struct sja1105_general_params_entry *general_params; - struct dsa_switch *ds = priv->ds; struct sja1105_table *table; - int port; + int rc; - for (port = 0; port < ds->num_ports; port++) { - if (dsa_is_cpu_port(ds, port)) { - default_general_params.host_port = port; - break; - } - } + rc = sja1105_init_topology(priv, &default_general_params); + if (rc) + return rc; table = &priv->static_config.tables[BLK_IDX_GENERAL_PARAMS]; @@ -763,19 +819,6 @@ static int sja1105_init_general_params(struct sja1105_private *priv) sja1110_select_tdmaconfigidx(priv); - /* Link-local traffic received on casc_port will be forwarded - * to host_port without embedding the source port and device ID - * info in the destination MAC address, and no RX timestamps will be - * taken either (presumably because it is a cascaded port and a - * downstream SJA switch already did that). - * To disable the feature, we need to do different things depending on - * switch generation. On SJA1105 we need to set an invalid port, while - * on SJA1110 which support multiple cascaded ports, this field is a - * bitmask so it must be left zero. - */ - if (!priv->info->multiple_cascade_ports) - general_params->casc_port = ds->num_ports; - return 0; } From patchwork Wed Aug 4 13:54:32 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Vladimir Oltean X-Patchwork-Id: 492751 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id A8B2AC4338F for ; Wed, 4 Aug 2021 13:55:23 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 8F4CE60EE9 for ; Wed, 4 Aug 2021 13:55:23 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238518AbhHDNzf (ORCPT ); Wed, 4 Aug 2021 09:55:35 -0400 Received: from mail-db8eur05on2061.outbound.protection.outlook.com ([40.107.20.61]:28896 "EHLO EUR05-DB8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S238522AbhHDNzb (ORCPT ); Wed, 4 Aug 2021 09:55:31 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=Xc2Wt1rHVzmMvCcNVP/HgcQo+l2qIZkjSouttZO6u8gRBCZ00/tf9Rzu2OSPkgasJ+y88vw+VcU/qIWm4JStCFSiERH4Hi3PT/LW9H67wNa0qczUrPcBCkh5Z55AuqpOrJn4TF/9MfV0B+DQ67N1Kt8qQ9ndM96ebVxIuRjTRZQZOGEFGgqaTWC851wtQrYjcs7AyHMW1XGaiChuisXLuolNvNvMEQCHr9p13j2JG/KR1R6oNG3Zrs0NMN5JMf3b6b5wI3TUcZeZulcV0qyT8hyo7PssNLRKmTKcPTsN+c94XB97orlMbVTUhGlNpFA0gFt3p1+NNm8gpdfPXrV9Tw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=+FUbX4vC43iGoyFViHGeh8jv2RK37AK+Gwbm2JgVWoQ=; b=Er1tUy5ZeRpdMvu4EoHnHvPRpvK9AE0bF9/jDIAllUAeQRSSURaUm7UiLJPfnwTfG2gNYI/kF6BuaDMqK61KrIrrPEPR1uCTyvsdlqaZLIUUpUfpGPfu26NWdmnGCRN0yzxed5CWiaIfTWy61dSuxw8t7eB+Olfd4Rjoc3nZTQ8IhwePdkvoUUoG5V6xy5+KmhKKhgyhggA+mAlASPaZkqSnjamk3EuJ507gxKm5meR0wzTDUdSHcDRwNJu+E+zTedVSd7O+tSnxvWP4EsFFMlvY5qfpirlnElP8tOhwiXJPnfZQTpwr3A7I9gZ0uuPz84p84mPBvyJubzHtbuMHRA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=+FUbX4vC43iGoyFViHGeh8jv2RK37AK+Gwbm2JgVWoQ=; b=nlmJmBaX4mfJL8Cdpdu4VEefDY8Lhuf57ZCM9efZA2aH3ATA5MkUnah8fDXuzDyFnlKOzZKiDzCkUZPRD17ZBwLgS2fFiyhXJ4iDbkpCI50H39RHpUpVaZIDq8xIgHpfD24JhIpoTYtMj8KcsYmCYWE1o7mTB/stOXYnqxPtrYw= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none; vger.kernel.org; dmarc=none action=none header.from=nxp.com; Received: from VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) by VI1PR0401MB2687.eurprd04.prod.outlook.com (2603:10a6:800:57::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15; Wed, 4 Aug 2021 13:55:11 +0000 Received: from VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0]) by VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0%2]) with mapi id 15.20.4373.027; Wed, 4 Aug 2021 13:55:11 +0000 From: Vladimir Oltean To: netdev@vger.kernel.org, Jakub Kicinski , "David S. Miller" Cc: Andrew Lunn , Florian Fainelli , Vivien Didelot , Vladimir Oltean Subject: [PATCH v3 net-next 4/8] net: dsa: sja1105: manage the forwarding domain towards DSA ports Date: Wed, 4 Aug 2021 16:54:32 +0300 Message-Id: <20210804135436.1741856-5-vladimir.oltean@nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210804135436.1741856-1-vladimir.oltean@nxp.com> References: <20210804135436.1741856-1-vladimir.oltean@nxp.com> X-ClientProxiedBy: AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) To VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (188.25.144.60) by AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15 via Frontend Transport; Wed, 4 Aug 2021 13:55:10 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 4caf1cec-5f89-48e9-b59e-08d9574f79fe X-MS-TrafficTypeDiagnostic: VI1PR0401MB2687: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:9508; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: Xq/4mclmAlbx5jCGlQz9N9CEnpxnG//0iPJlxL95SiSEBzz/NbWQVSDtH+xJVwRjjtiUqawsq+pH1R7PI7zDyEavW/hqLihYiACvryFMvVd1ZKGMmGw9xD77gG5N19jnXr5RLysMa5OFrwtyJCX/k5AYFi59CtZ7joCCc3Ck+m7ksrGnJiNCvIvTcp1lwfCzz4CJfElB7Mvol0FmRnEhnMKsXGf/Q5Bw4STFzUuynb8UEe9xm5gjF53SSlPoTmE1k0w6vIsf2qhClAMQDvGLj+R6h6vP5udq1wVOPI5OE5lGuvGCccft6P83roX2bMwMm6ucjvOTpYrwVUD+0n0xEN/yRw5nMmjyfm2Nn8+enOoSJLADgJglxrItc3DPIdTbFX+2Hzjss1Fc+9ba2C7iQlr+OKi9/eX6he4vAhjI+Ob4TLf803SBGecwkNSmKinYURURJdU0SRAFuIyk4mKhOdtMyGetAA+mu0wYwClQvui8LtWG1LTmHwwCEKZQPssSW9K33lKVmHOK/AKAR2f/nr/NNl5E7LXK7CCQAbx/BVfkWK6vzIsKzgmWoxqChqIFYZD90sNZn5wc0eeKd6SdvtCAuElRSqb/YAwZMvBNI4CovhqylZb3qTu5u7HGXIbQyswhsdSrwbSssf5ImTT9Y1/6ja9Qz7W3gTvJvRFmYaZpml8V1Uz2wMau/Q/Ey6sS X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:VI1PR04MB5136.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(136003)(366004)(396003)(376002)(39860400002)(6666004)(6486002)(5660300002)(478600001)(66946007)(1076003)(66476007)(4326008)(66556008)(54906003)(26005)(44832011)(38350700002)(86362001)(2616005)(52116002)(8676002)(6506007)(2906002)(36756003)(110136005)(83380400001)(38100700002)(956004)(6512007)(316002)(8936002)(186003); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: GlK0CTl28Qj8NU4sj3xYb5+ir2b0ajRVubkrPBqFSNo7+0A4NW6EUE7q3IKnMlQ/GcZtSdNgYd2dFR25ptiuer45c7yuTHgawpgjobZ+4Ww8NifMI2VqdKOGQI0FUnLjLKk1vytzgHl2hnxHSA7pV19zEkXWRnzYZgp5edb0+XrIFhcI5B67nR4hKZLyyssy4npro3/FuHrFxQbPOiBOlBvMcSUWpicfw75jXcMtw3twSsettxMTt0yHz+Nek7owLQuKx0YkObu89Ln0aqecSwIZQ0ke0ZcASNnrlRdxdZDltiJdFQxEToOgNOYGNfZr3NITAun+pE5g3x3oXY1ovl8zNp11T4lA51EglvbPu8yySq/YiNnvSdUODkw7qB2M9wmh8BpZHLf3XDFgRFYw0ZxHzp6FIReTxbGsNnaQiaGqBpLg/0X96O1iuGZa7KldvZ1ZgMwuIuVQ4514Vu7hsJn9G8pSENww59vhu51gxYT2gQn8MhFsR7fSESNW3ZsUnY8+81m7zYFyfj+6mVFXCtaS55nTrAasHlvFkWYkGaVwH095mNDDv5cuWlcYAqPovmisOyylZiHpXc3go1+iP1dCWsCLakFYJ7n1uW8UceGsGb2vNRm+LTA0PuOD8ugbsWaT4jxCKMuTOi8VgZYSHLK9EA6zhZ5Fl/EJgm2H+szC3AKav4732kYWxCiZGVM9CkOtp+rmKg+AUop14ImoiE66Of/5tNbyQbBb9iy/fczJGrcQwthbTL5KQy7ViQHN8zc2+anqmbbGZnQchdAulNenirfnuKqRUhZ/a0a0jbaH4RbvLC1nHn2OlqYqNdpxOqRBbcs595jgWr3ng3Q3CDQDd+cMrkZtH+TL5JkBCT6DugSDS8FiZGaezNbqJZz311cBWo/h9CkzWPl8Hb/jWLyh2SuFwL06uASl9TRhYabWZTOeo46AQCwMuhlJcHgegVKo5lFPalcwCjN0umTiQHfJZUSzdziF5rPPMCVK176/spab19sBNCxF3qx5I5+pNztfy7kCetSkyDDsOKhGXs845wRuE/OsOU0M7xucwY4WKZvOrkvuHI2TslQ1Yzu6pVJrEhHIlDilEf4hYP5TXkDnzj7LOJQE5U+s3jrdEHTo/UIQ27Zz2fQCMFigJHcxCtfH7anBgK3iIdZIX4UK8I/1t/7Mip9/Kgqa0asGxmUk6NiKNNjXyhbMTH7vtZDHa1GEvYeUr+ex5ejZLTRz4Tlu0/eWP2VpcpTXd/49rceV3nCmq7cNj/vTeUgyFsa0TN42uGXndJ0mwnh6aLdML0OoASaJ6UbheXqAnhLubpEeUhNtGjlP1LSMGCs6Ja15 X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 4caf1cec-5f89-48e9-b59e-08d9574f79fe X-MS-Exchange-CrossTenant-AuthSource: VI1PR04MB5136.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Aug 2021 13:55:11.1893 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: rvtSgP5VWL18dEP2Deomz/yUmR08P9Vy3XTywfWwn17tExBabEC4XU99c0B9aPY01bcHIxWCeBdkcJFOXS5HHw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0401MB2687 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Manage DSA links towards other switches, be they host ports or cascade ports, the same as the CPU port, i.e. allow forwarding and flooding unconditionally from all user ports. We send packets as always VLAN-tagged on a DSA port, and we rely on the cross-chip notifiers from tag_8021q to install the RX VLAN of a switch port only on the proper remote ports of another switch (the ports that are in the same bridging domain). So if there is no cross-chip bridging in the system, the flooded packets will be sent on the DSA ports too, but they will be dropped by the remote switches due to either (a) a lack of the RX VLAN in the VLAN table of the ingress DSA port, or (b) a lack of valid destinations for those packets, due to a lack of the RX VLAN on the user ports of the switch Note that switches which only transport packets in a cross-chip bridge, but have no user ports of their own as part of that bridge, such as switch 1 in this case: DSA link DSA link sw0p0 sw0p1 sw0p2 -------- sw1p0 sw1p2 sw1p3 -------- sw2p0 sw2p2 sw2p3 ip link set sw0p0 master br0 ip link set sw2p3 master br0 will still work, because the tag_8021q cross-chip notifiers keep the RX VLANs installed on all DSA ports. Signed-off-by: Vladimir Oltean --- drivers/net/dsa/sja1105/sja1105_main.c | 84 ++++++++++++++++++-------- 1 file changed, 60 insertions(+), 24 deletions(-) diff --git a/drivers/net/dsa/sja1105/sja1105_main.c b/drivers/net/dsa/sja1105/sja1105_main.c index 74cd5bf7abc6..66a54defde18 100644 --- a/drivers/net/dsa/sja1105/sja1105_main.c +++ b/drivers/net/dsa/sja1105/sja1105_main.c @@ -475,7 +475,8 @@ static int sja1105_init_l2_forwarding(struct sja1105_private *priv) struct sja1105_l2_forwarding_entry *l2fwd; struct dsa_switch *ds = priv->ds; struct sja1105_table *table; - int i, j; + int port, tc; + int from, to; table = &priv->static_config.tables[BLK_IDX_L2_FORWARDING]; @@ -493,47 +494,82 @@ static int sja1105_init_l2_forwarding(struct sja1105_private *priv) l2fwd = table->entries; - /* First 5 entries define the forwarding rules */ - for (i = 0; i < ds->num_ports; i++) { - unsigned int upstream = dsa_upstream_port(priv->ds, i); + /* First 5 entries in the L2 Forwarding Table define the forwarding + * rules and the VLAN PCP to ingress queue mapping. + * Set up the ingress queue mapping first. + */ + for (port = 0; port < ds->num_ports; port++) { + if (dsa_is_unused_port(ds, port)) + continue; - if (dsa_is_unused_port(ds, i)) + for (tc = 0; tc < SJA1105_NUM_TC; tc++) + l2fwd[port].vlan_pmap[tc] = tc; + } + + /* Then manage the forwarding domain for user ports. These can forward + * only to the always-on domain (CPU port and DSA links) + */ + for (from = 0; from < ds->num_ports; from++) { + if (!dsa_is_user_port(ds, from)) continue; - for (j = 0; j < SJA1105_NUM_TC; j++) - l2fwd[i].vlan_pmap[j] = j; + for (to = 0; to < ds->num_ports; to++) { + if (!dsa_is_cpu_port(ds, to) && + !dsa_is_dsa_port(ds, to)) + continue; - /* All ports start up with egress flooding enabled, - * including the CPU port. - */ - priv->ucast_egress_floods |= BIT(i); - priv->bcast_egress_floods |= BIT(i); + l2fwd[from].bc_domain |= BIT(to); + l2fwd[from].fl_domain |= BIT(to); + + sja1105_port_allow_traffic(l2fwd, from, to, true); + } + } - if (i == upstream) + /* Then manage the forwarding domain for DSA links and CPU ports (the + * always-on domain). These can send packets to any enabled port except + * themselves. + */ + for (from = 0; from < ds->num_ports; from++) { + if (!dsa_is_cpu_port(ds, from) && !dsa_is_dsa_port(ds, from)) continue; - sja1105_port_allow_traffic(l2fwd, i, upstream, true); - sja1105_port_allow_traffic(l2fwd, upstream, i, true); + for (to = 0; to < ds->num_ports; to++) { + if (dsa_is_unused_port(ds, to)) + continue; + + if (from == to) + continue; - l2fwd[i].bc_domain = BIT(upstream); - l2fwd[i].fl_domain = BIT(upstream); + l2fwd[from].bc_domain |= BIT(to); + l2fwd[from].fl_domain |= BIT(to); - l2fwd[upstream].bc_domain |= BIT(i); - l2fwd[upstream].fl_domain |= BIT(i); + sja1105_port_allow_traffic(l2fwd, from, to, true); + } + } + + /* Finally, manage the egress flooding domain. All ports start up with + * flooding enabled, including the CPU port and DSA links. + */ + for (port = 0; port < ds->num_ports; port++) { + if (dsa_is_unused_port(ds, port)) + continue; + + priv->ucast_egress_floods |= BIT(port); + priv->bcast_egress_floods |= BIT(port); } /* Next 8 entries define VLAN PCP mapping from ingress to egress. * Create a one-to-one mapping. */ - for (i = 0; i < SJA1105_NUM_TC; i++) { - for (j = 0; j < ds->num_ports; j++) { - if (dsa_is_unused_port(ds, j)) + for (tc = 0; tc < SJA1105_NUM_TC; tc++) { + for (port = 0; port < ds->num_ports; port++) { + if (dsa_is_unused_port(ds, port)) continue; - l2fwd[ds->num_ports + i].vlan_pmap[j] = i; + l2fwd[ds->num_ports + tc].vlan_pmap[port] = tc; } - l2fwd[ds->num_ports + i].type_egrpcp2outputq = true; + l2fwd[ds->num_ports + tc].type_egrpcp2outputq = true; } return 0; From patchwork Wed Aug 4 13:54:33 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Vladimir Oltean X-Patchwork-Id: 492102 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id E816FC4338F for ; Wed, 4 Aug 2021 13:55:26 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id CBD1560EE9 for ; Wed, 4 Aug 2021 13:55:26 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238532AbhHDNzi (ORCPT ); Wed, 4 Aug 2021 09:55:38 -0400 Received: from mail-db8eur05on2061.outbound.protection.outlook.com ([40.107.20.61]:28896 "EHLO EUR05-DB8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S238505AbhHDNzf (ORCPT ); Wed, 4 Aug 2021 09:55:35 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=ar7F0iyxWqnZ4KtzJGPkHENKfYFFSThn2XMRlmpBif/76QdJDBBO9bzZKyPThD+D+8RWI5bBCYH3V8aTukRshmllAfdXhlo02X1I/40I03rQed98w29122MTFLax7f3shOdIqMomC1es+ckJAyCdFyUaLKcnm+h5nJXPVCI2Sm2gK1QqkaJdQOWZS62/CgeN37jT15uCtfm8hJPPuOc+t4eBgD1hGv1+TrX6SeyMsebf4FQC9aBJpxUsxjQW1kWKz2udwF21nsupC9qwEem4VwtReyx6Pvbk3uO3odLXqhUQDKDs248miV0WQcpP0h0QjgyxSlGAytze1iSt9CBHkg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=HwI0jm+ZWgmCnORWmGh1d1TegTIKQ6d1GNKUNNMaqnI=; b=If0X3elQROAAfdDrNpWILSw7iR2VpyLChfqpEuE8G6rkKsJYu6bLtcffF8KjN4mOGfYvSs+GwXDTvDYSmdxh/MR8YmMHB9xofdSyDFQnHvIjIeK9EsABm3Unz0luBLQQeUpigJldamKMGx795rcBJOCFfU6CsH1m1EU7/ZhNO9gG0F0kBQITdXv27nRPwWfAsbIcyI5x9rrndJNEb6lAXWk5w0SFCCrkC+ZXwJVQ25OnurETGsiw85zd3OlOExusGn+6ZL1zwC8/CVdW2gwkJpDrBNjW/uDmM5OhJIqnk0J5sfj8lx6Q/f4FH9K8XDMFtwae0Xp5uMIeUeToubSE/Q== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=HwI0jm+ZWgmCnORWmGh1d1TegTIKQ6d1GNKUNNMaqnI=; b=SDJ2Oz57qiMoIZu7RsdAuQwxfl0lAtlBHNv2FsmGOMbg3J+NQkiplWZuji0dRMKAUPPDWZNdK2uP4gT6jaMUzm+AGH3uOsMrd3+y3qLeQEBp1Sr2IQbBVnSpN/7u3fCjxaRAFc2kz0/OHWthZXqhck8wjCmX/C0GscJPoP+wIls= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none; vger.kernel.org; dmarc=none action=none header.from=nxp.com; Received: from VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) by VI1PR0401MB2687.eurprd04.prod.outlook.com (2603:10a6:800:57::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15; Wed, 4 Aug 2021 13:55:12 +0000 Received: from VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0]) by VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0%2]) with mapi id 15.20.4373.027; Wed, 4 Aug 2021 13:55:12 +0000 From: Vladimir Oltean To: netdev@vger.kernel.org, Jakub Kicinski , "David S. Miller" Cc: Andrew Lunn , Florian Fainelli , Vivien Didelot , Vladimir Oltean Subject: [PATCH v3 net-next 5/8] net: dsa: sja1105: manage VLANs on cascade ports Date: Wed, 4 Aug 2021 16:54:33 +0300 Message-Id: <20210804135436.1741856-6-vladimir.oltean@nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210804135436.1741856-1-vladimir.oltean@nxp.com> References: <20210804135436.1741856-1-vladimir.oltean@nxp.com> X-ClientProxiedBy: AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) To VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (188.25.144.60) by AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15 via Frontend Transport; Wed, 4 Aug 2021 13:55:11 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 3e2c3ec1-0a59-4d4f-afc8-08d9574f7a8c X-MS-TrafficTypeDiagnostic: VI1PR0401MB2687: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:949; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: o+vHxeRtd2OQu61nrmCa+wX7OMkoTsrQ9EqR6Xo05ICKUOeMH9F+fMcQawj+TqDPatxpFH9GTv6APlq6EeTMuo0zY5qEHMUOS02SFWtOdY4gzoKcoUaAEerhUcObHrqjzXcw/MHaO8J/crK+sRw8dgzDu4VsFawCAHC7lzmBZP0Y1NXTw69M6KYh61S7/Z5KEeXdJUCXW23iDxUt6mpfUGsh8cZF0fUg9HBBxGscqPwCjtWfxE9Cq3a9qMaoanl8kLmq1fNndk3D1ZZ2DKUaUBwwNhU68WO3vL0XO/6CQRF9qtx2/U1b5/fr87KArfG/yUJUplq8thiSrRWmSFaKne3Y2Ya0hhzFXmwTMRP9FpVJLcwz4pe7sPxohkiz3v4hfUPcNsK2fQRIYY82ZPiuuzUq6KxndcLx7AnKVaiYo2Yqk4wxsTc1+egRz9+ccqQxD+ecdgDF6C2RpWPihR9sQnzzCDNp2LsOcxKvq2mW6GqV7GaNIwY69VCwMAq3VPtF1t7HiAYPta89TEogyoEtzoleyltIvIgRW98PQBwlB//NIPDvi1Z1fih1bfm3Vr8zmzsUifyQhWYyxtht4ty+nw++FR550okavgo20Wup4AKJZHs8VsW0UDncnUylVnbpdQ/m0UnmTUwG9kSiroXSUFnWySfdLw17tRuIWpx4uCeWw+6E/ePK7cxr2DCtJdToUY6dSfvMQaRqxRErXLvSnQ== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:VI1PR04MB5136.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(136003)(366004)(396003)(376002)(39860400002)(6666004)(6486002)(5660300002)(478600001)(66946007)(1076003)(66476007)(4326008)(66556008)(54906003)(26005)(44832011)(38350700002)(86362001)(2616005)(52116002)(8676002)(6506007)(2906002)(36756003)(110136005)(83380400001)(38100700002)(956004)(6512007)(316002)(8936002)(186003); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 8pU6mvkvvdudiSQ4NRDI/dhh62m2Fgx/i8NJTI4wRdxxYmcu2+nGshST5AerARJ1mZN/jSrvQC4dkayg+De494qEh3IydEzMGMOMTdDFuvf515lnINH4Gi1RGvF2KoeckjNcr8BXGlQM+iVBWNhrVYgny7lvc4NOK7GPcN7ou1+DT+ZQt1h6bYHeq5zqSERkHO72EBrQrlWMOxCpjEwVxid9dN20AkKKgk9x/jMMFN5FK/qJJbpoVtN5zklimGeE4tCS/HBR8HtDTbLBfKitsl3DF7n79TF2nZfJnHJ5a7KI5aA8fxPdBjvP8QQ+UW6GKmuW7nPZYVRrtE8ovQh/cQ86BAOibGSnqHexOvJyG4Lgqg2uMMwQhI2NyDs5Q/6CQq9cajxv/OnUVPfU/UI+aUWogWT+CqqdLJKE8ZsfWuDsDVUd/aX0AAH6URNxapi5nXM2xd/FUT+WvQHH9JePcLiKVDkH4Y6QhBssybxAScpGq64vhsFpp+Bdsx7Y7Ym6M3WagDIZQZ3t5mqIr9Weig2g2n4ES5h7EqKDKKV/Ykj4kwLBsC/qnGLNVMBG6z5WrUHVuDyCMLPL7TXax/WU3CcsnKwCGFxDzbB2FdRirlFjvk6gwBwbm+ZOHeneqhCHQRfZa9bfQPDRrEMKYrurG9UdhdGZuYBmi00ojGcbNfUicCLBL+On/KOrS1c5uf1Kc+AVTmLCwXW6OvSCh3V+hCQhKaTgvkmzeNgIhqWIJOfAeaQFt8LXOBEti+aGaGRpNokqUwmiJ+OhZpu8zPK5yBjRbyHGKVW4+GAVIO6KBTYvvCOvXBDIgQq9YcJbXChwEMb6xG2Fqs2eESReav6M/pz6FrnjPliyzFMVBgx/nucqsPypInuY76M2PRttAqTFSOrQCeU7NeodE9Uuo5ZY5/zZ/PNf4IRUkpRwu2UIJSj3AEobJKjafLjokSngFPLBEU4n/fKW5aBjB9YZs0gkCQ9P5/hkFAL7PNqIaZbovFMIJH15z1fEiTqSPSdJMeTCl13NQKlL2eqSc/Pr0Ty9kdP5Uti/UaHrbtgNmTwbUO2cQGBIH8CUe5bAH8KVZOmldvGxcuYjpyDg6VLMxYzX6axBmOL9UFTTCylh44zP0gaTD6sNLgg6WCl9binXEAqsqZF++BIIlaTalAG+blbMSiZSrb5uXbAfYj7wvNV5T4RvrcfBBNPTAnP/F8zzb5O+eA2HpC1/RfqNBkvSIdfQ+PRkpBFvbg2Kgw0O2Cb9SQdIcr1qhuFoag14zHS6gOwYY/wQHC8Pqk9dw/HguH1rObKAh5Kz89GzYlm30giUqZrGs236NM6sc1djHLsyMdFV X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 3e2c3ec1-0a59-4d4f-afc8-08d9574f7a8c X-MS-Exchange-CrossTenant-AuthSource: VI1PR04MB5136.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Aug 2021 13:55:12.1178 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: YWi0oRTG209Vzq7lqx4BmTChx4pielAJnh7iLS+rxqAN3eVbnf4ussIvWxqI6Ny0PsQB9TKLb25KFFd10jRLJg== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0401MB2687 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Since commit ed040abca4c1 ("net: dsa: sja1105: use 4095 as the private VLAN for untagged traffic"), this driver uses a reserved value as pvid for the host port (DSA CPU port). Control packets which are sent as untagged get classified to this VLAN, and all ports are members of it (this is to be expected for control packets). Manage all cascade ports in the same way and allow control packets to egress everywhere. Also, all VLANs need to be sent as egress-tagged on all cascade ports. Signed-off-by: Vladimir Oltean --- drivers/net/dsa/sja1105/sja1105_main.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/net/dsa/sja1105/sja1105_main.c b/drivers/net/dsa/sja1105/sja1105_main.c index 66a54defde18..d1d4d956cae8 100644 --- a/drivers/net/dsa/sja1105/sja1105_main.c +++ b/drivers/net/dsa/sja1105/sja1105_main.c @@ -460,7 +460,7 @@ static int sja1105_init_static_vlan(struct sja1105_private *priv) pvid.vlan_bc |= BIT(port); pvid.tag_port &= ~BIT(port); - if (dsa_is_cpu_port(ds, port)) { + if (dsa_is_cpu_port(ds, port) || dsa_is_dsa_port(ds, port)) { priv->tag_8021q_pvid[port] = SJA1105_DEFAULT_VLAN; priv->bridge_pvid[port] = SJA1105_DEFAULT_VLAN; } @@ -2310,8 +2310,8 @@ static int sja1105_bridge_vlan_add(struct dsa_switch *ds, int port, return -EBUSY; } - /* Always install bridge VLANs as egress-tagged on the CPU port. */ - if (dsa_is_cpu_port(ds, port)) + /* Always install bridge VLANs as egress-tagged on CPU and DSA ports */ + if (dsa_is_cpu_port(ds, port) || dsa_is_dsa_port(ds, port)) flags = 0; rc = sja1105_vlan_add(priv, port, vlan->vid, flags); From patchwork Wed Aug 4 13:54:34 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Vladimir Oltean X-Patchwork-Id: 492750 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 2FF45C4338F for ; Wed, 4 Aug 2021 13:55:30 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 1754460F58 for ; Wed, 4 Aug 2021 13:55:30 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238527AbhHDNzk (ORCPT ); Wed, 4 Aug 2021 09:55:40 -0400 Received: from mail-db8eur05on2061.outbound.protection.outlook.com ([40.107.20.61]:28896 "EHLO EUR05-DB8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S238488AbhHDNzg (ORCPT ); Wed, 4 Aug 2021 09:55:36 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=hI0GTJHlXIxOlvxr3CwNtA6sfOpz/AZAriutJbEYvXtGE4ay9mxX1p986d2DxRgZ5oH41B+dYCIz03SdOkbUb3UHN/JD/KyKApYd/u9Fx8p9eH4MMcCSRiUo9+cMPHV2geMaMrgSNXOWUp4hOj4ox39+fYKjvxiCWNLS10xWhC5dz0/6vMJDvf7QwtusN/GzFEbuUC44jNgVC+85vp7MYBlBfUkMjJ8hRzbvuBq1DPfPMaRn9gR6pWnxYDJxNfs2Gt3EAIrUjCwKYrQFGCHWqUHIp5NV91I3MvH6sw3oelOiG2yx9QHQLIG1xbx0au3HFbM1hVKHtdbAxFNT9zHsAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Xv8psI/5kz8emCRqcS+SdgKVUIb5qDFIY0g5PQAGfMo=; b=IZFYsRMOEuvgYFapiSvyyq6kGDWhwCml2Ke9zRZ+UoVq/bG9PD7GKD7dkK9kp9+ID3lVBA7XX7wP1rGGvt+kQ4mXREFFntYTL4wAUKjLEMfisbgI+t3IOb55kheUvW7SjIvMpZ6PRrSqi3dW8f5W7fGYXHFiNWaEiujBvwHQJJ/pYEp/gwSkyI/dT7yVR+dnVVwrcgZqydmXiDUjMd9Gh6ixQ4Z2hlADQ1MUWiAPRCKEOmYeBlNndDfoiUpcJCD/O870wm4IUxStio/90SohutD+2yXAT88JxM61+1DgQB5DVog5TzHAktszCr0WpuEcpTQSfK+KlEA5E9Hi9teDyA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Xv8psI/5kz8emCRqcS+SdgKVUIb5qDFIY0g5PQAGfMo=; b=LW8+bgWx0NoNCvNnFw2iudFHcKG25FC0Sgo1Alkimpftd0LfhcBc8ZwSLT89Y5O4Yh245qTbjmg4K3uTlsvjCLWsAI4febDJDZJdBTJ70colRTUTi01Da7juvz1JxGB7auDAZAtWeeygHVaeUUMwHJpT6EJD4L2v3oIeMteBEXo= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none; vger.kernel.org; dmarc=none action=none header.from=nxp.com; Received: from VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) by VI1PR0401MB2687.eurprd04.prod.outlook.com (2603:10a6:800:57::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15; Wed, 4 Aug 2021 13:55:13 +0000 Received: from VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0]) by VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0%2]) with mapi id 15.20.4373.027; Wed, 4 Aug 2021 13:55:13 +0000 From: Vladimir Oltean To: netdev@vger.kernel.org, Jakub Kicinski , "David S. Miller" Cc: Andrew Lunn , Florian Fainelli , Vivien Didelot , Vladimir Oltean Subject: [PATCH v3 net-next 6/8] net: dsa: sja1105: increase MTU to account for VLAN header on DSA ports Date: Wed, 4 Aug 2021 16:54:34 +0300 Message-Id: <20210804135436.1741856-7-vladimir.oltean@nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210804135436.1741856-1-vladimir.oltean@nxp.com> References: <20210804135436.1741856-1-vladimir.oltean@nxp.com> X-ClientProxiedBy: AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) To VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (188.25.144.60) by AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15 via Frontend Transport; Wed, 4 Aug 2021 13:55:12 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: d427bd64-1d90-473b-4e73-08d9574f7b20 X-MS-TrafficTypeDiagnostic: VI1PR0401MB2687: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:7219; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: DT2VcfJHlQtGNoaln77xNrPUdpuUkqv1qk/cEg56xOkPS5LNOdW2g9S96JmrTWX38Tf0mpRvCwGQPgBXcKSYV16IBnnRmH6OkGkqsh3/QFhAM2hqnDqzZiA3etaARrfNQ0jE0QhNNbk3CbR7Kd0+3wIaIiB3VC6BYqDcpPkrTSHSy5aqgr/oRV6RPtYrrjxA5x2+GBgmReLpSnWdZKaZGXfZN1Gc23OaTwezQ5cXNX/ryH140X5PlLqzUDxif5gK6AmYDOzmICHb3Hv6UHeIWaaX7mKJXlBcnIhVl1Y2+b+bbJNRu/LHcEqbNC+nj7tg9jMmcRc0aoyndnVfqhdo14lqAdSfM6VClAr0uSWYiA3dpVj6JOnAt6+DqoFxOLkC8Iz7uJhqU/z8kyPMjxP66AgFU7T4BQA08p3iyltcW2nuwGEaGJ3kHcdCZMOUXNsko2zgg0E7v52/lBvyR3SrKIdTToZG32aOLIwq37HV/VX71wJViCJokZ68IQIgJivT/NwJ4QM+alXh8vPgp/jONlDyUFadybLnWCLJu1MDyZhsqn9qz99HZ2C1B0wZFUvswbfi5Xk5bZcFJvcEfTpN9ILs1KTNjQ0G0QUAWTgPUKXUtJCNnizzBHbaoW5VypSATa1cXV4m6iVoL8UAyaxuCXw7s07RIXNJb2pSiWms5+kY3m8Jg+QOig3OQdu70j95XUR71W8qW7BeQwOnXA3PbQ== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:VI1PR04MB5136.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(136003)(366004)(396003)(376002)(39860400002)(6666004)(6486002)(5660300002)(478600001)(66946007)(1076003)(66476007)(15650500001)(4326008)(66556008)(54906003)(26005)(44832011)(38350700002)(86362001)(2616005)(52116002)(8676002)(6506007)(2906002)(36756003)(110136005)(83380400001)(38100700002)(956004)(6512007)(316002)(8936002)(186003); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 3f5soSLopc544VgatZlKG/JDIimonlEyB27Jma7vD8h9Yk7dCOZeZ+VlttoGjD9qdxoge0QFDKrfNcj7Aa1drCaNk14MdF8RmJlLkbWlctg/wEZxS+dHX7qHbjqsUoFC9nRWvi71UPYHRLONtbc9UoV+aaPRJ7kxVnyXqPjZZlLCIBiK3gxY39g8hFVaGh4I0bgAfkbGev+CZBMsBLPX1gArBMHQbShg7JVu7NMBsn32kVF3q/HEoBaGeiaZysb7UTMr5y5iomKpjjkL23bE7ck1qbmNopvJgPr3OqXwNKIWdc8jL6I0WfnAraiAe4SoOPDe+ogaQdt67MrvOs4dH6kk5sdL4BalxNc3b6tquz3RCKdxw0jfSn4vSrSUie2EdbUiMtKQuysOXqAgJveloy7Hsf6nV7+afztkJJFK4+PVu33voZsQMoZ6ii8KtpooVYCAmTlgD4qoA/XAp2bgJS63uhAX2tsL7Z2v0vnfWDsdZjXuuLLr+z0anOAXOxdvKRvosae2h34NC/U3K48Iu0xZbOrXCIVzTYihT0Ycl/frvmNiaz/ML/liEt6rKJMdQx9CT7UrB6m9pgBmrNFAKRgR8RjWc19LipfAC1ztdgw/ILg6IS2C9ZfHFBKgKruf992V/Cb0r8YPe3Qle6o4BiB9IhVMuiqpEuYF0kp79WFBNWHkZaF0CawNLHpZJppEmWPh8LhUhUbxuz4uJLiedvypY6gGBK3VJA34ddathyAqO5J62ZEZQPlbtnFbSmh+j2PbekwekxeNxq//AYCz2fQSBRPyIhuaj+Fl4cbdBMZ3jvIqc1AtIlFjc5SdhSEFCKlx+w+NIG6QSv8xOj1qIvjnshbzznp9Z0AFPRpDIT/1jQc29YWUc1JYKq9bblCOJ6jDDYrA3PVoDApSH/9kg0UlH+bb63EpIYd5kLxS2v48PkpvaiewQ1MBLDxJcvAR57CMsvIVMz47owVu7eDN519yI0MfcM83OP+1xbI7/QfzS/vkS8mcOF0rUwlirek+uLIQo4CXUUGv1g+y+4S1iptVThaG/rlmSEv2dmOXUyvxcdWtuDA8o6GYAM33H+m0DeUhXl+/A/PKu9J85jd94fVWUa7uFFZV+ygkT/1iVVQhSY/0mCGxQk+UwAwR1rvUUWRNTPCvbR6Ed+XoyOl/ZydytE09U1XR0n+80HnSmYrcY53a9nsvzkW16fVyCmiYnwEGjByxDKIIhYEnHWEuzNAxFdBB0bX0zD5OK/5YzOWl3sYMXydeNZJbzydPWlzSK1DYfREQPcrv13PNyMmizkDY7ckLZi5HHRujKJzJMAPUqiPHCJyp7UE+B5qlaI36 X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: d427bd64-1d90-473b-4e73-08d9574f7b20 X-MS-Exchange-CrossTenant-AuthSource: VI1PR04MB5136.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Aug 2021 13:55:13.1162 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: utbzvMeQIdubcI1qE0RZcc6+PMSHwh+ZPFRXKPJG3On8ER/jNoQqoa9WG74nG2WI+UooeqSIgRXBgqxUfGOlMA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0401MB2687 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Since all packets are transmitted as VLAN-tagged over a DSA link (this VLAN tag represents the tag_8021q header), we need to increase the MTU of these interfaces to account for the possibility that we are already transporting a user-visible VLAN header. Signed-off-by: Vladimir Oltean --- drivers/net/dsa/sja1105/sja1105_main.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/net/dsa/sja1105/sja1105_main.c b/drivers/net/dsa/sja1105/sja1105_main.c index d1d4d956cae8..fffcaef6b148 100644 --- a/drivers/net/dsa/sja1105/sja1105_main.c +++ b/drivers/net/dsa/sja1105/sja1105_main.c @@ -982,7 +982,7 @@ static int sja1105_init_l2_policing(struct sja1105_private *priv) for (port = 0; port < ds->num_ports; port++) { int mtu = VLAN_ETH_FRAME_LEN + ETH_FCS_LEN; - if (dsa_is_cpu_port(priv->ds, port)) + if (dsa_is_cpu_port(ds, port) || dsa_is_dsa_port(ds, port)) mtu += VLAN_HLEN; policing[port].smax = 65535; /* Burst size in bytes */ @@ -2664,7 +2664,7 @@ static int sja1105_change_mtu(struct dsa_switch *ds, int port, int new_mtu) new_mtu += VLAN_ETH_HLEN + ETH_FCS_LEN; - if (dsa_is_cpu_port(ds, port)) + if (dsa_is_cpu_port(ds, port) || dsa_is_dsa_port(ds, port)) new_mtu += VLAN_HLEN; policing = priv->static_config.tables[BLK_IDX_L2_POLICING].entries; From patchwork Wed Aug 4 13:54:35 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Vladimir Oltean X-Patchwork-Id: 492101 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id A769EC4320A for ; Wed, 4 Aug 2021 13:55:36 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 8E52660F94 for ; Wed, 4 Aug 2021 13:55:36 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238544AbhHDNzs (ORCPT ); Wed, 4 Aug 2021 09:55:48 -0400 Received: from mail-db8eur05on2061.outbound.protection.outlook.com ([40.107.20.61]:28896 "EHLO EUR05-DB8-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S238540AbhHDNzj (ORCPT ); Wed, 4 Aug 2021 09:55:39 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=hM+Q3CFPXmT4atd2vCpBoTK0jQBOUqpsvX4SepLsGsEiTkSKA9WAkSxR2IZAHz/GNvl872+RFR/pcAIPS6kjZw1cwOmVGdKnIoZTlCeawd1uq+Sis4qy5y5M5Yp3GalV3526TJ/ty79M48s2FoTB3ELqNftl5OFCy50EEcywaSzT22FgRplkTVIaOwasEqRx51byRLqnRBtQoBW5gWTCcb81ReB8zjihYyTkuUAU7SKOp89wkGSak3zy7lFPspVMsRJ5PbCe0m16kKY9aitrhDfFbQGkEgnXKe7cqWpozEQaFlN9wEmoXrVx9xpVBthlMq55IMReRwq0QPMp+0FHHQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=4TuMvmJH7L+Vlds5rFAsFSG1+pHMWI8Fb91zoNxYNiQ=; b=TId0wJD0lvL8UOpdAyiTRPRTzgkdSakmVF4j+E2nXJSfSFyPncfWVqSiIPgvtFjIRXG6o0jEaDPQFG56wme9d3+juFN4bMxfzDLgL6PVBi3PKPADi6HnaxHHkVVHc3Nx6VAVdZZv8TZz7B/xditAiSSeKj+WrP8Z5xWna47tp1CNIpMzuyt1Bh+F4nogzr234O6+lcWrHUj5KY5auB8ENtZeXc8+Qf5/FB2m7x55G2klv7+7yeXHf7qIkwoK6NV/4TAnq/Xu1S3rxB4bz5WZtOFc2SMwp6DwOgfoWJy5gzlkcnmSliQLTf0kT6X89+etuL229hk5OsvP8bf8gKzEdg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=4TuMvmJH7L+Vlds5rFAsFSG1+pHMWI8Fb91zoNxYNiQ=; b=j1rsvBU6SeF4lSLoDfyClB9BJIU9zK3b0Fhqlte6KfDB/P5bxqpEQu0o59rIxujcwh3oyN2eFR8CH8CEhynIOHU78WsIUrchd2I0wsp2V02DfpUdsE4H3kl4MmOGW/VhtZNGEueyYGuFx61d2/H/qmd1v8GKfHfDCDXbup3nNGw= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none; vger.kernel.org; dmarc=none action=none header.from=nxp.com; Received: from VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) by VI1PR0401MB2687.eurprd04.prod.outlook.com (2603:10a6:800:57::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15; Wed, 4 Aug 2021 13:55:14 +0000 Received: from VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0]) by VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0%2]) with mapi id 15.20.4373.027; Wed, 4 Aug 2021 13:55:14 +0000 From: Vladimir Oltean To: netdev@vger.kernel.org, Jakub Kicinski , "David S. Miller" Cc: Andrew Lunn , Florian Fainelli , Vivien Didelot , Vladimir Oltean Subject: [PATCH v3 net-next 7/8] net: dsa: sja1105: suppress TX packets from looping back in "H" topologies Date: Wed, 4 Aug 2021 16:54:35 +0300 Message-Id: <20210804135436.1741856-8-vladimir.oltean@nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210804135436.1741856-1-vladimir.oltean@nxp.com> References: <20210804135436.1741856-1-vladimir.oltean@nxp.com> X-ClientProxiedBy: AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) To VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (188.25.144.60) by AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15 via Frontend Transport; Wed, 4 Aug 2021 13:55:13 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: b48825ec-24ea-46ef-66b2-08d9574f7bb2 X-MS-TrafficTypeDiagnostic: VI1PR0401MB2687: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:10000; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: k8S8EvQXyLfWmzryOxTGT7EB1QFT3qeaEBqNx2/8a8p07PI4gbOXPu8GYP6zCXieMd/EYp9E2YCs+0tQfRxfDmxxsf0eZ0MRTGNLJReiiuja41V+5k1pWXLjE5t8L8Il50LUafuc6pfdhk+PmzLRp35AQzlDuF9XyMrSmEkhyZU3jPvAEceblQQ77Y3wFf+4K6NIbAbXijBLwSdxSf1XmVYI16Bs5LTd0S2KpHoyu7XuHmYkZUWxLot7q084pnpd+xndqxh9hwCbqr7kyfRofeUEsqQneZSOxe87CAUxDe9Sn3z0mf81jJWFP0tX9yQ/sT2YQNomD/fg3GnmoDUq6f++jOFAoQDqifk8kUuByCVri1JKmpFsT9/CYwHr+XWMr9j1HfxMZUIWGHATf/7C7+ATl1x5V9sZjBc2QU4g9TkKWUn2JC+ou/Qz6ToLI/V6Ffz5vOq2FMjfd0YN0V06XIOaNiBi/b94B8kjv/7JEkw97Wh1tZr5FnCkCRNkgYG0RkTyMCl3PhpOyH5d0BqAMxz7ZQWL3023y3AOaSLKLwWb75ckDDsTQEyH1kW/L6horlcZYhp9UkJMcj+4zQRbfLRiJDfUvQ5aiVrMPcls93KPRklfa5kpUKnfGk1+4bbQg7oQfdPK56kBZi59e8kkA/v9kX7ZGbhft4C0WpHpl1+A/NpR5fL/OH/0cnu+D19aFx8TZhat6W0Ur1jcTcAaQQ== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:VI1PR04MB5136.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(136003)(366004)(396003)(376002)(39860400002)(6666004)(6486002)(5660300002)(478600001)(66946007)(1076003)(66476007)(4326008)(66556008)(54906003)(26005)(44832011)(38350700002)(86362001)(2616005)(52116002)(8676002)(6506007)(2906002)(36756003)(110136005)(83380400001)(38100700002)(956004)(6512007)(316002)(8936002)(186003); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: OY0Sd4bUiFNGJdvzU9+rpfS7DmCFpwJ8lSoUs5DCnhzHKX25BhydTHXt8QWtJKHVcX7DzHEkcXNg0BNZcjrmUmLhCTIIuCLrVDAORA0MxkXuZxURUP5LWpfPvRrG4ntOVMzU2DXFKwahqjve0fbGKtDyw3Y4VAg+KFhz+CcH1PPVSEugJxq9dU6iztTSky5y2xYf5kYUvJSa2roUdh1EB5mHlUCYjvu6ZRoidvSY45tBlXvXzj+dg2i9Uv2G4PJpHHHAghDpdCovu+7Scs4gsB3miYYR6KYb5JLppbwLomX693rwd2I8Ono/QJpCpwk63H4W99QKqe7j46/T8gZNRfYF2hW+aOiT09AG9ooXH2b33MUJr66MCJAOZVoLKWshtfQ8HAH1qUiaLuaT4a8bKUo2StVirkGcDxMWrrwDZTxRNqMt7PDlZkye1wL7fYeo5iTNHqs5F1F9QxqZ7qC/5wW/bHlIHfhQn5WKcIwYwbzKxjOlNupCTrdmiZzg2oGWJjxMjEBd4MExOy9G1N51dkqQED/b4KWeTafqs+CB4oVZz/gvs1JYE4kMxjyFbm6SIRfUHZ53xhn4dawPsGTa7zUBM9jGMbVBeIhI2eCoN3m/+/8uMisuHMRhwWgoXsEIYwNYWYlfOVEcTH7d73nnm0RhExi+Hfy9beRUU9tagEHPoKHJu9ylwP6Ahz779Z8pJ3W0RJayvhkfReK9xAOp2AGQVvyFs0AI4bGJmBj5L2QG6kWG7qYOhVfaNVR2jURgMm2UmrjqkPhcoE2CmbQW4E1OU7cOyL9EnaUPkGjNIUQZG74FkO+jFWagmhSEvv8X7b/s7iY7NfJcWOzG41jOFB1mLDF38+wjdPEn14u9vTJDhEni3myUVPXEswunlyDHpbxL2IZzwKqK6KSARr4XLlpmu/GCvwLrKIM/W+ZCM/VMsBev42f4i8SRNteJmyOv1pOeEvPQR55rmoRzsaz96BWwQNbzO91xHUPad1VABcYyzLzLh/7DS62Vvk3UI+E7g2Z6WnASourK1UzuDprW61uTO4JSeAU2YF/phB6Cy78Cisg1yMnbxaNkHeF7BAiZaWpgdtGnJ1JoguVFWIAvYAUD9BM7Pd7r5byIjFmQbwUi3nYD3hhIBMkiUd4lOX2gHSrpRQgiHeO6H/982lljSHnJDATshPIOVhTcSGcTgXZIxaydG4qyS/AGFZkQcMMaIkmcYsiqHWtVCetJR2sc+pbwe1Zycs59ci7QaL9MR41bng4inxCCl3XxJA1+C3X9YuK7BIT/8GCGtOR1t9nDFFm+yMuh/RzspxZ6y7hGhRpgTPAib3i9/PbAsmpT8j7V X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: b48825ec-24ea-46ef-66b2-08d9574f7bb2 X-MS-Exchange-CrossTenant-AuthSource: VI1PR04MB5136.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Aug 2021 13:55:14.0627 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: GVHDu97/5oVm0jwUn1H5u6h2mceBXiBCkdNodOJhYHCPkg95tsQUrgSrrcrDMvANiFLOC9DRX6yNIBGrMYcToA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0401MB2687 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org H topologies like this one have a problem: eth0 eth1 | | CPU port CPU port | DSA link | sw0p0 sw0p1 sw0p2 sw0p3 sw0p4 -------- sw1p4 sw1p3 sw1p2 sw1p1 sw1p0 | | | | | | user user user user user user port port port port port port Basically any packet sent by the eth0 DSA master can be flooded on the interconnecting DSA link sw0p4 <-> sw1p4 and it will be received by the eth1 DSA master too. Basically we are talking to ourselves. In VLAN-unaware mode, these packets are encoded using a tag_8021q TX VLAN, which dsa_8021q_rcv() rightfully cannot decode and complains. Whereas in VLAN-aware mode, the packets are encoded with a bridge VLAN which _can_ be decoded by the tagger running on eth1, so it will attempt to reinject that packet into the network stack (the bridge, if there is any port under eth1 that is under a bridge). In the case where the ports under eth1 are under the same cross-chip bridge as the ports under eth0, the TX packets will even be learned as RX packets. The only thing that will prevent loops with the software bridging path, and therefore disaster, is that the source port and the destination port are in the same hardware domain, and the bridge will receive packets from the driver with skb->offload_fwd_mark = true and will not forward between the two. The proper solution to this problem is to detect H topologies and enforce that all packets are received through the local switch and we do not attempt to receive packets on our CPU port from switches that have their own. This is a viable solution which works thanks to the fact that MAC addresses which should be filtered towards the host are installed by DSA as static MAC addresses towards the CPU port of each switch. TX from a CPU port towards the DSA port continues to be allowed, this is because sja1105 supports bridge TX forwarding offload, and the skb->dev used initially for xmit does not have any direct correlation with where the station that will respond to that packet is connected. It may very well happen that when we send a ping through a br0 interface that spans all switch ports, the xmit packet will exit the system through a DSA switch interface under eth1 (say sw1p2), but the destination station is connected to a switch port under eth0, like sw0p0. So the switch under eth1 needs to communicate on TX with the switch under eth0. The response, however, will not follow the same path, but instead, this patch enforces that the response is sent by the first switch directly to its DSA master which is eth0. Signed-off-by: Vladimir Oltean --- drivers/net/dsa/sja1105/sja1105_main.c | 29 ++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/drivers/net/dsa/sja1105/sja1105_main.c b/drivers/net/dsa/sja1105/sja1105_main.c index fffcaef6b148..b3b5ae3ef408 100644 --- a/drivers/net/dsa/sja1105/sja1105_main.c +++ b/drivers/net/dsa/sja1105/sja1105_main.c @@ -474,7 +474,9 @@ static int sja1105_init_l2_forwarding(struct sja1105_private *priv) { struct sja1105_l2_forwarding_entry *l2fwd; struct dsa_switch *ds = priv->ds; + struct dsa_switch_tree *dst; struct sja1105_table *table; + struct dsa_link *dl; int port, tc; int from, to; @@ -547,6 +549,33 @@ static int sja1105_init_l2_forwarding(struct sja1105_private *priv) } } + /* In odd topologies ("H" connections where there is a DSA link to + * another switch which also has its own CPU port), TX packets can loop + * back into the system (they are flooded from CPU port 1 to the DSA + * link, and from there to CPU port 2). Prevent this from happening by + * cutting RX from DSA links towards our CPU port, if the remote switch + * has its own CPU port and therefore doesn't need ours for network + * stack termination. + */ + dst = ds->dst; + + list_for_each_entry(dl, &dst->rtable, list) { + if (dl->dp->ds != ds || dl->link_dp->cpu_dp == dl->dp->cpu_dp) + continue; + + from = dl->dp->index; + to = dsa_upstream_port(ds, from); + + dev_warn(ds->dev, + "H topology detected, cutting RX from DSA link %d to CPU port %d to prevent TX packet loops\n", + from, to); + + sja1105_port_allow_traffic(l2fwd, from, to, false); + + l2fwd[from].bc_domain &= ~BIT(to); + l2fwd[from].fl_domain &= ~BIT(to); + } + /* Finally, manage the egress flooding domain. All ports start up with * flooding enabled, including the CPU port and DSA links. */ From patchwork Wed Aug 4 13:54:36 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Vladimir Oltean X-Patchwork-Id: 492749 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 01ED9C4338F for ; Wed, 4 Aug 2021 13:55:41 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id DF80E60F58 for ; Wed, 4 Aug 2021 13:55:40 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238543AbhHDNzv (ORCPT ); Wed, 4 Aug 2021 09:55:51 -0400 Received: from mail-am6eur05on2087.outbound.protection.outlook.com ([40.107.22.87]:27905 "EHLO EUR05-AM6-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S238510AbhHDNzr (ORCPT ); Wed, 4 Aug 2021 09:55:47 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=MFEvd1y6feLl3ysUPg4GGv0cu7E1EWoOTVRNAvd5YKZjdTv7KsWIcMvTg0VvLEkX63Az25J4uAtgU5cpZlNnjArq/0+W9ryoeP/VDgyKrSkiidBXPNC1yY9+ozaaj3EfTC3hoKwPHTocoL61XrqZhAM9vWLDu81Iscf6wXp9w/0soD9MZgX5ALGrxcNCHV22b9fF9FzlD8z1y7tPB7FJb5I7RSiKrpbDJqzBqpm1EuUNyW592sRwYu7nSg2iNbzj2gwAnrQhlRdVVe7Ox2CFz4qlifDXjZnG3uD43sHLO6wj56bCISVA/X5NJwa8ZnYO2v07TM9BncfsAGPjL9ju2w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=tFP0ZDXnCmxYhygfqgxLl3BCxbUOVWsrQ3TY81MvUAI=; b=H3Xpdhexm3mfecvFbKbIJ1qtl+pLmaq9I+0OUlEvfrTQv+ZMp1rdg5bgLP0SUCoTVgeyhNpoIy98vrqvXUnaIpDWkh6ptKRKbdPfq+7CKNyrqglH3qBKBDaZgxLj9KAlKpxchc8y2ggzGPwCgDUythEWkUbUwtE7QI6YmMTZcDhmMZU+KvNP1THGMzzQInBdY2NtUEp3MMpXfUJLOi4HwULz34KmTZOjL26x2gtFlMk5AkyDf3EIeUoVFVrUetqMmpyBQ3r2xgRZRqhDuxu07XU3qPL7DwxUSRLXQU0ns+WAsIxmVxIEL+eXRsKgxGTr2Htp8Jp4/ZxpgIP4+vKlYA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=tFP0ZDXnCmxYhygfqgxLl3BCxbUOVWsrQ3TY81MvUAI=; b=ULZ3TkIB4f5NsfbRNmQaeq+cdlNbdcemWd9kLAA5jC+ZB3xQSkC8u8/YC/VwiCMzagRqAm2fdsCoMpIKEvsRBH6h0sAPcg95/O1q3Ky3sBAcT97FhXVbGcXmz39MblHPwVqXgQ28i/zHbWYOT8HBQ48VBnxkI/uXAntx6IM+Dx0= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none; vger.kernel.org; dmarc=none action=none header.from=nxp.com; Received: from VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) by VI1PR0401MB2687.eurprd04.prod.outlook.com (2603:10a6:800:57::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15; Wed, 4 Aug 2021 13:55:15 +0000 Received: from VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0]) by VI1PR04MB5136.eurprd04.prod.outlook.com ([fe80::109:1995:3e6b:5bd0%2]) with mapi id 15.20.4373.027; Wed, 4 Aug 2021 13:55:15 +0000 From: Vladimir Oltean To: netdev@vger.kernel.org, Jakub Kicinski , "David S. Miller" Cc: Andrew Lunn , Florian Fainelli , Vivien Didelot , Vladimir Oltean Subject: [PATCH v3 net-next 8/8] net: dsa: sja1105: enable address learning on cascade ports Date: Wed, 4 Aug 2021 16:54:36 +0300 Message-Id: <20210804135436.1741856-9-vladimir.oltean@nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210804135436.1741856-1-vladimir.oltean@nxp.com> References: <20210804135436.1741856-1-vladimir.oltean@nxp.com> X-ClientProxiedBy: AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) To VI1PR04MB5136.eurprd04.prod.outlook.com (2603:10a6:803:55::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from localhost.localdomain (188.25.144.60) by AM0PR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:208:aa::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4394.15 via Frontend Transport; Wed, 4 Aug 2021 13:55:14 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 8b7ccf8d-3966-4dfd-8368-08d9574f7c42 X-MS-TrafficTypeDiagnostic: VI1PR0401MB2687: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:9508; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: wF/U2THdC+h0teHETrmrVT6OemKQPOkFgcueMU+RAi+GJf0zTKWudN4bXUQgdWtOYS8OWZ3hpgQW7j0vAoR0VRpi5Jq11wMQHkpBsltqKo2VxbFZ2VNSpNyC1Jw/FmFlOwtKu/gcUAeK7NGX67KstnNw8AwbRlQUM6KWzSbJhY5dN1E8dn9tih9FtPkkyVikQIRgDBrhtSvU/Pk+xuj+JSEHl8uV/Z9dkfv2B7ydSGtcC0WG8bzVci1w2ywJqtA9Fja8KNXEufJonlBWpp3XEDId4C5a7v49l4kMfIlMld9166i25YdRsqog+sbw4z580ssxA6MFzIdxLTvRST1JG1FWsUnLE3ZzT3r4C6s50ntATbjegByJaRIkcgVz3vBPil8wLU98KLLola6GfjhGjKFus9ycKonuD/lWK3Vb46NDGXLdUZinMI0TlAndS4tgrvR5rDcQW8d9jzi2+nkDaabV3D0/JEhDUGEU2snhDe0RpRX9aKyiVh+i/EfiKMZcVNg2Q3SwLvM62iWBNgGgfOJekWviD6UlPKSe0GNgDIkR9oK11vIfQwDQgrmZIf4ALizUkvOb9NqbdL8eq/GjqgaADtTMcZVrW8mnu1NvSP4496pWd0D9VP+ikyLRD1eEbpdGpCCXAW55CizoBcj8Ec92mL97cJgxt3IGs41lrPs0Xk7DTNRSVSjs+OuuE0edy2DKRbDxnHTcVDwmN2rURw== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:VI1PR04MB5136.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(346002)(136003)(366004)(396003)(376002)(39860400002)(6666004)(6486002)(5660300002)(478600001)(66946007)(1076003)(66476007)(4326008)(66556008)(54906003)(26005)(44832011)(38350700002)(86362001)(2616005)(52116002)(8676002)(6506007)(2906002)(36756003)(110136005)(83380400001)(38100700002)(956004)(6512007)(316002)(8936002)(186003); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 8UeEGJFqtcG93PUeWFtUtAla/NMjWWA7r4Uo027pCgM+4pY7/r4/Ag2yL3j1MGOq3rHa4+HlldhTakaN3bGJisWAy9gVLfveRiJ+pD+NlQrgkVVNeVOxLCMrK8auYPuNmzmRufJ+1j//BZTbAfQ4fG4dOApQIC0i9MZ4bo4F08UZC6PoyB7RNwgDlGTlj085M3WJqVdEVeDGJ+8qtOBrTkhKKZi/sTxhpckmO6spzibByAsl5MMy8lxterIfPkEu3m68l7nHDPo7NZbY6rI6G1FDqe/9Zdv1Ty+tfILNYfXwnmexhNsI/L3MIdOU6CQ0Tw8VUlnmQOoR+eO8kvxfXyvRWTn/pMrD9FP8f3gkG+aoGRLgSv1zGs/VWiDZzHT8aBLaZ7fg/dQrZ2lwUUgxpi48p1LP/h+RnxHp97JXip1LFXXp4qN9fm2iGi8DwFfe64IVHXhlfT0drGfCojIo/ZwvewKv1wB7lihFhru6w3HlOCAJMyXVdym5KOTXV6PRVk7VSU1DvqpKrOD7Vl7ODydQinxdoSDQz8BxFdKIDxOFIt2VNNNkHHtItbJZCEJjbLdnd4g65T1FjBlPpczxEgN9N6iiwlyPtLnLGtdtUpml929gIN20Ow0W1SOB+IpS3RPL3JACAOpRcAOIhQDIyMw+JBkg9f+3QXTvmT9jH8WWSeH7sv3AdI4s2+VGYgm2lOCu4VFzAldXrhcKp9d4QmYGTkQzUrLc8ANYJF9hrUl6eH8jqKshfMsQs8IlW2Wzgq8EK5xLl9V5i+0qJ+QjWG0rs1BNxpiFRsk4f2/Oizski6XMkXlFdStpCjFBgaxe45+33kbG/ZJWTXHoriq4P+qiWRMHRyFEDxKr0kDh8IRShayEsA+U/67DG1jNnwriRZHXazdokSARjwZq33BM0ZFBnZDqGKAoLH7r5OAv4xnNsExULNUHA8bRoVURJW+B9DH+WaOk1+dkm+m/9EnNrPEl1IhGJNk5x+QTxitIwY+fQeOiqki/oJrc/+FAzHAtYdxUNyA0/k14LcU69dtFhudjvSCGxL/LhhXPznzFbFJcDmD7kkAR7RdCbTn7HGypx44tUq/HULNPw+0aiD6MmODsN/+tvevVUzpizB6HBSnXg7GNbCUZEs/yDE3bihnzjblaeX/BEFytrN693MBEhxgeTtQUYWDeE23Yl23Gzg1oXZQs7hNo4+eRYKqkCRWATZKPwCv1B6OmTUSF/+mCic/DAa418qtj1CfAvdgq5XlslJ3QGuZ4qFA1Xn/lDCGaiagCpgkKFxfMTmFltKvPtu28TUv6MXa6JQougYBQlfLt2Hq/j6/JYXK5e+EuLzI8 X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 8b7ccf8d-3966-4dfd-8368-08d9574f7c42 X-MS-Exchange-CrossTenant-AuthSource: VI1PR04MB5136.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Aug 2021 13:55:14.9921 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: ODGNJzk5LE8a9RWnNzFVu2Th/D3KxaUAkYCPgE/bU+aUYgA2K2GVamWiA47S25ImF75ThYiEvy+jsTNVsUrCdQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR0401MB2687 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Right now, address learning is disabled on DSA ports, which means that a packet received over a DSA port from a cross-chip switch will be flooded to unrelated ports. It is desirable to eliminate that, but for that we need a breakdown of the possibilities for the sja1105 driver. A DSA port can be: - a downstream-facing cascade port. This is simple because it will always receive packets from a downstream switch, and there should be no other route to reach that downstream switch in the first place, which means it should be safe to learn that MAC address towards that switch. - an upstream-facing cascade port. This receives packets either: * autonomously forwarded by an upstream switch (and therefore these packets belong to the data plane of a bridge, so address learning should be ok), or * injected from the CPU. This deserves further discussion, as normally, an upstream-facing cascade port is no different than the CPU port itself. But with "H" topologies (a DSA link towards a switch that has its own CPU port), these are more "laterally-facing" cascade ports than they are "upstream-facing". Here, there is a risk that the port might learn the host addresses on the wrong port (on the DSA port instead of on its own CPU port), but this is solved by DSA's RX filtering infrastructure, which installs the host addresses as static FDB entries on the CPU port of all switches in a "H" tree. So even if there will be an attempt from the switch to migrate the FDB entry from the CPU port to the laterally-facing cascade port, it will fail to do that, because the FDB entry that already exists is static and cannot migrate. So address learning should be safe for this configuration too. Ok, so what about other MAC addresses coming from the host, not necessarily the bridge local FDB entries? What about MAC addresses dynamically learned on foreign interfaces, isn't there a risk that cascade ports will learn these entries dynamically when they are supposed to be delivered towards the CPU port? Well, that is correct, and this is why we also need to enable the assisted learning feature, to snoop for these addresses and write them to hardware as static FDB entries towards the CPU, to make the switch's learning process on the cascade ports ineffective for them. With assisted learning enabled, the hardware learning on the CPU port must be disabled. Signed-off-by: Vladimir Oltean --- drivers/net/dsa/sja1105/sja1105_main.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/drivers/net/dsa/sja1105/sja1105_main.c b/drivers/net/dsa/sja1105/sja1105_main.c index b3b5ae3ef408..f13a6766dd41 100644 --- a/drivers/net/dsa/sja1105/sja1105_main.c +++ b/drivers/net/dsa/sja1105/sja1105_main.c @@ -199,9 +199,13 @@ static int sja1105_init_mac_settings(struct sja1105_private *priv) mac[i] = default_mac; /* Let sja1105_bridge_stp_state_set() keep address learning - * enabled for the CPU port. + * enabled for the DSA ports. CPU ports use software-assisted + * learning to ensure that only FDB entries belonging to the + * bridge are learned, and that they are learned towards all + * CPU ports in a cross-chip topology if multiple CPU ports + * exist. */ - if (dsa_is_cpu_port(ds, i)) + if (dsa_is_dsa_port(ds, i)) priv->learn_ena |= BIT(i); } @@ -2509,6 +2513,7 @@ static int sja1105_setup(struct dsa_switch *ds) ds->num_tx_queues = SJA1105_NUM_TC; ds->mtu_enforcement_ingress = true; + ds->assisted_learning_on_cpu_port = true; rc = sja1105_devlink_setup(ds); if (rc < 0)