Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4921673pxj; Wed, 12 May 2021 16:38:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxh2Rb2+1sxbbzENMkf2I4QoYC+B9f52F3kWC1rcrrVmXOSRDR0PvLQRYzi+QaFNZAvBFXV X-Received: by 2002:aa7:d5c9:: with SMTP id d9mr46932854eds.153.1620862691016; Wed, 12 May 2021 16:38:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620862691; cv=none; d=google.com; s=arc-20160816; b=T2qCFORj9RQgBULCdJTE4wVelmGaXW15PLbS8dC+rOGf+WtFt5mKJdrzr9FW4kBkXf sWHNl07/RVjv0LKnFcWzsX0ihA5zXiqFTLbDJIQh3DlSJva9GTNo7j8Rev2yvL1WdPfT hlPbMtBgcgmooop+2RjH60xjY2t9AEngqflVn5I8vEdELo1uAT+LmeXS/wA0blZdfNfq OK55T2pZb8Hk4xPCBPoxqNKIqKLEQcVYTeadn1xrcdnCt7yHJUQ+ygpHdnuF3ygkUpSD HijtWv/fTAtBpdnEOUEKZc50TKwCKdAirf2VyU3kDaC52usHTDci2ceahfiLGC5szwzk t2Mw== 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 :message-id:date:subject:cc:to:from; bh=4Dl+emWoaMbD3CjIzmy+++GyIbwfdlhe/qYZFZ3qMzI=; b=JzMaFYnujG2Kox2f72SOa0SAdRRxtRByDEsQRK8vFdAKPtaBUa/kfjx2McvV6pjgQ0 84Fjxz4SdWXUj0t3oDUQUBPzpBv85ozimxWOcaa7K5leY3YCNAJaiRuPbJEFxXiuf6m9 ee8OBfdbU2eejFj34Mg3G3Mzh6lKIqZdtIlhswNNEyCiUbNV7KezC0Q0L6fT1u93nKIi caBwyup8eieVHqm3TXep6l7GwmA0oMr/BWeFlI8gwy5e+YOPoz0C145ZoYPC/YMQc2T1 jO8joiiCgD0bqDTysZBaPASJl9XylZPyUxW9j21zibLLAGpwS3Rk8X4iJ1kpZ1H5s5sv tB6g== 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 l27si1265151eji.726.2021.05.12.16.37.27; Wed, 12 May 2021 16:38:11 -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 S233962AbhELXha (ORCPT + 99 others); Wed, 12 May 2021 19:37:30 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39812 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233920AbhELXU6 (ORCPT ); Wed, 12 May 2021 19:20:58 -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 E7B82C06175F; Wed, 12 May 2021 16:19:48 -0700 (PDT) Received: from [127.0.0.1] (localhost [127.0.0.1]) by localhost (Mailerdaemon) with ESMTPSA id 760503E942; Thu, 13 May 2021 01:19:45 +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 Subject: [PATCH net-next v3 00/11] net: bridge: split IPv4/v6 mc router state and export for batman-adv Date: Thu, 13 May 2021 01:19:30 +0200 Message-Id: <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 Hi, The following patches are splitting the so far combined multicast router state in the Linux bridge into two ones, one for IPv4 and one for IPv6, for a more fine-grained detection of multicast routers. This avoids sending IPv4 multicast packets to an IPv6-only multicast router and avoids sending IPv6 multicast packets to an IPv4-only multicast router. This also allows batman-adv to make use of the now split information in the final patch. The first eight patches prepare the bridge code to avoid duplicate code or IPv6-#ifdef clutter for the multicast router state split. And contain no functional changes yet. The ninth patch then implements the IPv4+IPv6 multicast router state split. Patch number ten adds IPv4+IPv6 specific timers to the mdb netlink router port dump, so that the timers validity can be checked individually from userspace. The final, eleventh patch exports this now per protocol family multicast router state so that batman-adv can then later make full use of the Multicast Router Discovery (MRD) support in the Linux bridge. The batman-adv protocol format currently expects separate multicast router states for IPv4 and IPv6, therefore it depends on the first patch. batman-adv will then make use of this newly exported functions like this[0]. Regards, Linus [0]: https://git.open-mesh.org/batman-adv.git/shortlog/refs/heads/linus/multicast-routeable-mrd -> https://git.open-mesh.org/batman-adv.git/commit/d4bed3a92427445708baeb1f2d1841c5fb816fd4 Changelog v3: * Patch 01/11: * fixed/added missing rename of br->router_list to br->ip4_mc_router_list in br_multicast_flood() * Patch 02/11: * moved inline functions from br_forward.c to br_private.h * Patch 03/11: * removed inline attribute from functions added to br_mdb.c * Patch 04/11: * unchanged * Patch 05/11: * converted if()'s into switch-case in br_multicast_is_router() * Patch 06/11: * removed inline attribute from function added to br_multicast.c * Patch 07/11: * added missing static attribute to function br_ip4_multicast_get_rport_slot() added to br_multicast.c * Patch 08/11: * removed inline attribute from function added to br_multicast.c * Patch 09/11: * added missing static attribute to function br_ip6_multicast_get_rport_slot() added to br_multicast.c * removed inline attribute from function added to br_multicast.c * Patch 10/11: * unchanged * Patch 11/11: * simplified bridge check in br_multicast_has_router_adjacent() by using br_port_get_check_rcu() * added missing declaration for br_multicast_has_router_adjacent() in include/linux/if_bridge.h Changelog v2: * split into multiple patches as suggested by Nikolay * added helper functions to br_multicast_flood(), avoiding IPv6 #ifdef clutter * fixed reverse xmas tree ordering in br_rports_fill_info() and added helper functions to avoid IPv6 #ifdef clutter * Added a common br_multicast_add_router() and a helper function to retrieve the correct slot to avoid duplicate code for an ip4 and ip6 variant * replaced the "1" and "2" constants in br_multicast_is_router() with the appropriate enums * added br_{ip4,ip6}_multicast_rport_del() wrappers to reduce IPv6 #ifdef clutter * added return values to br_*multicast_rport_del() to only notify if the port was actually removed and did not race with a readdition somewhere else * added empty, void br_ip6_multicast_mark_router() if compiled without IPv6, to reduce IPv6 #ifdef clutter