Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp5406974rwb; Tue, 17 Jan 2023 13:22:43 -0800 (PST) X-Google-Smtp-Source: AMrXdXv29sSIWM7nOJnc02yOXRk73+UxL97FS8ZtzpZrcdLKHoLCs8lnL/z2J+GUoTKFWfs/tvXF X-Received: by 2002:a17:902:bcc2:b0:194:a7cd:7e09 with SMTP id o2-20020a170902bcc200b00194a7cd7e09mr3901555pls.50.1673990562961; Tue, 17 Jan 2023 13:22:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673990562; cv=none; d=google.com; s=arc-20160816; b=pAWzGlxjlEFYVxlkcc+3AgndePV52Mx3tnk8QqrF1t6DEQM1MX8p0emUSxWdpdHaHd D6RlG9YcY+98kRr36jOxF1QKVDN4eYqDCZDPl0L4c6FBzOVNgK7RmOP7pr0+kkdTnMs+ tI8RJyvaHPQ9PrwDRlSUN335CVA6fC7gZx5ajkh9M6CQd6oh7Xz4ysyPTq7n+ENx2A4N tZ9YqxeZg612svVnRIUaUZ1gtllCs/yCLeD/x1Lb6GgM6GdTMZ1Ylh6CE1tBrWO/0IUa oGYW5VvZxH0e7/KThR8ijnDkczBfVY/30g73ZV2B3Jznja6Np1py7Hbsu+AppsqMLimv Sj0A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:organization :mime-version:references:in-reply-to:message-id:date:subject:cc:to :from; bh=oCxlfN+5O4LHXKt5ZOG1T60DX1xFjpOlUhTi34G3tNQ=; b=uyOg2zw9ORQ/cnWgYLNfpjhcMJIMyGCvydBNBnUbHYwhVbbCE5wkaDZ1UbEUuRU/b2 NU/BVQpUab5xMalQ4zirG9yzV6gLl7Xc+sJNp6Y8iv2WkI6TTWnTXQwIyT6UA7XZKaaU x1iN9T2L9Kh0Z17jzp+lV4wAiv0FvvDG/wa4nvF9UvjD8QPiB3zkCDidoSQKeSzFV82H w+DnA7zy+SuIkKjfrgRdLP1tB5iw8lo7jfvZZEnMeltd/lNi35+JLxxbkx0nla7FAsiE LGOGGZzhlFd4AfO8nBpsdQPeImQlkZv1aCQCZm52gCurf0V0+xgwE9jUAqzJXurjhx9U H8Zw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h1-20020a170902f54100b001944785f248si24716163plf.84.2023.01.17.13.22.35; Tue, 17 Jan 2023 13:22:42 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232187AbjAQUwa (ORCPT + 47 others); Tue, 17 Jan 2023 15:52:30 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59132 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235257AbjAQUtW (ORCPT ); Tue, 17 Jan 2023 15:49:22 -0500 Received: from mailout-taastrup.gigahost.dk (mailout-taastrup.gigahost.dk [46.183.139.199]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9314F47423; Tue, 17 Jan 2023 11:25:07 -0800 (PST) Received: from mailout.gigahost.dk (mailout.gigahost.dk [89.186.169.112]) by mailout-taastrup.gigahost.dk (Postfix) with ESMTP id 0884118835F8; Tue, 17 Jan 2023 18:59:13 +0000 (UTC) Received: from smtp.gigahost.dk (smtp.gigahost.dk [89.186.169.109]) by mailout.gigahost.dk (Postfix) with ESMTP id EE2C8250007B; Tue, 17 Jan 2023 18:59:12 +0000 (UTC) Received: by smtp.gigahost.dk (Postfix, from userid 1000) id E5B499EC000B; Tue, 17 Jan 2023 18:59:12 +0000 (UTC) X-Screener-Id: 413d8c6ce5bf6eab4824d0abaab02863e8e3f662 Received: from fujitsu.vestervang (2-104-116-184-cable.dk.customer.tdc.net [2.104.116.184]) by smtp.gigahost.dk (Postfix) with ESMTPSA id 48D9991201E4; Tue, 17 Jan 2023 18:59:12 +0000 (UTC) From: "Hans J. Schultz" To: davem@davemloft.net, kuba@kernel.org Cc: netdev@vger.kernel.org, "Hans J. Schultz" , Florian Fainelli , Andrew Lunn , Vladimir Oltean , Eric Dumazet , Paolo Abeni , Kurt Kanzenbach , Hauke Mehrtens , Woojung Huh , UNGLinuxDriver@microchip.com (maintainer:MICROCHIP KSZ SERIES ETHERNET SWITCH DRIVER), Sean Wang , Landen Chao , DENG Qingfang , Matthias Brugger , Claudiu Manoil , Alexandre Belloni , =?UTF-8?q?Cl=C3=A9ment=20L=C3=A9ger?= , Jiri Pirko , Ivan Vecera , Roopa Prabhu , Nikolay Aleksandrov , Russell King , Christian Marangi , linux-kernel@vger.kernel.org (open list), linux-arm-kernel@lists.infradead.org (moderated list:ARM/Mediatek SoC support), linux-mediatek@lists.infradead.org (moderated list:ARM/Mediatek SoC support), linux-renesas-soc@vger.kernel.org (open list:RENESAS RZ/N1 A5PSW SWITCH DRIVER), bridge@lists.linux-foundation.org (moderated list:ETHERNET BRIDGE) Subject: [RFC PATCH net-next 1/5] net: bridge: add dynamic flag to switchdev notifier Date: Tue, 17 Jan 2023 19:57:10 +0100 Message-Id: <20230117185714.3058453-2-netdev@kapio-technology.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230117185714.3058453-1-netdev@kapio-technology.com> References: <20230117185714.3058453-1-netdev@kapio-technology.com> MIME-Version: 1.0 Organization: Westermo Network Technologies AB Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.6 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_LOW, SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org To be able to add dynamic FDB entries to drivers from userspace, the dynamic flag must be added when sending RTM_NEWNEIGH events down. Signed-off-by: Hans J. Schultz --- include/net/switchdev.h | 1 + net/bridge/br_switchdev.c | 1 + 2 files changed, 2 insertions(+) diff --git a/include/net/switchdev.h b/include/net/switchdev.h index ca0312b78294..aaf918d4ba67 100644 --- a/include/net/switchdev.h +++ b/include/net/switchdev.h @@ -249,6 +249,7 @@ struct switchdev_notifier_fdb_info { u8 added_by_user:1, is_local:1, locked:1, + is_dyn:1, offloaded:1; }; diff --git a/net/bridge/br_switchdev.c b/net/bridge/br_switchdev.c index 7eb6fd5bb917..60c05a00a1df 100644 --- a/net/bridge/br_switchdev.c +++ b/net/bridge/br_switchdev.c @@ -136,6 +136,7 @@ static void br_switchdev_fdb_populate(struct net_bridge *br, item->added_by_user = test_bit(BR_FDB_ADDED_BY_USER, &fdb->flags); item->offloaded = test_bit(BR_FDB_OFFLOADED, &fdb->flags); item->is_local = test_bit(BR_FDB_LOCAL, &fdb->flags); + item->is_dyn = !test_bit(BR_FDB_STATIC, &fdb->flags); item->locked = false; item->info.dev = (!p || item->is_local) ? br->dev : p->dev; item->info.ctx = ctx; -- 2.34.1