Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4925114pxj; Wed, 12 May 2021 16:44:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyhUPpkQfVPEd1FyENhwZvLBg7kXw3PrK40hXYP/GcfXDNgo8IO+j3sJ9I+dGULBVeTGYsj X-Received: by 2002:a17:907:1b06:: with SMTP id mp6mr40988706ejc.292.1620863077719; Wed, 12 May 2021 16:44:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620863077; cv=none; d=google.com; s=arc-20160816; b=f/fIrSgqRsEN+kHgm5QdTps94H4snouxTTJR9dWb86+74n/wCtpKcFBJj/oKRE52Ov nCfiBogfNyelThsh8ufQZra/vuAF4VGGXx5tbgfXWr0G6JCrZdf1a3pW6meyHeUJpzZO Bgy2nBu9zC41TzwOzyhIt+TPAFbd/tD0sIBe2lvAD8xAmPHjsiUWcL/SLBNs9q/+FOoH zTzo1GuAF2pg8XF2GFAfCawi6oUkp1aYBOzjPDHhURcIt8F90Mzz950IWHvXNtGqy49b J/QFndjjdYNpJOSdxXh5ihbqd49YKOBWjy5N2poSSBCzYNCgVGZMN1nbW3D17l3DAHXE w3PQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=hU9TNLImHBDpdx2LZekaoTiH4f9GExotI0L7nJ4ERr8=; b=CcguuS444M8Msdllg1QTqfXZ585gbWS2GeKhTZWt8R3+eifiETjPAgtoh38TaBQQGy Cqit3mOKWKdejArJt3DcrrIgrNvA1x1MpiVnNVs5s4ff/iL5pFp5eZH/ew0Qjejioagb lZxvwPk/X1bJouqzkcUv6jYRFtLE63EOt43QpaUSNAIfgU+CherkF9N4JdpD2nD/2jJw Kcw8Jmh2a4/cWN1X2rEhF6J5nYRng6tvea4QTkeS5ysvHg9zycvXS+klMBgPga811XlS LWQk7xCuv5plWxfGYDqUU7OrBHUlWoVamGUCNQ7Xp3kK8ueqgeBY+rJdJlleM9YYrpeW zmjQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id mh7si1311638ejb.585.2021.05.12.16.44.14; Wed, 12 May 2021 16:44:37 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235149AbhELXjK (ORCPT + 99 others); Wed, 12 May 2021 19:39:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39882 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234089AbhELXVG (ORCPT ); Wed, 12 May 2021 19:21:06 -0400 Received: from mail.aperture-lab.de (mail.aperture-lab.de [IPv6:2a01:4f8:c2c:665b::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4A865C061763; Wed, 12 May 2021 16:19:51 -0700 (PDT) Received: from [127.0.0.1] (localhost [127.0.0.1]) by localhost (Mailerdaemon) with ESMTPSA id D4C1341008; Thu, 13 May 2021 01:19:49 +0200 (CEST) From: =?UTF-8?q?Linus=20L=C3=BCssing?= To: netdev@vger.kernel.org Cc: Roopa Prabhu , Nikolay Aleksandrov , Jakub Kicinski , "David S . Miller" , bridge@lists.linux-foundation.org, linux-kernel@vger.kernel.org, =?UTF-8?q?Linus=20L=C3=BCssing?= Subject: [net-next v3 03/11] net: bridge: mcast: prepare mdb netlink for mcast router split Date: Thu, 13 May 2021 01:19:33 +0200 Message-Id: <20210512231941.19211-4-linus.luessing@c0d3.blue> In-Reply-To: <20210512231941.19211-1-linus.luessing@c0d3.blue> References: <20210512231941.19211-1-linus.luessing@c0d3.blue> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Last-TLS-Session-Version: TLSv1.2 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In preparation for the upcoming split of multicast router state into their IPv4 and IPv6 variants and to avoid IPv6 #ifdef clutter later add some inline functions for the protocol specific parts in the mdb router netlink code. Also the we need iterate over the port instead of router list to be able put one router port entry with both the IPv4 and IPv6 multicast router info later. Signed-off-by: Linus Lüssing --- net/bridge/br_mdb.c | 39 ++++++++++++++++++++++++++++++++++----- 1 file changed, 34 insertions(+), 5 deletions(-) diff --git a/net/bridge/br_mdb.c b/net/bridge/br_mdb.c index d61def8..482edb9 100644 --- a/net/bridge/br_mdb.c +++ b/net/bridge/br_mdb.c @@ -16,29 +16,58 @@ #include "br_private.h" +static bool br_rports_have_mc_router(struct net_bridge *br) +{ + return !hlist_empty(&br->ip4_mc_router_list); +} + +static bool +br_ip4_rports_get_timer(struct net_bridge_port *port, unsigned long *timer) +{ + *timer = br_timer_value(&port->ip4_mc_router_timer); + return !hlist_unhashed(&port->ip4_rlist); +} + +static bool +br_ip6_rports_get_timer(struct net_bridge_port *port, unsigned long *timer) +{ + *timer = 0; + return false; +} + static int br_rports_fill_info(struct sk_buff *skb, struct netlink_callback *cb, struct net_device *dev) { struct net_bridge *br = netdev_priv(dev); - struct net_bridge_port *p; + bool have_ip4_mc_rtr, have_ip6_mc_rtr; + unsigned long ip4_timer, ip6_timer; struct nlattr *nest, *port_nest; + struct net_bridge_port *p; - if (!br->multicast_router || hlist_empty(&br->ip4_mc_router_list)) + if (!br->multicast_router) + return 0; + + if (!br_rports_have_mc_router(br)) return 0; nest = nla_nest_start_noflag(skb, MDBA_ROUTER); if (nest == NULL) return -EMSGSIZE; - hlist_for_each_entry_rcu(p, &br->ip4_mc_router_list, ip4_rlist) { - if (!p) + list_for_each_entry_rcu(p, &br->port_list, list) { + have_ip4_mc_rtr = br_ip4_rports_get_timer(p, &ip4_timer); + have_ip6_mc_rtr = br_ip6_rports_get_timer(p, &ip6_timer); + + if (!have_ip4_mc_rtr && !have_ip6_mc_rtr) continue; + port_nest = nla_nest_start_noflag(skb, MDBA_ROUTER_PORT); if (!port_nest) goto fail; + if (nla_put_nohdr(skb, sizeof(u32), &p->dev->ifindex) || nla_put_u32(skb, MDBA_ROUTER_PATTR_TIMER, - br_timer_value(&p->ip4_mc_router_timer)) || + max(ip4_timer, ip6_timer)) || nla_put_u8(skb, MDBA_ROUTER_PATTR_TYPE, p->multicast_router)) { nla_nest_cancel(skb, port_nest); -- 2.31.0