1 /* SPDX-License-Identifier: GPL-2.0-or-later */ 2 /* 3 * Linux ethernet bridge 4 * 5 * Authors: 6 * Lennert Buytenhek <buytenh@gnu.org> 7 */ 8 9 #ifndef _BR_PRIVATE_H 10 #define _BR_PRIVATE_H 11 12 #include <linux/netdevice.h> 13 #include <linux/if_bridge.h> 14 #include <linux/netpoll.h> 15 #include <linux/u64_stats_sync.h> 16 #include <net/route.h> 17 #include <net/ip6_fib.h> 18 #include <net/pkt_cls.h> 19 #include <linux/if_vlan.h> 20 #include <linux/rhashtable.h> 21 #include <linux/refcount.h> 22 23 #define BR_HASH_BITS 8 24 #define BR_HASH_SIZE (1 << BR_HASH_BITS) 25 26 #define BR_HOLD_TIME (1*HZ) 27 28 #define BR_PORT_BITS 10 29 #define BR_MAX_PORTS (1<<BR_PORT_BITS) 30 31 #define BR_MULTICAST_DEFAULT_HASH_MAX 4096 32 #define BR_MULTICAST_QUERY_INTVL_MIN msecs_to_jiffies(1000) 33 #define BR_MULTICAST_STARTUP_QUERY_INTVL_MIN BR_MULTICAST_QUERY_INTVL_MIN 34 #define BR_MULTICAST_QUERY_INTVL_MAX msecs_to_jiffies(86400000) /* 24 hours */ 35 #define BR_MULTICAST_STARTUP_QUERY_INTVL_MAX BR_MULTICAST_QUERY_INTVL_MAX 36 37 #define BR_HWDOM_MAX BITS_PER_LONG 38 39 #define BR_VERSION "2.3" 40 41 /* Control of forwarding link local multicast */ 42 #define BR_GROUPFWD_DEFAULT 0 43 /* Don't allow forwarding of control protocols like STP, MAC PAUSE and LACP */ 44 enum { 45 BR_GROUPFWD_STP = BIT(0), 46 BR_GROUPFWD_MACPAUSE = BIT(1), 47 BR_GROUPFWD_LACP = BIT(2), 48 }; 49 50 #define BR_GROUPFWD_RESTRICTED (BR_GROUPFWD_STP | BR_GROUPFWD_MACPAUSE | \ 51 BR_GROUPFWD_LACP) 52 /* The Nearest Customer Bridge Group Address, 01-80-C2-00-00-[00,0B,0C,0D,0F] */ 53 #define BR_GROUPFWD_8021AD 0xB801u 54 55 /* Path to usermode spanning tree program */ 56 #define BR_STP_PROG "/sbin/bridge-stp" 57 58 #define BR_FDB_NOTIFY_SETTABLE_BITS (FDB_NOTIFY_BIT | FDB_NOTIFY_INACTIVE_BIT) 59 60 typedef struct bridge_id bridge_id; 61 typedef struct mac_addr mac_addr; 62 typedef __u16 port_id; 63 64 struct bridge_id { 65 unsigned char prio[2]; 66 unsigned char addr[ETH_ALEN]; 67 }; 68 69 struct mac_addr { 70 unsigned char addr[ETH_ALEN]; 71 }; 72 73 #ifdef CONFIG_BRIDGE_IGMP_SNOOPING 74 /* our own querier */ 75 struct bridge_mcast_own_query { 76 struct timer_list timer; 77 u32 startup_sent; 78 }; 79 80 /* other querier */ 81 struct bridge_mcast_other_query { 82 struct timer_list timer; 83 struct timer_list delay_timer; 84 }; 85 86 /* selected querier */ 87 struct bridge_mcast_querier { 88 struct br_ip addr; 89 int port_ifidx; 90 seqcount_spinlock_t seq; 91 }; 92 93 /* IGMP/MLD statistics */ 94 struct bridge_mcast_stats { 95 struct br_mcast_stats mstats; 96 struct u64_stats_sync syncp; 97 }; 98 99 struct br_mdb_src_entry { 100 struct br_ip addr; 101 }; 102 103 struct br_mdb_config { 104 struct net_bridge *br; 105 struct net_bridge_port *p; 106 struct br_mdb_entry *entry; 107 struct br_ip group; 108 bool src_entry; 109 u8 filter_mode; 110 u16 nlflags; 111 struct br_mdb_src_entry *src_entries; 112 int num_src_entries; 113 u8 rt_protocol; 114 }; 115 #endif 116 117 /* net_bridge_mcast_port must be always defined due to forwarding stubs */ 118 struct net_bridge_mcast_port { 119 #ifdef CONFIG_BRIDGE_IGMP_SNOOPING 120 struct net_bridge_port *port; 121 struct net_bridge_vlan *vlan; 122 123 struct bridge_mcast_own_query ip4_own_query; 124 struct timer_list ip4_mc_router_timer; 125 struct hlist_node ip4_rlist; 126 #if IS_ENABLED(CONFIG_IPV6) 127 struct bridge_mcast_own_query ip6_own_query; 128 struct timer_list ip6_mc_router_timer; 129 struct hlist_node ip6_rlist; 130 #endif /* IS_ENABLED(CONFIG_IPV6) */ 131 unsigned char multicast_router; 132 u32 mdb_n_entries; 133 u32 mdb_max_entries; 134 #endif /* CONFIG_BRIDGE_IGMP_SNOOPING */ 135 }; 136 137 /* net_bridge_mcast must be always defined due to forwarding stubs */ 138 struct net_bridge_mcast { 139 #ifdef CONFIG_BRIDGE_IGMP_SNOOPING 140 struct net_bridge *br; 141 struct net_bridge_vlan *vlan; 142 143 u32 multicast_last_member_count; 144 u32 multicast_startup_query_count; 145 146 u8 multicast_querier; 147 u8 multicast_igmp_version; 148 u8 multicast_router; 149 #if IS_ENABLED(CONFIG_IPV6) 150 u8 multicast_mld_version; 151 #endif 152 unsigned long multicast_last_member_interval; 153 unsigned long multicast_membership_interval; 154 unsigned long multicast_querier_interval; 155 unsigned long multicast_query_interval; 156 unsigned long multicast_query_response_interval; 157 unsigned long multicast_startup_query_interval; 158 struct hlist_head ip4_mc_router_list; 159 struct timer_list ip4_mc_router_timer; 160 struct bridge_mcast_other_query ip4_other_query; 161 struct bridge_mcast_own_query ip4_own_query; 162 struct bridge_mcast_querier ip4_querier; 163 #if IS_ENABLED(CONFIG_IPV6) 164 struct hlist_head ip6_mc_router_list; 165 struct timer_list ip6_mc_router_timer; 166 struct bridge_mcast_other_query ip6_other_query; 167 struct bridge_mcast_own_query ip6_own_query; 168 struct bridge_mcast_querier ip6_querier; 169 #endif /* IS_ENABLED(CONFIG_IPV6) */ 170 #endif /* CONFIG_BRIDGE_IGMP_SNOOPING */ 171 }; 172 173 struct br_tunnel_info { 174 __be64 tunnel_id; 175 struct metadata_dst __rcu *tunnel_dst; 176 }; 177 178 /* private vlan flags */ 179 enum { 180 BR_VLFLAG_PER_PORT_STATS = BIT(0), 181 BR_VLFLAG_ADDED_BY_SWITCHDEV = BIT(1), 182 BR_VLFLAG_MCAST_ENABLED = BIT(2), 183 BR_VLFLAG_GLOBAL_MCAST_ENABLED = BIT(3), 184 BR_VLFLAG_NEIGH_SUPPRESS_ENABLED = BIT(4), 185 BR_VLFLAG_TAGGING_BY_SWITCHDEV = BIT(5), 186 }; 187 188 /** 189 * struct net_bridge_vlan - per-vlan entry 190 * 191 * @vnode: rhashtable member 192 * @tnode: rhashtable member 193 * @vid: VLAN id 194 * @flags: bridge vlan flags 195 * @priv_flags: private (in-kernel) bridge vlan flags 196 * @state: STP state (e.g. blocking, learning, forwarding) 197 * @stats: per-cpu VLAN statistics 198 * @br: if MASTER flag set, this points to a bridge struct 199 * @port: if MASTER flag unset, this points to a port struct 200 * @refcnt: if MASTER flag set, this is bumped for each port referencing it 201 * @brvlan: if MASTER flag unset, this points to the global per-VLAN context 202 * for this VLAN entry 203 * @tinfo: bridge tunnel info 204 * @br_mcast_ctx: if MASTER flag set, this is the global vlan multicast context 205 * @port_mcast_ctx: if MASTER flag unset, this is the per-port/vlan multicast 206 * context 207 * @msti: if MASTER flag set, this holds the VLANs MST instance 208 * @vlist: sorted list of VLAN entries 209 * @rcu: used for entry destruction 210 * 211 * This structure is shared between the global per-VLAN entries contained in 212 * the bridge rhashtable and the local per-port per-VLAN entries contained in 213 * the port's rhashtable. The union entries should be interpreted depending on 214 * the entry flags that are set. 215 */ 216 struct net_bridge_vlan { 217 struct rhash_head vnode; 218 struct rhash_head tnode; 219 u16 vid; 220 u16 flags; 221 u16 priv_flags; 222 u8 state; 223 struct pcpu_sw_netstats __percpu *stats; 224 union { 225 struct net_bridge *br; 226 struct net_bridge_port *port; 227 }; 228 union { 229 refcount_t refcnt; 230 struct net_bridge_vlan *brvlan; 231 }; 232 233 struct br_tunnel_info tinfo; 234 235 union { 236 struct net_bridge_mcast br_mcast_ctx; 237 struct net_bridge_mcast_port port_mcast_ctx; 238 }; 239 240 u16 msti; 241 242 struct list_head vlist; 243 244 struct rcu_head rcu; 245 }; 246 247 /** 248 * struct net_bridge_vlan_group 249 * 250 * @vlan_hash: VLAN entry rhashtable 251 * @tunnel_hash: Hash table to map from tunnel key ID (e.g. VXLAN VNI) to VLAN 252 * @vlan_list: sorted VLAN entry list 253 * @num_vlans: number of total VLAN entries 254 * @pvid: PVID VLAN id 255 * @pvid_state: PVID's STP state (e.g. forwarding, learning, blocking) 256 * 257 * IMPORTANT: Be careful when checking if there're VLAN entries using list 258 * primitives because the bridge can have entries in its list which 259 * are just for global context but not for filtering, i.e. they have 260 * the master flag set but not the brentry flag. If you have to check 261 * if there're "real" entries in the bridge please test @num_vlans 262 */ 263 struct net_bridge_vlan_group { 264 struct rhashtable vlan_hash; 265 struct rhashtable tunnel_hash; 266 struct list_head vlan_list; 267 u16 num_vlans; 268 u16 pvid; 269 u8 pvid_state; 270 }; 271 272 /* bridge fdb flags */ 273 enum { 274 BR_FDB_LOCAL, 275 BR_FDB_STATIC, 276 BR_FDB_STICKY, 277 BR_FDB_ADDED_BY_USER, 278 BR_FDB_ADDED_BY_EXT_LEARN, 279 BR_FDB_OFFLOADED, 280 BR_FDB_NOTIFY, 281 BR_FDB_NOTIFY_INACTIVE, 282 BR_FDB_LOCKED, 283 BR_FDB_DYNAMIC_LEARNED, 284 }; 285 286 struct net_bridge_fdb_key { 287 mac_addr addr; 288 u16 vlan_id; 289 }; 290 291 struct net_bridge_fdb_entry { 292 struct rhash_head rhnode; 293 struct net_bridge_port *dst; 294 295 struct net_bridge_fdb_key key; 296 struct hlist_node fdb_node; 297 unsigned long flags; 298 299 /* write-heavy members should not affect lookups */ 300 unsigned long updated ____cacheline_aligned_in_smp; 301 unsigned long used; 302 303 struct rcu_head rcu; 304 }; 305 306 struct net_bridge_fdb_flush_desc { 307 unsigned long flags; 308 unsigned long flags_mask; 309 int port_ifindex; 310 u16 vlan_id; 311 }; 312 313 #define MDB_PG_FLAGS_PERMANENT BIT(0) 314 #define MDB_PG_FLAGS_OFFLOAD BIT(1) 315 #define MDB_PG_FLAGS_FAST_LEAVE BIT(2) 316 #define MDB_PG_FLAGS_STAR_EXCL BIT(3) 317 #define MDB_PG_FLAGS_BLOCKED BIT(4) 318 #define MDB_PG_FLAGS_OFFLOAD_FAILED BIT(5) 319 320 #define PG_SRC_ENT_LIMIT 32 321 322 #define BR_SGRP_F_DELETE BIT(0) 323 #define BR_SGRP_F_SEND BIT(1) 324 #define BR_SGRP_F_INSTALLED BIT(2) 325 #define BR_SGRP_F_USER_ADDED BIT(3) 326 327 struct net_bridge_mcast_gc { 328 struct hlist_node gc_node; 329 void (*destroy)(struct net_bridge_mcast_gc *gc); 330 }; 331 332 struct net_bridge_group_src { 333 struct hlist_node node; 334 335 struct br_ip addr; 336 struct net_bridge_port_group *pg; 337 u8 flags; 338 u8 src_query_rexmit_cnt; 339 struct timer_list timer; 340 341 struct net_bridge *br; 342 struct net_bridge_mcast_gc mcast_gc; 343 struct rcu_head rcu; 344 }; 345 346 struct net_bridge_port_group_sg_key { 347 struct net_bridge_port *port; 348 struct br_ip addr; 349 }; 350 351 struct net_bridge_port_group { 352 struct net_bridge_port_group __rcu *next; 353 struct net_bridge_port_group_sg_key key; 354 unsigned char eth_addr[ETH_ALEN] __aligned(2); 355 unsigned char flags; 356 unsigned char filter_mode; 357 unsigned char grp_query_rexmit_cnt; 358 unsigned char rt_protocol; 359 360 struct hlist_head src_list; 361 unsigned int src_ents; 362 struct timer_list timer; 363 struct timer_list rexmit_timer; 364 struct hlist_node mglist; 365 struct rb_root eht_set_tree; 366 struct rb_root eht_host_tree; 367 368 struct rhash_head rhnode; 369 struct net_bridge_mcast_gc mcast_gc; 370 struct rcu_head rcu; 371 }; 372 373 struct net_bridge_mdb_entry { 374 struct rhash_head rhnode; 375 struct net_bridge *br; 376 struct net_bridge_port_group __rcu *ports; 377 struct br_ip addr; 378 bool host_joined; 379 380 struct timer_list timer; 381 struct hlist_node mdb_node; 382 383 struct net_bridge_mcast_gc mcast_gc; 384 struct rcu_head rcu; 385 }; 386 387 struct net_bridge_port { 388 struct net_bridge *br; 389 struct net_device *dev; 390 netdevice_tracker dev_tracker; 391 struct list_head list; 392 393 unsigned long flags; 394 #ifdef CONFIG_BRIDGE_VLAN_FILTERING 395 struct net_bridge_vlan_group __rcu *vlgrp; 396 #endif 397 struct net_bridge_port __rcu *backup_port; 398 u32 backup_nhid; 399 400 /* STP */ 401 u8 priority; 402 u8 state; 403 u16 port_no; 404 unsigned char topology_change_ack; 405 unsigned char config_pending; 406 port_id port_id; 407 port_id designated_port; 408 bridge_id designated_root; 409 bridge_id designated_bridge; 410 u32 path_cost; 411 u32 designated_cost; 412 unsigned long designated_age; 413 414 struct timer_list forward_delay_timer; 415 struct timer_list hold_timer; 416 struct timer_list message_age_timer; 417 struct kobject kobj; 418 struct rcu_head rcu; 419 420 struct net_bridge_mcast_port multicast_ctx; 421 422 #ifdef CONFIG_BRIDGE_IGMP_SNOOPING 423 struct bridge_mcast_stats __percpu *mcast_stats; 424 425 u32 multicast_eht_hosts_limit; 426 u32 multicast_eht_hosts_cnt; 427 struct hlist_head mglist; 428 #endif 429 430 #ifdef CONFIG_SYSFS 431 char sysfs_name[IFNAMSIZ]; 432 #endif 433 434 #ifdef CONFIG_NET_POLL_CONTROLLER 435 struct netpoll *np; 436 #endif 437 #ifdef CONFIG_NET_SWITCHDEV 438 /* Identifier used to group ports that share the same switchdev 439 * hardware domain. 440 */ 441 int hwdom; 442 int offload_count; 443 struct netdev_phys_item_id ppid; 444 #endif 445 u16 group_fwd_mask; 446 u16 backup_redirected_cnt; 447 448 struct bridge_stp_xstats stp_xstats; 449 }; 450 451 #define kobj_to_brport(obj) container_of(obj, struct net_bridge_port, kobj) 452 453 #define br_auto_port(p) ((p)->flags & BR_AUTO_MASK) 454 #define br_promisc_port(p) ((p)->flags & BR_PROMISC) 455 456 static inline struct net_bridge_port *br_port_get_rcu(const struct net_device *dev) 457 { 458 return rcu_dereference(dev->rx_handler_data); 459 } 460 461 static inline struct net_bridge_port *br_port_get_rtnl(const struct net_device *dev) 462 { 463 return netif_is_bridge_port(dev) ? 464 rtnl_dereference(dev->rx_handler_data) : NULL; 465 } 466 467 static inline struct net_bridge_port *br_port_get_rtnl_rcu(const struct net_device *dev) 468 { 469 return netif_is_bridge_port(dev) ? 470 rcu_dereference_rtnl(dev->rx_handler_data) : NULL; 471 } 472 473 enum net_bridge_opts { 474 BROPT_VLAN_ENABLED, 475 BROPT_VLAN_STATS_ENABLED, 476 BROPT_NF_CALL_IPTABLES, 477 BROPT_NF_CALL_IP6TABLES, 478 BROPT_NF_CALL_ARPTABLES, 479 BROPT_GROUP_ADDR_SET, 480 BROPT_MULTICAST_ENABLED, 481 BROPT_MULTICAST_QUERY_USE_IFADDR, 482 BROPT_MULTICAST_STATS_ENABLED, 483 BROPT_HAS_IPV6_ADDR, 484 BROPT_NEIGH_SUPPRESS_ENABLED, 485 BROPT_MTU_SET_BY_USER, 486 BROPT_VLAN_STATS_PER_PORT, 487 BROPT_NO_LL_LEARN, 488 BROPT_VLAN_BRIDGE_BINDING, 489 BROPT_MCAST_VLAN_SNOOPING_ENABLED, 490 BROPT_MST_ENABLED, 491 BROPT_MDB_OFFLOAD_FAIL_NOTIFICATION, 492 BROPT_FDB_LOCAL_VLAN_0, 493 }; 494 495 struct net_bridge { 496 spinlock_t lock; 497 spinlock_t hash_lock; 498 struct hlist_head frame_type_list; 499 struct net_device *dev; 500 unsigned long options; 501 /* These fields are accessed on each packet */ 502 #ifdef CONFIG_BRIDGE_VLAN_FILTERING 503 __be16 vlan_proto; 504 u16 default_pvid; 505 struct net_bridge_vlan_group __rcu *vlgrp; 506 #endif 507 508 struct rhashtable fdb_hash_tbl; 509 struct list_head port_list; 510 #if IS_ENABLED(CONFIG_BRIDGE_NETFILTER) 511 union { 512 struct rtable fake_rtable; 513 struct rt6_info fake_rt6_info; 514 }; 515 u32 metrics[RTAX_MAX]; 516 #endif 517 u16 group_fwd_mask; 518 u16 group_fwd_mask_required; 519 520 /* STP */ 521 bridge_id designated_root; 522 bridge_id bridge_id; 523 unsigned char topology_change; 524 unsigned char topology_change_detected; 525 u16 root_port; 526 unsigned long max_age; 527 unsigned long hello_time; 528 unsigned long forward_delay; 529 unsigned long ageing_time; 530 unsigned long bridge_max_age; 531 unsigned long bridge_hello_time; 532 unsigned long bridge_forward_delay; 533 unsigned long bridge_ageing_time; 534 u32 root_path_cost; 535 536 u8 group_addr[ETH_ALEN]; 537 538 enum { 539 BR_NO_STP, /* no spanning tree */ 540 BR_KERNEL_STP, /* old STP in kernel */ 541 BR_USER_STP, /* new RSTP in userspace */ 542 } stp_enabled; 543 544 struct net_bridge_mcast multicast_ctx; 545 546 #ifdef CONFIG_BRIDGE_IGMP_SNOOPING 547 struct bridge_mcast_stats __percpu *mcast_stats; 548 549 u32 hash_max; 550 551 spinlock_t multicast_lock; 552 553 struct rhashtable mdb_hash_tbl; 554 struct rhashtable sg_port_tbl; 555 556 struct hlist_head mcast_gc_list; 557 struct hlist_head mdb_list; 558 559 struct work_struct mcast_gc_work; 560 #endif 561 562 struct timer_list hello_timer; 563 struct timer_list tcn_timer; 564 struct timer_list topology_change_timer; 565 struct delayed_work gc_work; 566 struct kobject *ifobj; 567 u32 auto_cnt; 568 569 atomic_t fdb_n_learned; 570 u32 fdb_max_learned; 571 572 #ifdef CONFIG_NET_SWITCHDEV 573 /* Counter used to make sure that hardware domains get unique 574 * identifiers in case a bridge spans multiple switchdev instances. 575 */ 576 int last_hwdom; 577 /* Bit mask of hardware domain numbers in use */ 578 unsigned long busy_hwdoms; 579 #endif 580 struct hlist_head fdb_list; 581 582 #if IS_ENABLED(CONFIG_BRIDGE_MRP) 583 struct hlist_head mrp_list; 584 #endif 585 #if IS_ENABLED(CONFIG_BRIDGE_CFM) 586 struct hlist_head mep_list; 587 #endif 588 }; 589 590 struct br_input_skb_cb { 591 struct net_device *brdev; 592 593 u16 frag_max_size; 594 #ifdef CONFIG_BRIDGE_IGMP_SNOOPING 595 u8 igmp; 596 u8 mrouters_only:1; 597 #endif 598 u8 proxyarp_replied:1; 599 u8 src_port_isolated:1; 600 u8 promisc:1; 601 #ifdef CONFIG_BRIDGE_VLAN_FILTERING 602 u8 vlan_filtered:1; 603 #endif 604 #ifdef CONFIG_NETFILTER_FAMILY_BRIDGE 605 u8 br_netfilter_broute:1; 606 #endif 607 608 #ifdef CONFIG_NET_SWITCHDEV 609 /* Set if TX data plane offloading is used towards at least one 610 * hardware domain. 611 */ 612 u8 tx_fwd_offload:1; 613 /* The switchdev hardware domain from which this packet was received. 614 * If skb->offload_fwd_mark was set, then this packet was already 615 * forwarded by hardware to the other ports in the source hardware 616 * domain, otherwise it wasn't. 617 */ 618 int src_hwdom; 619 /* Bit mask of hardware domains towards this packet has already been 620 * transmitted using the TX data plane offload. 621 */ 622 unsigned long fwd_hwdoms; 623 #endif 624 625 u32 backup_nhid; 626 }; 627 628 #define BR_INPUT_SKB_CB(__skb) ((struct br_input_skb_cb *)(__skb)->cb) 629 630 #ifdef CONFIG_BRIDGE_IGMP_SNOOPING 631 # define BR_INPUT_SKB_CB_MROUTERS_ONLY(__skb) (BR_INPUT_SKB_CB(__skb)->mrouters_only) 632 #else 633 # define BR_INPUT_SKB_CB_MROUTERS_ONLY(__skb) (0) 634 #endif 635 636 #define br_printk(level, br, format, args...) \ 637 printk(level "%s: " format, (br)->dev->name, ##args) 638 639 #define br_err(__br, format, args...) \ 640 br_printk(KERN_ERR, __br, format, ##args) 641 #define br_warn(__br, format, args...) \ 642 br_printk(KERN_WARNING, __br, format, ##args) 643 #define br_notice(__br, format, args...) \ 644 br_printk(KERN_NOTICE, __br, format, ##args) 645 #define br_info(__br, format, args...) \ 646 br_printk(KERN_INFO, __br, format, ##args) 647 648 #define br_debug(br, format, args...) \ 649 pr_debug("%s: " format, (br)->dev->name, ##args) 650 651 /* called under bridge lock */ 652 static inline int br_is_root_bridge(const struct net_bridge *br) 653 { 654 return !memcmp(&br->bridge_id, &br->designated_root, 8); 655 } 656 657 /* check if a VLAN entry is global */ 658 static inline bool br_vlan_is_master(const struct net_bridge_vlan *v) 659 { 660 return v->flags & BRIDGE_VLAN_INFO_MASTER; 661 } 662 663 /* check if a VLAN entry is used by the bridge */ 664 static inline bool br_vlan_is_brentry(const struct net_bridge_vlan *v) 665 { 666 return v->flags & BRIDGE_VLAN_INFO_BRENTRY; 667 } 668 669 /* check if we should use the vlan entry, returns false if it's only context */ 670 static inline bool br_vlan_should_use(const struct net_bridge_vlan *v) 671 { 672 if (br_vlan_is_master(v)) { 673 if (br_vlan_is_brentry(v)) 674 return true; 675 else 676 return false; 677 } 678 679 return true; 680 } 681 682 static inline bool nbp_state_should_learn(const struct net_bridge_port *p) 683 { 684 return p->state == BR_STATE_LEARNING || p->state == BR_STATE_FORWARDING; 685 } 686 687 static inline bool br_vlan_valid_id(u16 vid, struct netlink_ext_ack *extack) 688 { 689 bool ret = vid > 0 && vid < VLAN_VID_MASK; 690 691 if (!ret) 692 NL_SET_ERR_MSG_MOD(extack, "Vlan id is invalid"); 693 694 return ret; 695 } 696 697 static inline bool br_vlan_valid_range(const struct bridge_vlan_info *cur, 698 const struct bridge_vlan_info *last, 699 struct netlink_ext_ack *extack) 700 { 701 /* pvid flag is not allowed in ranges */ 702 if (cur->flags & BRIDGE_VLAN_INFO_PVID) { 703 NL_SET_ERR_MSG_MOD(extack, "Pvid isn't allowed in a range"); 704 return false; 705 } 706 707 /* when cur is the range end, check if: 708 * - it has range start flag 709 * - range ids are invalid (end is equal to or before start) 710 */ 711 if (last) { 712 if (cur->flags & BRIDGE_VLAN_INFO_RANGE_BEGIN) { 713 NL_SET_ERR_MSG_MOD(extack, "Found a new vlan range start while processing one"); 714 return false; 715 } else if (!(cur->flags & BRIDGE_VLAN_INFO_RANGE_END)) { 716 NL_SET_ERR_MSG_MOD(extack, "Vlan range end flag is missing"); 717 return false; 718 } else if (cur->vid <= last->vid) { 719 NL_SET_ERR_MSG_MOD(extack, "End vlan id is less than or equal to start vlan id"); 720 return false; 721 } 722 } 723 724 /* check for required range flags */ 725 if (!(cur->flags & (BRIDGE_VLAN_INFO_RANGE_BEGIN | 726 BRIDGE_VLAN_INFO_RANGE_END))) { 727 NL_SET_ERR_MSG_MOD(extack, "Both vlan range flags are missing"); 728 return false; 729 } 730 731 return true; 732 } 733 734 static inline u8 br_vlan_multicast_router(const struct net_bridge_vlan *v) 735 { 736 u8 mcast_router = MDB_RTR_TYPE_DISABLED; 737 738 #ifdef CONFIG_BRIDGE_IGMP_SNOOPING 739 if (!br_vlan_is_master(v)) 740 mcast_router = v->port_mcast_ctx.multicast_router; 741 else 742 mcast_router = v->br_mcast_ctx.multicast_router; 743 #endif 744 745 return mcast_router; 746 } 747 748 static inline int br_afspec_cmd_to_rtm(int cmd) 749 { 750 switch (cmd) { 751 case RTM_SETLINK: 752 return RTM_NEWVLAN; 753 case RTM_DELLINK: 754 return RTM_DELVLAN; 755 } 756 757 return 0; 758 } 759 760 static inline int br_opt_get(const struct net_bridge *br, 761 enum net_bridge_opts opt) 762 { 763 return test_bit(opt, &br->options); 764 } 765 766 int br_boolopt_toggle(struct net_bridge *br, enum br_boolopt_id opt, bool on, 767 struct netlink_ext_ack *extack); 768 int br_boolopt_get(const struct net_bridge *br, enum br_boolopt_id opt); 769 int br_boolopt_multi_toggle(struct net_bridge *br, 770 struct br_boolopt_multi *bm, 771 struct netlink_ext_ack *extack); 772 void br_boolopt_multi_get(const struct net_bridge *br, 773 struct br_boolopt_multi *bm); 774 void br_opt_toggle(struct net_bridge *br, enum net_bridge_opts opt, bool on); 775 776 #if IS_ENABLED(CONFIG_NET_TC_SKB_EXT) 777 static inline void br_tc_skb_miss_set(struct sk_buff *skb, bool miss) 778 { 779 struct tc_skb_ext *ext; 780 781 if (!tc_skb_ext_tc_enabled()) 782 return; 783 784 ext = skb_ext_find(skb, TC_SKB_EXT); 785 if (ext) { 786 ext->l2_miss = miss; 787 return; 788 } 789 if (!miss) 790 return; 791 ext = tc_skb_ext_alloc(skb); 792 if (!ext) 793 return; 794 ext->l2_miss = true; 795 } 796 #else 797 static inline void br_tc_skb_miss_set(struct sk_buff *skb, bool miss) 798 { 799 } 800 #endif 801 802 /* br_device.c */ 803 void br_dev_setup(struct net_device *dev); 804 void br_dev_delete(struct net_device *dev, struct list_head *list); 805 netdev_tx_t br_dev_xmit(struct sk_buff *skb, struct net_device *dev); 806 #ifdef CONFIG_NET_POLL_CONTROLLER 807 static inline void br_netpoll_send_skb(const struct net_bridge_port *p, 808 struct sk_buff *skb) 809 { 810 netpoll_send_skb(p->np, skb); 811 } 812 813 int br_netpoll_enable(struct net_bridge_port *p); 814 void br_netpoll_disable(struct net_bridge_port *p); 815 #else 816 static inline void br_netpoll_send_skb(const struct net_bridge_port *p, 817 struct sk_buff *skb) 818 { 819 } 820 821 static inline int br_netpoll_enable(struct net_bridge_port *p) 822 { 823 return 0; 824 } 825 826 static inline void br_netpoll_disable(struct net_bridge_port *p) 827 { 828 } 829 #endif 830 831 /* br_fdb.c */ 832 #define FDB_FLUSH_IGNORED_NDM_FLAGS (NTF_MASTER | NTF_SELF) 833 #define FDB_FLUSH_ALLOWED_NDM_STATES (NUD_PERMANENT | NUD_NOARP) 834 #define FDB_FLUSH_ALLOWED_NDM_FLAGS (NTF_USE | NTF_EXT_LEARNED | \ 835 NTF_STICKY | NTF_OFFLOADED) 836 837 int br_fdb_init(void); 838 void br_fdb_fini(void); 839 int br_fdb_hash_init(struct net_bridge *br); 840 void br_fdb_hash_fini(struct net_bridge *br); 841 void br_fdb_flush(struct net_bridge *br, 842 const struct net_bridge_fdb_flush_desc *desc); 843 void br_fdb_find_delete_local(struct net_bridge *br, 844 const struct net_bridge_port *p, 845 const unsigned char *addr, u16 vid); 846 void br_fdb_changeaddr(struct net_bridge_port *p, const unsigned char *newaddr); 847 void br_fdb_change_mac_address(struct net_bridge *br, const u8 *newaddr); 848 void br_fdb_cleanup(struct work_struct *work); 849 int br_fdb_toggle_local_vlan_0(struct net_bridge *br, bool on, 850 struct netlink_ext_ack *extack); 851 void br_fdb_delete_by_port(struct net_bridge *br, 852 const struct net_bridge_port *p, u16 vid, int do_all); 853 struct net_bridge_fdb_entry *br_fdb_find_rcu(struct net_bridge *br, 854 const unsigned char *addr, 855 __u16 vid); 856 int br_fdb_test_addr(struct net_device *dev, unsigned char *addr); 857 int br_fdb_fillbuf(struct net_bridge *br, void *buf, unsigned long count, 858 unsigned long off); 859 int br_fdb_add_local(struct net_bridge *br, struct net_bridge_port *source, 860 const unsigned char *addr, u16 vid); 861 void br_fdb_update(struct net_bridge *br, struct net_bridge_port *source, 862 const unsigned char *addr, u16 vid, unsigned long flags); 863 864 int br_fdb_delete(struct ndmsg *ndm, struct nlattr *tb[], 865 struct net_device *dev, const unsigned char *addr, u16 vid, 866 bool *notified, struct netlink_ext_ack *extack); 867 int br_fdb_delete_bulk(struct nlmsghdr *nlh, struct net_device *dev, 868 struct netlink_ext_ack *extack); 869 int br_fdb_add(struct ndmsg *nlh, struct nlattr *tb[], struct net_device *dev, 870 const unsigned char *addr, u16 vid, u16 nlh_flags, 871 bool *notified, struct netlink_ext_ack *extack); 872 int br_fdb_dump(struct sk_buff *skb, struct netlink_callback *cb, 873 struct net_device *dev, struct net_device *fdev, int *idx); 874 int br_fdb_get(struct sk_buff *skb, struct nlattr *tb[], struct net_device *dev, 875 const unsigned char *addr, u16 vid, u32 portid, u32 seq, 876 struct netlink_ext_ack *extack); 877 int br_fdb_sync_static(struct net_bridge *br, struct net_bridge_port *p); 878 void br_fdb_unsync_static(struct net_bridge *br, struct net_bridge_port *p); 879 int br_fdb_external_learn_add(struct net_bridge *br, struct net_bridge_port *p, 880 const unsigned char *addr, u16 vid, 881 bool locked, bool swdev_notify); 882 int br_fdb_external_learn_del(struct net_bridge *br, struct net_bridge_port *p, 883 const unsigned char *addr, u16 vid, 884 bool swdev_notify); 885 void br_fdb_offloaded_set(struct net_bridge *br, struct net_bridge_port *p, 886 const unsigned char *addr, u16 vid, bool offloaded); 887 888 /* br_forward.c */ 889 enum br_pkt_type { 890 BR_PKT_UNICAST, 891 BR_PKT_MULTICAST, 892 BR_PKT_BROADCAST 893 }; 894 int br_dev_queue_push_xmit(struct net *net, struct sock *sk, struct sk_buff *skb); 895 void br_forward(const struct net_bridge_port *to, struct sk_buff *skb, 896 bool local_rcv, bool local_orig); 897 int br_forward_finish(struct net *net, struct sock *sk, struct sk_buff *skb); 898 void br_flood(struct net_bridge *br, struct sk_buff *skb, 899 enum br_pkt_type pkt_type, bool local_rcv, bool local_orig, 900 u16 vid); 901 902 /* return true if both source port and dest port are isolated */ 903 static inline bool br_skb_isolated(const struct net_bridge_port *to, 904 const struct sk_buff *skb) 905 { 906 return BR_INPUT_SKB_CB(skb)->src_port_isolated && 907 (to->flags & BR_ISOLATED); 908 } 909 910 /* br_if.c */ 911 void br_port_carrier_check(struct net_bridge_port *p, bool *notified); 912 int br_add_bridge(struct net *net, const char *name); 913 int br_del_bridge(struct net *net, const char *name); 914 int br_add_if(struct net_bridge *br, struct net_device *dev, 915 struct netlink_ext_ack *extack); 916 int br_del_if(struct net_bridge *br, struct net_device *dev); 917 void br_mtu_auto_adjust(struct net_bridge *br); 918 netdev_features_t br_features_recompute(struct net_bridge *br, 919 netdev_features_t features); 920 void br_port_flags_change(struct net_bridge_port *port, unsigned long mask); 921 void br_manage_promisc(struct net_bridge *br); 922 int nbp_backup_change(struct net_bridge_port *p, struct net_device *backup_dev); 923 924 /* br_input.c */ 925 int br_handle_frame_finish(struct net *net, struct sock *sk, struct sk_buff *skb); 926 rx_handler_func_t *br_get_rx_handler(const struct net_device *dev); 927 928 struct br_frame_type { 929 __be16 type; 930 int (*frame_handler)(struct net_bridge_port *port, 931 struct sk_buff *skb); 932 struct hlist_node list; 933 }; 934 935 void br_add_frame(struct net_bridge *br, struct br_frame_type *ft); 936 void br_del_frame(struct net_bridge *br, struct br_frame_type *ft); 937 938 static inline bool br_rx_handler_check_rcu(const struct net_device *dev) 939 { 940 return rcu_dereference(dev->rx_handler) == br_get_rx_handler(dev); 941 } 942 943 static inline bool br_rx_handler_check_rtnl(const struct net_device *dev) 944 { 945 return rcu_dereference_rtnl(dev->rx_handler) == br_get_rx_handler(dev); 946 } 947 948 static inline struct net_bridge_port *br_port_get_check_rcu(const struct net_device *dev) 949 { 950 return br_rx_handler_check_rcu(dev) ? br_port_get_rcu(dev) : NULL; 951 } 952 953 static inline struct net_bridge_port * 954 br_port_get_check_rtnl(const struct net_device *dev) 955 { 956 return br_rx_handler_check_rtnl(dev) ? br_port_get_rtnl_rcu(dev) : NULL; 957 } 958 959 /* br_ioctl.c */ 960 int br_dev_siocdevprivate(struct net_device *dev, struct ifreq *rq, 961 void __user *data, int cmd); 962 int br_ioctl_stub(struct net *net, unsigned int cmd, void __user *uarg); 963 964 /* br_multicast.c */ 965 #ifdef CONFIG_BRIDGE_IGMP_SNOOPING 966 int br_multicast_rcv(struct net_bridge_mcast **brmctx, 967 struct net_bridge_mcast_port **pmctx, 968 struct net_bridge_vlan *vlan, 969 struct sk_buff *skb, u16 vid); 970 struct net_bridge_mdb_entry * 971 br_mdb_entry_skb_get(struct net_bridge_mcast *brmctx, struct sk_buff *skb, 972 u16 vid); 973 int br_multicast_add_port(struct net_bridge_port *port); 974 void br_multicast_del_port(struct net_bridge_port *port); 975 void br_multicast_enable_port(struct net_bridge_port *port); 976 void br_multicast_disable_port(struct net_bridge_port *port); 977 void br_multicast_init(struct net_bridge *br); 978 void br_multicast_join_snoopers(struct net_bridge *br); 979 void br_multicast_leave_snoopers(struct net_bridge *br); 980 void br_multicast_open(struct net_bridge *br); 981 void br_multicast_stop(struct net_bridge *br); 982 void br_multicast_dev_del(struct net_bridge *br); 983 void br_multicast_flood(struct net_bridge_mdb_entry *mdst, struct sk_buff *skb, 984 struct net_bridge_mcast *brmctx, 985 bool local_rcv, bool local_orig); 986 int br_multicast_set_router(struct net_bridge_mcast *brmctx, unsigned long val); 987 int br_multicast_set_port_router(struct net_bridge_mcast_port *pmctx, 988 unsigned long val); 989 int br_multicast_set_vlan_router(struct net_bridge_vlan *v, u8 mcast_router); 990 int br_multicast_toggle(struct net_bridge *br, unsigned long val, 991 struct netlink_ext_ack *extack); 992 int br_multicast_set_querier(struct net_bridge_mcast *brmctx, unsigned long val); 993 int br_multicast_set_igmp_version(struct net_bridge_mcast *brmctx, 994 unsigned long val); 995 #if IS_ENABLED(CONFIG_IPV6) 996 int br_multicast_set_mld_version(struct net_bridge_mcast *brmctx, 997 unsigned long val); 998 #endif 999 struct net_bridge_mdb_entry * 1000 br_mdb_ip_get(struct net_bridge *br, struct br_ip *dst); 1001 struct net_bridge_mdb_entry * 1002 br_multicast_new_group(struct net_bridge *br, struct br_ip *group); 1003 struct net_bridge_port_group * 1004 br_multicast_new_port_group(struct net_bridge_port *port, 1005 const struct br_ip *group, 1006 struct net_bridge_port_group __rcu *next, 1007 unsigned char flags, const unsigned char *src, 1008 u8 filter_mode, u8 rt_protocol, 1009 struct netlink_ext_ack *extack); 1010 void br_multicast_del_port_group(struct net_bridge_port_group *p); 1011 int br_mdb_hash_init(struct net_bridge *br); 1012 void br_mdb_hash_fini(struct net_bridge *br); 1013 void br_mdb_notify(struct net_device *dev, struct net_bridge_mdb_entry *mp, 1014 struct net_bridge_port_group *pg, int type); 1015 void br_mdb_flag_change_notify(struct net_device *dev, struct net_bridge_mdb_entry *mp, 1016 struct net_bridge_port_group *pg); 1017 void br_rtr_notify(struct net_device *dev, struct net_bridge_mcast_port *pmctx, 1018 int type); 1019 void br_multicast_del_pg(struct net_bridge_mdb_entry *mp, 1020 struct net_bridge_port_group *pg, 1021 struct net_bridge_port_group __rcu **pp); 1022 void br_multicast_count(struct net_bridge *br, 1023 const struct net_bridge_port *p, 1024 const struct sk_buff *skb, u8 type, u8 dir); 1025 int br_multicast_init_stats(struct net_bridge *br); 1026 void br_multicast_uninit_stats(struct net_bridge *br); 1027 void br_multicast_get_stats(const struct net_bridge *br, 1028 const struct net_bridge_port *p, 1029 struct br_mcast_stats *dest); 1030 u32 br_multicast_ngroups_get(const struct net_bridge_mcast_port *pmctx); 1031 void br_multicast_ngroups_set_max(struct net_bridge_mcast_port *pmctx, u32 max); 1032 u32 br_multicast_ngroups_get_max(const struct net_bridge_mcast_port *pmctx); 1033 int br_mdb_add(struct net_device *dev, struct nlattr *tb[], u16 nlmsg_flags, 1034 struct netlink_ext_ack *extack); 1035 int br_mdb_del(struct net_device *dev, struct nlattr *tb[], 1036 struct netlink_ext_ack *extack); 1037 int br_mdb_del_bulk(struct net_device *dev, struct nlattr *tb[], 1038 struct netlink_ext_ack *extack); 1039 int br_mdb_dump(struct net_device *dev, struct sk_buff *skb, 1040 struct netlink_callback *cb); 1041 int br_mdb_get(struct net_device *dev, struct nlattr *tb[], u32 portid, u32 seq, 1042 struct netlink_ext_ack *extack); 1043 void br_multicast_host_join(const struct net_bridge_mcast *brmctx, 1044 struct net_bridge_mdb_entry *mp, bool notify); 1045 void br_multicast_host_leave(struct net_bridge_mdb_entry *mp, bool notify); 1046 void br_multicast_star_g_handle_mode(struct net_bridge_port_group *pg, 1047 u8 filter_mode); 1048 void br_multicast_sg_add_exclude_ports(struct net_bridge_mdb_entry *star_mp, 1049 struct net_bridge_port_group *sg); 1050 struct net_bridge_group_src * 1051 br_multicast_find_group_src(struct net_bridge_port_group *pg, struct br_ip *ip); 1052 struct net_bridge_group_src * 1053 br_multicast_new_group_src(struct net_bridge_port_group *pg, 1054 struct br_ip *src_ip); 1055 void __br_multicast_del_group_src(struct net_bridge_group_src *src); 1056 void br_multicast_del_group_src(struct net_bridge_group_src *src, 1057 bool fastleave); 1058 void br_multicast_ctx_init(struct net_bridge *br, 1059 struct net_bridge_vlan *vlan, 1060 struct net_bridge_mcast *brmctx); 1061 void br_multicast_ctx_deinit(struct net_bridge_mcast *brmctx); 1062 void br_multicast_port_ctx_init(struct net_bridge_port *port, 1063 struct net_bridge_vlan *vlan, 1064 struct net_bridge_mcast_port *pmctx); 1065 void br_multicast_port_ctx_deinit(struct net_bridge_mcast_port *pmctx); 1066 void br_multicast_update_vlan_mcast_ctx(struct net_bridge_vlan *v, u8 state); 1067 void br_multicast_toggle_one_vlan(struct net_bridge_vlan *vlan, bool on); 1068 int br_multicast_toggle_vlan_snooping(struct net_bridge *br, bool on, 1069 struct netlink_ext_ack *extack); 1070 bool br_multicast_toggle_global_vlan(struct net_bridge_vlan *vlan, bool on); 1071 1072 int br_rports_fill_info(struct sk_buff *skb, 1073 const struct net_bridge_mcast *brmctx); 1074 int br_multicast_dump_querier_state(struct sk_buff *skb, 1075 const struct net_bridge_mcast *brmctx, 1076 int nest_attr); 1077 size_t br_multicast_querier_state_size(void); 1078 size_t br_rports_size(const struct net_bridge_mcast *brmctx); 1079 void br_multicast_set_query_intvl(struct net_bridge_mcast *brmctx, 1080 unsigned long val); 1081 void br_multicast_set_startup_query_intvl(struct net_bridge_mcast *brmctx, 1082 unsigned long val); 1083 1084 static inline bool br_group_is_l2(const struct br_ip *group) 1085 { 1086 return group->proto == 0; 1087 } 1088 1089 #define mlock_dereference(X, br) \ 1090 rcu_dereference_protected(X, lockdep_is_held(&br->multicast_lock)) 1091 1092 static inline struct hlist_node * 1093 br_multicast_get_first_rport_node(struct net_bridge_mcast *brmctx, 1094 struct sk_buff *skb) 1095 { 1096 #if IS_ENABLED(CONFIG_IPV6) 1097 if (skb->protocol == htons(ETH_P_IPV6)) 1098 return rcu_dereference(hlist_first_rcu(&brmctx->ip6_mc_router_list)); 1099 #endif 1100 return rcu_dereference(hlist_first_rcu(&brmctx->ip4_mc_router_list)); 1101 } 1102 1103 static inline struct net_bridge_port * 1104 br_multicast_rport_from_node_skb(struct hlist_node *rp, struct sk_buff *skb) 1105 { 1106 struct net_bridge_mcast_port *mctx; 1107 1108 #if IS_ENABLED(CONFIG_IPV6) 1109 if (skb->protocol == htons(ETH_P_IPV6)) 1110 mctx = hlist_entry_safe(rp, struct net_bridge_mcast_port, 1111 ip6_rlist); 1112 else 1113 #endif 1114 mctx = hlist_entry_safe(rp, struct net_bridge_mcast_port, 1115 ip4_rlist); 1116 1117 if (mctx) 1118 return mctx->port; 1119 else 1120 return NULL; 1121 } 1122 1123 static inline bool br_ip4_multicast_is_router(struct net_bridge_mcast *brmctx) 1124 { 1125 return timer_pending(&brmctx->ip4_mc_router_timer); 1126 } 1127 1128 static inline bool br_ip6_multicast_is_router(struct net_bridge_mcast *brmctx) 1129 { 1130 #if IS_ENABLED(CONFIG_IPV6) 1131 return timer_pending(&brmctx->ip6_mc_router_timer); 1132 #else 1133 return false; 1134 #endif 1135 } 1136 1137 static inline bool 1138 br_multicast_is_router(struct net_bridge_mcast *brmctx, struct sk_buff *skb) 1139 { 1140 switch (brmctx->multicast_router) { 1141 case MDB_RTR_TYPE_PERM: 1142 return true; 1143 case MDB_RTR_TYPE_TEMP_QUERY: 1144 if (skb) { 1145 if (skb->protocol == htons(ETH_P_IP)) 1146 return br_ip4_multicast_is_router(brmctx); 1147 else if (skb->protocol == htons(ETH_P_IPV6)) 1148 return br_ip6_multicast_is_router(brmctx); 1149 } else { 1150 return br_ip4_multicast_is_router(brmctx) || 1151 br_ip6_multicast_is_router(brmctx); 1152 } 1153 fallthrough; 1154 default: 1155 return false; 1156 } 1157 } 1158 1159 static inline bool 1160 __br_multicast_querier_exists(struct net_bridge_mcast *brmctx, 1161 struct bridge_mcast_other_query *querier, 1162 const bool is_ipv6) 1163 { 1164 bool own_querier_enabled; 1165 1166 if (brmctx->multicast_querier) { 1167 if (is_ipv6 && !br_opt_get(brmctx->br, BROPT_HAS_IPV6_ADDR)) 1168 own_querier_enabled = false; 1169 else 1170 own_querier_enabled = true; 1171 } else { 1172 own_querier_enabled = false; 1173 } 1174 1175 return !timer_pending(&querier->delay_timer) && 1176 (own_querier_enabled || timer_pending(&querier->timer)); 1177 } 1178 1179 static inline bool br_multicast_querier_exists(struct net_bridge_mcast *brmctx, 1180 struct ethhdr *eth, 1181 const struct net_bridge_mdb_entry *mdb) 1182 { 1183 switch (eth->h_proto) { 1184 case (htons(ETH_P_IP)): 1185 return __br_multicast_querier_exists(brmctx, 1186 &brmctx->ip4_other_query, false); 1187 #if IS_ENABLED(CONFIG_IPV6) 1188 case (htons(ETH_P_IPV6)): 1189 return __br_multicast_querier_exists(brmctx, 1190 &brmctx->ip6_other_query, true); 1191 #endif 1192 default: 1193 return !!mdb && br_group_is_l2(&mdb->addr); 1194 } 1195 } 1196 1197 static inline bool br_multicast_is_star_g(const struct br_ip *ip) 1198 { 1199 switch (ip->proto) { 1200 case htons(ETH_P_IP): 1201 return ipv4_is_zeronet(ip->src.ip4); 1202 #if IS_ENABLED(CONFIG_IPV6) 1203 case htons(ETH_P_IPV6): 1204 return ipv6_addr_any(&ip->src.ip6); 1205 #endif 1206 default: 1207 return false; 1208 } 1209 } 1210 1211 static inline bool 1212 br_multicast_should_handle_mode(const struct net_bridge_mcast *brmctx, 1213 __be16 proto) 1214 { 1215 switch (proto) { 1216 case htons(ETH_P_IP): 1217 return !!(brmctx->multicast_igmp_version == 3); 1218 #if IS_ENABLED(CONFIG_IPV6) 1219 case htons(ETH_P_IPV6): 1220 return !!(brmctx->multicast_mld_version == 2); 1221 #endif 1222 default: 1223 return false; 1224 } 1225 } 1226 1227 static inline int br_multicast_igmp_type(const struct sk_buff *skb) 1228 { 1229 return BR_INPUT_SKB_CB(skb)->igmp; 1230 } 1231 1232 static inline unsigned long br_multicast_lmqt(const struct net_bridge_mcast *brmctx) 1233 { 1234 return brmctx->multicast_last_member_interval * 1235 brmctx->multicast_last_member_count; 1236 } 1237 1238 static inline unsigned long br_multicast_gmi(const struct net_bridge_mcast *brmctx) 1239 { 1240 return brmctx->multicast_membership_interval; 1241 } 1242 1243 static inline bool 1244 br_multicast_ctx_is_vlan(const struct net_bridge_mcast *brmctx) 1245 { 1246 return !!brmctx->vlan; 1247 } 1248 1249 static inline bool 1250 br_multicast_port_ctx_is_vlan(const struct net_bridge_mcast_port *pmctx) 1251 { 1252 return !!pmctx->vlan; 1253 } 1254 1255 static inline struct net_bridge_mcast * 1256 br_multicast_port_ctx_get_global(const struct net_bridge_mcast_port *pmctx) 1257 { 1258 if (!br_multicast_port_ctx_is_vlan(pmctx)) 1259 return &pmctx->port->br->multicast_ctx; 1260 else 1261 return &pmctx->vlan->brvlan->br_mcast_ctx; 1262 } 1263 1264 static inline bool 1265 br_multicast_ctx_vlan_global_disabled(const struct net_bridge_mcast *brmctx) 1266 { 1267 return br_multicast_ctx_is_vlan(brmctx) && 1268 (!br_opt_get(brmctx->br, BROPT_MCAST_VLAN_SNOOPING_ENABLED) || 1269 !(brmctx->vlan->priv_flags & BR_VLFLAG_GLOBAL_MCAST_ENABLED)); 1270 } 1271 1272 static inline bool 1273 br_multicast_ctx_vlan_disabled(const struct net_bridge_mcast *brmctx) 1274 { 1275 return br_multicast_ctx_is_vlan(brmctx) && 1276 !(brmctx->vlan->priv_flags & BR_VLFLAG_MCAST_ENABLED); 1277 } 1278 1279 static inline bool 1280 br_multicast_port_ctx_vlan_disabled(const struct net_bridge_mcast_port *pmctx) 1281 { 1282 return br_multicast_port_ctx_is_vlan(pmctx) && 1283 !(pmctx->vlan->priv_flags & BR_VLFLAG_MCAST_ENABLED); 1284 } 1285 1286 static inline bool 1287 br_multicast_port_ctx_state_disabled(const struct net_bridge_mcast_port *pmctx) 1288 { 1289 return pmctx->port->state == BR_STATE_DISABLED || 1290 (br_multicast_port_ctx_is_vlan(pmctx) && 1291 (br_multicast_port_ctx_vlan_disabled(pmctx) || 1292 pmctx->vlan->state == BR_STATE_DISABLED)); 1293 } 1294 1295 static inline bool 1296 br_multicast_port_ctx_state_stopped(const struct net_bridge_mcast_port *pmctx) 1297 { 1298 return br_multicast_port_ctx_state_disabled(pmctx) || 1299 pmctx->port->state == BR_STATE_BLOCKING || 1300 (br_multicast_port_ctx_is_vlan(pmctx) && 1301 pmctx->vlan->state == BR_STATE_BLOCKING); 1302 } 1303 1304 static inline bool 1305 br_rports_have_mc_router(const struct net_bridge_mcast *brmctx) 1306 { 1307 #if IS_ENABLED(CONFIG_IPV6) 1308 return !hlist_empty(&brmctx->ip4_mc_router_list) || 1309 !hlist_empty(&brmctx->ip6_mc_router_list); 1310 #else 1311 return !hlist_empty(&brmctx->ip4_mc_router_list); 1312 #endif 1313 } 1314 1315 static inline bool 1316 br_multicast_ctx_options_equal(const struct net_bridge_mcast *brmctx1, 1317 const struct net_bridge_mcast *brmctx2) 1318 { 1319 return brmctx1->multicast_igmp_version == 1320 brmctx2->multicast_igmp_version && 1321 brmctx1->multicast_last_member_count == 1322 brmctx2->multicast_last_member_count && 1323 brmctx1->multicast_startup_query_count == 1324 brmctx2->multicast_startup_query_count && 1325 brmctx1->multicast_last_member_interval == 1326 brmctx2->multicast_last_member_interval && 1327 brmctx1->multicast_membership_interval == 1328 brmctx2->multicast_membership_interval && 1329 brmctx1->multicast_querier_interval == 1330 brmctx2->multicast_querier_interval && 1331 brmctx1->multicast_query_interval == 1332 brmctx2->multicast_query_interval && 1333 brmctx1->multicast_query_response_interval == 1334 brmctx2->multicast_query_response_interval && 1335 brmctx1->multicast_startup_query_interval == 1336 brmctx2->multicast_startup_query_interval && 1337 brmctx1->multicast_querier == brmctx2->multicast_querier && 1338 brmctx1->multicast_router == brmctx2->multicast_router && 1339 !br_rports_have_mc_router(brmctx1) && 1340 !br_rports_have_mc_router(brmctx2) && 1341 #if IS_ENABLED(CONFIG_IPV6) 1342 brmctx1->multicast_mld_version == 1343 brmctx2->multicast_mld_version && 1344 #endif 1345 true; 1346 } 1347 1348 static inline bool 1349 br_multicast_port_ctx_options_equal(const struct net_bridge_mcast_port *pmctx1, 1350 const struct net_bridge_mcast_port *pmctx2) 1351 { 1352 return br_multicast_ngroups_get(pmctx1) == 1353 br_multicast_ngroups_get(pmctx2) && 1354 br_multicast_ngroups_get_max(pmctx1) == 1355 br_multicast_ngroups_get_max(pmctx2); 1356 } 1357 1358 static inline bool 1359 br_multicast_ctx_matches_vlan_snooping(const struct net_bridge_mcast *brmctx) 1360 { 1361 bool vlan_snooping_enabled; 1362 1363 vlan_snooping_enabled = !!br_opt_get(brmctx->br, 1364 BROPT_MCAST_VLAN_SNOOPING_ENABLED); 1365 1366 return !!(vlan_snooping_enabled == br_multicast_ctx_is_vlan(brmctx)); 1367 } 1368 1369 static inline void 1370 br_multicast_set_pg_offload_flags(struct net_bridge_port_group *p, 1371 bool offloaded) 1372 { 1373 p->flags &= ~(MDB_PG_FLAGS_OFFLOAD | MDB_PG_FLAGS_OFFLOAD_FAILED); 1374 p->flags |= (offloaded ? MDB_PG_FLAGS_OFFLOAD : 1375 MDB_PG_FLAGS_OFFLOAD_FAILED); 1376 } 1377 1378 static inline bool 1379 br_mdb_should_notify(const struct net_bridge *br, u8 changed_flags) 1380 { 1381 return br_opt_get(br, BROPT_MDB_OFFLOAD_FAIL_NOTIFICATION) && 1382 (changed_flags & MDB_PG_FLAGS_OFFLOAD_FAILED); 1383 } 1384 #else 1385 static inline int br_multicast_rcv(struct net_bridge_mcast **brmctx, 1386 struct net_bridge_mcast_port **pmctx, 1387 struct net_bridge_vlan *vlan, 1388 struct sk_buff *skb, 1389 u16 vid) 1390 { 1391 return 0; 1392 } 1393 1394 static inline struct net_bridge_mdb_entry * 1395 br_mdb_entry_skb_get(struct net_bridge_mcast *brmctx, struct sk_buff *skb, 1396 u16 vid) 1397 { 1398 return NULL; 1399 } 1400 1401 static inline int br_multicast_add_port(struct net_bridge_port *port) 1402 { 1403 return 0; 1404 } 1405 1406 static inline void br_multicast_del_port(struct net_bridge_port *port) 1407 { 1408 } 1409 1410 static inline void br_multicast_enable_port(struct net_bridge_port *port) 1411 { 1412 } 1413 1414 static inline void br_multicast_disable_port(struct net_bridge_port *port) 1415 { 1416 } 1417 1418 static inline void br_multicast_init(struct net_bridge *br) 1419 { 1420 } 1421 1422 static inline void br_multicast_join_snoopers(struct net_bridge *br) 1423 { 1424 } 1425 1426 static inline void br_multicast_leave_snoopers(struct net_bridge *br) 1427 { 1428 } 1429 1430 static inline void br_multicast_open(struct net_bridge *br) 1431 { 1432 } 1433 1434 static inline void br_multicast_stop(struct net_bridge *br) 1435 { 1436 } 1437 1438 static inline void br_multicast_dev_del(struct net_bridge *br) 1439 { 1440 } 1441 1442 static inline void br_multicast_flood(struct net_bridge_mdb_entry *mdst, 1443 struct sk_buff *skb, 1444 struct net_bridge_mcast *brmctx, 1445 bool local_rcv, bool local_orig) 1446 { 1447 } 1448 1449 static inline bool br_multicast_is_router(struct net_bridge_mcast *brmctx, 1450 struct sk_buff *skb) 1451 { 1452 return false; 1453 } 1454 1455 static inline bool br_multicast_querier_exists(struct net_bridge_mcast *brmctx, 1456 struct ethhdr *eth, 1457 const struct net_bridge_mdb_entry *mdb) 1458 { 1459 return false; 1460 } 1461 1462 static inline int br_mdb_add(struct net_device *dev, struct nlattr *tb[], 1463 u16 nlmsg_flags, struct netlink_ext_ack *extack) 1464 { 1465 return -EOPNOTSUPP; 1466 } 1467 1468 static inline int br_mdb_del(struct net_device *dev, struct nlattr *tb[], 1469 struct netlink_ext_ack *extack) 1470 { 1471 return -EOPNOTSUPP; 1472 } 1473 1474 static inline int br_mdb_del_bulk(struct net_device *dev, struct nlattr *tb[], 1475 struct netlink_ext_ack *extack) 1476 { 1477 return -EOPNOTSUPP; 1478 } 1479 1480 static inline int br_mdb_dump(struct net_device *dev, struct sk_buff *skb, 1481 struct netlink_callback *cb) 1482 { 1483 return 0; 1484 } 1485 1486 static inline int br_mdb_get(struct net_device *dev, struct nlattr *tb[], 1487 u32 portid, u32 seq, 1488 struct netlink_ext_ack *extack) 1489 { 1490 return -EOPNOTSUPP; 1491 } 1492 1493 static inline int br_mdb_hash_init(struct net_bridge *br) 1494 { 1495 return 0; 1496 } 1497 1498 static inline void br_mdb_hash_fini(struct net_bridge *br) 1499 { 1500 } 1501 1502 static inline void br_multicast_count(struct net_bridge *br, 1503 const struct net_bridge_port *p, 1504 const struct sk_buff *skb, 1505 u8 type, u8 dir) 1506 { 1507 } 1508 1509 static inline int br_multicast_init_stats(struct net_bridge *br) 1510 { 1511 return 0; 1512 } 1513 1514 static inline void br_multicast_uninit_stats(struct net_bridge *br) 1515 { 1516 } 1517 1518 static inline int br_multicast_igmp_type(const struct sk_buff *skb) 1519 { 1520 return 0; 1521 } 1522 1523 static inline void br_multicast_ctx_init(struct net_bridge *br, 1524 struct net_bridge_vlan *vlan, 1525 struct net_bridge_mcast *brmctx) 1526 { 1527 } 1528 1529 static inline void br_multicast_ctx_deinit(struct net_bridge_mcast *brmctx) 1530 { 1531 } 1532 1533 static inline void br_multicast_port_ctx_init(struct net_bridge_port *port, 1534 struct net_bridge_vlan *vlan, 1535 struct net_bridge_mcast_port *pmctx) 1536 { 1537 } 1538 1539 static inline void br_multicast_port_ctx_deinit(struct net_bridge_mcast_port *pmctx) 1540 { 1541 } 1542 1543 static inline void br_multicast_update_vlan_mcast_ctx(struct net_bridge_vlan *v, 1544 u8 state) 1545 { 1546 } 1547 1548 static inline void br_multicast_toggle_one_vlan(struct net_bridge_vlan *vlan, 1549 bool on) 1550 { 1551 } 1552 1553 static inline int br_multicast_toggle_vlan_snooping(struct net_bridge *br, 1554 bool on, 1555 struct netlink_ext_ack *extack) 1556 { 1557 return -EOPNOTSUPP; 1558 } 1559 1560 static inline bool br_multicast_toggle_global_vlan(struct net_bridge_vlan *vlan, 1561 bool on) 1562 { 1563 return false; 1564 } 1565 1566 static inline bool 1567 br_multicast_ctx_options_equal(const struct net_bridge_mcast *brmctx1, 1568 const struct net_bridge_mcast *brmctx2) 1569 { 1570 return true; 1571 } 1572 #endif 1573 1574 /* br_vlan.c */ 1575 #ifdef CONFIG_BRIDGE_VLAN_FILTERING 1576 bool br_allowed_ingress(const struct net_bridge *br, 1577 struct net_bridge_vlan_group *vg, struct sk_buff *skb, 1578 u16 *vid, u8 *state, 1579 struct net_bridge_vlan **vlan); 1580 bool br_allowed_egress(struct net_bridge_vlan_group *vg, 1581 const struct sk_buff *skb); 1582 bool br_should_learn(struct net_bridge_port *p, struct sk_buff *skb, u16 *vid); 1583 struct sk_buff *br_handle_vlan(struct net_bridge *br, 1584 const struct net_bridge_port *port, 1585 struct net_bridge_vlan_group *vg, 1586 struct sk_buff *skb); 1587 int br_vlan_add(struct net_bridge *br, u16 vid, u16 flags, 1588 bool *changed, struct netlink_ext_ack *extack); 1589 int br_vlan_delete(struct net_bridge *br, u16 vid); 1590 void br_vlan_flush(struct net_bridge *br); 1591 struct net_bridge_vlan *br_vlan_find(struct net_bridge_vlan_group *vg, u16 vid); 1592 void br_recalculate_fwd_mask(struct net_bridge *br); 1593 int br_vlan_filter_toggle(struct net_bridge *br, unsigned long val, 1594 struct netlink_ext_ack *extack); 1595 int __br_vlan_set_proto(struct net_bridge *br, __be16 proto, 1596 struct netlink_ext_ack *extack); 1597 int br_vlan_set_proto(struct net_bridge *br, unsigned long val, 1598 struct netlink_ext_ack *extack); 1599 int br_vlan_set_stats(struct net_bridge *br, unsigned long val); 1600 int br_vlan_set_stats_per_port(struct net_bridge *br, unsigned long val); 1601 int br_vlan_init(struct net_bridge *br); 1602 int br_vlan_set_default_pvid(struct net_bridge *br, unsigned long val, 1603 struct netlink_ext_ack *extack); 1604 int __br_vlan_set_default_pvid(struct net_bridge *br, u16 pvid, 1605 struct netlink_ext_ack *extack); 1606 int nbp_vlan_add(struct net_bridge_port *port, u16 vid, u16 flags, 1607 bool *changed, struct netlink_ext_ack *extack); 1608 int nbp_vlan_delete(struct net_bridge_port *port, u16 vid); 1609 void nbp_vlan_flush(struct net_bridge_port *port); 1610 int nbp_vlan_init(struct net_bridge_port *port, struct netlink_ext_ack *extack); 1611 int nbp_get_num_vlan_infos(struct net_bridge_port *p, u32 filter_mask); 1612 void br_vlan_get_stats(const struct net_bridge_vlan *v, 1613 struct pcpu_sw_netstats *stats); 1614 void br_vlan_port_event(struct net_bridge_port *p, unsigned long event); 1615 int br_vlan_bridge_event(struct net_device *dev, unsigned long event, 1616 void *ptr); 1617 void br_vlan_vlan_upper_event(struct net_device *br_dev, 1618 struct net_device *vlan_dev, 1619 unsigned long event); 1620 int br_vlan_rtnl_init(void); 1621 void br_vlan_rtnl_uninit(void); 1622 void br_vlan_notify(const struct net_bridge *br, 1623 const struct net_bridge_port *p, 1624 u16 vid, u16 vid_range, 1625 int cmd); 1626 bool br_vlan_can_enter_range(const struct net_bridge_vlan *v_curr, 1627 const struct net_bridge_vlan *range_end); 1628 1629 void br_vlan_fill_forward_path_pvid(struct net_bridge *br, 1630 struct net_device_path_ctx *ctx, 1631 struct net_device_path *path); 1632 int br_vlan_fill_forward_path_mode(struct net_bridge *br, 1633 struct net_bridge_port *dst, 1634 struct net_device_path *path); 1635 1636 static inline struct net_bridge_vlan_group *br_vlan_group( 1637 const struct net_bridge *br) 1638 { 1639 return rtnl_dereference(br->vlgrp); 1640 } 1641 1642 static inline struct net_bridge_vlan_group *nbp_vlan_group( 1643 const struct net_bridge_port *p) 1644 { 1645 return rtnl_dereference(p->vlgrp); 1646 } 1647 1648 static inline struct net_bridge_vlan_group *br_vlan_group_rcu( 1649 const struct net_bridge *br) 1650 { 1651 return rcu_dereference(br->vlgrp); 1652 } 1653 1654 static inline struct net_bridge_vlan_group *nbp_vlan_group_rcu( 1655 const struct net_bridge_port *p) 1656 { 1657 return rcu_dereference(p->vlgrp); 1658 } 1659 1660 /* Since bridge now depends on 8021Q module, but the time bridge sees the 1661 * skb, the vlan tag will always be present if the frame was tagged. 1662 */ 1663 static inline int br_vlan_get_tag(const struct sk_buff *skb, u16 *vid) 1664 { 1665 int err = 0; 1666 1667 if (skb_vlan_tag_present(skb)) { 1668 *vid = skb_vlan_tag_get_id(skb); 1669 } else { 1670 *vid = 0; 1671 err = -EINVAL; 1672 } 1673 1674 return err; 1675 } 1676 1677 static inline u16 br_get_pvid(const struct net_bridge_vlan_group *vg) 1678 { 1679 if (!vg) 1680 return 0; 1681 1682 smp_rmb(); 1683 return vg->pvid; 1684 } 1685 1686 static inline u16 br_vlan_flags(const struct net_bridge_vlan *v, u16 pvid) 1687 { 1688 return v->vid == pvid ? v->flags | BRIDGE_VLAN_INFO_PVID : v->flags; 1689 } 1690 #else 1691 static inline bool br_allowed_ingress(const struct net_bridge *br, 1692 struct net_bridge_vlan_group *vg, 1693 struct sk_buff *skb, 1694 u16 *vid, u8 *state, 1695 struct net_bridge_vlan **vlan) 1696 1697 { 1698 *vlan = NULL; 1699 return true; 1700 } 1701 1702 static inline bool br_allowed_egress(struct net_bridge_vlan_group *vg, 1703 const struct sk_buff *skb) 1704 { 1705 return true; 1706 } 1707 1708 static inline bool br_should_learn(struct net_bridge_port *p, 1709 struct sk_buff *skb, u16 *vid) 1710 { 1711 return true; 1712 } 1713 1714 static inline struct sk_buff *br_handle_vlan(struct net_bridge *br, 1715 const struct net_bridge_port *port, 1716 struct net_bridge_vlan_group *vg, 1717 struct sk_buff *skb) 1718 { 1719 return skb; 1720 } 1721 1722 static inline int br_vlan_add(struct net_bridge *br, u16 vid, u16 flags, 1723 bool *changed, struct netlink_ext_ack *extack) 1724 { 1725 *changed = false; 1726 return -EOPNOTSUPP; 1727 } 1728 1729 static inline int br_vlan_delete(struct net_bridge *br, u16 vid) 1730 { 1731 return -EOPNOTSUPP; 1732 } 1733 1734 static inline void br_vlan_flush(struct net_bridge *br) 1735 { 1736 } 1737 1738 static inline void br_recalculate_fwd_mask(struct net_bridge *br) 1739 { 1740 } 1741 1742 static inline int br_vlan_init(struct net_bridge *br) 1743 { 1744 return 0; 1745 } 1746 1747 static inline int nbp_vlan_add(struct net_bridge_port *port, u16 vid, u16 flags, 1748 bool *changed, struct netlink_ext_ack *extack) 1749 { 1750 *changed = false; 1751 return -EOPNOTSUPP; 1752 } 1753 1754 static inline int nbp_vlan_delete(struct net_bridge_port *port, u16 vid) 1755 { 1756 return -EOPNOTSUPP; 1757 } 1758 1759 static inline void nbp_vlan_flush(struct net_bridge_port *port) 1760 { 1761 } 1762 1763 static inline struct net_bridge_vlan *br_vlan_find(struct net_bridge_vlan_group *vg, 1764 u16 vid) 1765 { 1766 return NULL; 1767 } 1768 1769 static inline int nbp_vlan_init(struct net_bridge_port *port, 1770 struct netlink_ext_ack *extack) 1771 { 1772 return 0; 1773 } 1774 1775 static inline u16 br_vlan_get_tag(const struct sk_buff *skb, u16 *tag) 1776 { 1777 return 0; 1778 } 1779 1780 static inline u16 br_get_pvid(const struct net_bridge_vlan_group *vg) 1781 { 1782 return 0; 1783 } 1784 1785 static inline int br_vlan_filter_toggle(struct net_bridge *br, 1786 unsigned long val, 1787 struct netlink_ext_ack *extack) 1788 { 1789 return -EOPNOTSUPP; 1790 } 1791 1792 static inline int nbp_get_num_vlan_infos(struct net_bridge_port *p, 1793 u32 filter_mask) 1794 { 1795 return 0; 1796 } 1797 1798 static inline void br_vlan_fill_forward_path_pvid(struct net_bridge *br, 1799 struct net_device_path_ctx *ctx, 1800 struct net_device_path *path) 1801 { 1802 } 1803 1804 static inline int br_vlan_fill_forward_path_mode(struct net_bridge *br, 1805 struct net_bridge_port *dst, 1806 struct net_device_path *path) 1807 { 1808 return 0; 1809 } 1810 1811 static inline struct net_bridge_vlan_group *br_vlan_group( 1812 const struct net_bridge *br) 1813 { 1814 return NULL; 1815 } 1816 1817 static inline struct net_bridge_vlan_group *nbp_vlan_group( 1818 const struct net_bridge_port *p) 1819 { 1820 return NULL; 1821 } 1822 1823 static inline struct net_bridge_vlan_group *br_vlan_group_rcu( 1824 const struct net_bridge *br) 1825 { 1826 return NULL; 1827 } 1828 1829 static inline struct net_bridge_vlan_group *nbp_vlan_group_rcu( 1830 const struct net_bridge_port *p) 1831 { 1832 return NULL; 1833 } 1834 1835 static inline void br_vlan_get_stats(const struct net_bridge_vlan *v, 1836 struct pcpu_sw_netstats *stats) 1837 { 1838 } 1839 1840 static inline void br_vlan_port_event(struct net_bridge_port *p, 1841 unsigned long event) 1842 { 1843 } 1844 1845 static inline int br_vlan_bridge_event(struct net_device *dev, 1846 unsigned long event, void *ptr) 1847 { 1848 return 0; 1849 } 1850 1851 static inline void br_vlan_vlan_upper_event(struct net_device *br_dev, 1852 struct net_device *vlan_dev, 1853 unsigned long event) 1854 { 1855 } 1856 1857 static inline int br_vlan_rtnl_init(void) 1858 { 1859 return 0; 1860 } 1861 1862 static inline void br_vlan_rtnl_uninit(void) 1863 { 1864 } 1865 1866 static inline void br_vlan_notify(const struct net_bridge *br, 1867 const struct net_bridge_port *p, 1868 u16 vid, u16 vid_range, 1869 int cmd) 1870 { 1871 } 1872 1873 static inline bool br_vlan_can_enter_range(const struct net_bridge_vlan *v_curr, 1874 const struct net_bridge_vlan *range_end) 1875 { 1876 return true; 1877 } 1878 1879 static inline u16 br_vlan_flags(const struct net_bridge_vlan *v, u16 pvid) 1880 { 1881 return 0; 1882 } 1883 1884 #endif 1885 1886 /* br_vlan_options.c */ 1887 #ifdef CONFIG_BRIDGE_VLAN_FILTERING 1888 bool br_vlan_opts_eq_range(const struct net_bridge_vlan *v_curr, 1889 const struct net_bridge_vlan *range_end); 1890 bool br_vlan_opts_fill(struct sk_buff *skb, const struct net_bridge_vlan *v, 1891 const struct net_bridge_port *p); 1892 size_t br_vlan_opts_nl_size(void); 1893 int br_vlan_process_options(const struct net_bridge *br, 1894 const struct net_bridge_port *p, 1895 struct net_bridge_vlan *range_start, 1896 struct net_bridge_vlan *range_end, 1897 struct nlattr **tb, 1898 struct netlink_ext_ack *extack); 1899 int br_vlan_rtm_process_global_options(struct net_device *dev, 1900 const struct nlattr *attr, 1901 int cmd, 1902 struct netlink_ext_ack *extack); 1903 bool br_vlan_global_opts_can_enter_range(const struct net_bridge_vlan *v_curr, 1904 const struct net_bridge_vlan *r_end); 1905 bool br_vlan_global_opts_fill(struct sk_buff *skb, u16 vid, u16 vid_range, 1906 const struct net_bridge_vlan *v_opts); 1907 1908 /* vlan state manipulation helpers using *_ONCE to annotate lock-free access, 1909 * while br_vlan_set_state() may access data protected by multicast_lock. 1910 */ 1911 static inline u8 br_vlan_get_state(const struct net_bridge_vlan *v) 1912 { 1913 return READ_ONCE(v->state); 1914 } 1915 1916 static inline void br_vlan_set_state(struct net_bridge_vlan *v, u8 state) 1917 { 1918 WRITE_ONCE(v->state, state); 1919 br_multicast_update_vlan_mcast_ctx(v, state); 1920 } 1921 1922 static inline u8 br_vlan_get_pvid_state(const struct net_bridge_vlan_group *vg) 1923 { 1924 return READ_ONCE(vg->pvid_state); 1925 } 1926 1927 static inline void br_vlan_set_pvid_state(struct net_bridge_vlan_group *vg, 1928 u8 state) 1929 { 1930 WRITE_ONCE(vg->pvid_state, state); 1931 } 1932 1933 /* learn_allow is true at ingress and false at egress */ 1934 static inline bool br_vlan_state_allowed(u8 state, bool learn_allow) 1935 { 1936 switch (state) { 1937 case BR_STATE_LEARNING: 1938 return learn_allow; 1939 case BR_STATE_FORWARDING: 1940 return true; 1941 default: 1942 return false; 1943 } 1944 } 1945 #endif 1946 1947 /* br_mst.c */ 1948 #ifdef CONFIG_BRIDGE_VLAN_FILTERING 1949 DECLARE_STATIC_KEY_FALSE(br_mst_used); 1950 static inline bool br_mst_is_enabled(const struct net_bridge_port *p) 1951 { 1952 /* check the port's vlan group to avoid racing with port deletion */ 1953 return static_branch_unlikely(&br_mst_used) && 1954 br_opt_get(p->br, BROPT_MST_ENABLED) && 1955 rcu_access_pointer(p->vlgrp); 1956 } 1957 1958 int br_mst_set_state(struct net_bridge_port *p, u16 msti, u8 state, 1959 struct netlink_ext_ack *extack); 1960 int br_mst_vlan_set_msti(struct net_bridge_vlan *v, u16 msti); 1961 void br_mst_vlan_init_state(struct net_bridge_vlan *v); 1962 int br_mst_set_enabled(struct net_bridge *br, bool on, 1963 struct netlink_ext_ack *extack); 1964 size_t br_mst_info_size(const struct net_bridge_vlan_group *vg); 1965 int br_mst_fill_info(struct sk_buff *skb, 1966 const struct net_bridge_vlan_group *vg); 1967 int br_mst_process(struct net_bridge_port *p, const struct nlattr *mst_attr, 1968 struct netlink_ext_ack *extack); 1969 void br_mst_uninit(struct net_bridge *br); 1970 #else 1971 static inline bool br_mst_is_enabled(const struct net_bridge_port *p) 1972 { 1973 return false; 1974 } 1975 1976 static inline int br_mst_set_state(struct net_bridge_port *p, u16 msti, 1977 u8 state, struct netlink_ext_ack *extack) 1978 { 1979 return -EOPNOTSUPP; 1980 } 1981 1982 static inline int br_mst_set_enabled(struct net_bridge *br, bool on, 1983 struct netlink_ext_ack *extack) 1984 { 1985 return -EOPNOTSUPP; 1986 } 1987 1988 static inline size_t br_mst_info_size(const struct net_bridge_vlan_group *vg) 1989 { 1990 return 0; 1991 } 1992 1993 static inline int br_mst_fill_info(struct sk_buff *skb, 1994 const struct net_bridge_vlan_group *vg) 1995 { 1996 return -EOPNOTSUPP; 1997 } 1998 1999 static inline int br_mst_process(struct net_bridge_port *p, 2000 const struct nlattr *mst_attr, 2001 struct netlink_ext_ack *extack) 2002 { 2003 return -EOPNOTSUPP; 2004 } 2005 2006 static inline void br_mst_uninit(struct net_bridge *br) 2007 { 2008 } 2009 #endif 2010 2011 struct nf_br_ops { 2012 int (*br_dev_xmit_hook)(struct sk_buff *skb); 2013 }; 2014 extern const struct nf_br_ops __rcu *nf_br_ops; 2015 2016 /* br_netfilter.c */ 2017 #if IS_ENABLED(CONFIG_BRIDGE_NETFILTER) 2018 int br_nf_core_init(void); 2019 void br_nf_core_fini(void); 2020 void br_netfilter_rtable_init(struct net_bridge *); 2021 #else 2022 static inline int br_nf_core_init(void) { return 0; } 2023 static inline void br_nf_core_fini(void) {} 2024 #define br_netfilter_rtable_init(x) 2025 #endif 2026 2027 /* br_stp.c */ 2028 void br_set_state(struct net_bridge_port *p, unsigned int state); 2029 struct net_bridge_port *br_get_port(struct net_bridge *br, u16 port_no); 2030 void br_init_port(struct net_bridge_port *p); 2031 void br_become_designated_port(struct net_bridge_port *p); 2032 2033 void __br_set_forward_delay(struct net_bridge *br, unsigned long t); 2034 int br_set_forward_delay(struct net_bridge *br, unsigned long x); 2035 int br_set_hello_time(struct net_bridge *br, unsigned long x); 2036 int br_set_max_age(struct net_bridge *br, unsigned long x); 2037 int __set_ageing_time(struct net_device *dev, unsigned long t); 2038 int br_set_ageing_time(struct net_bridge *br, clock_t ageing_time); 2039 2040 2041 /* br_stp_if.c */ 2042 void br_stp_enable_bridge(struct net_bridge *br); 2043 void br_stp_disable_bridge(struct net_bridge *br); 2044 int br_stp_set_enabled(struct net_bridge *br, unsigned long val, 2045 struct netlink_ext_ack *extack); 2046 void br_stp_enable_port(struct net_bridge_port *p); 2047 void br_stp_disable_port(struct net_bridge_port *p); 2048 bool br_stp_recalculate_bridge_id(struct net_bridge *br); 2049 void br_stp_change_bridge_id(struct net_bridge *br, const unsigned char *a); 2050 void br_stp_set_bridge_priority(struct net_bridge *br, u16 newprio); 2051 int br_stp_set_port_priority(struct net_bridge_port *p, unsigned long newprio); 2052 int br_stp_set_path_cost(struct net_bridge_port *p, unsigned long path_cost); 2053 ssize_t br_show_bridge_id(char *buf, const struct bridge_id *id); 2054 2055 /* br_stp_bpdu.c */ 2056 struct stp_proto; 2057 void br_stp_rcv(const struct stp_proto *proto, struct sk_buff *skb, 2058 struct net_device *dev); 2059 2060 /* br_stp_timer.c */ 2061 void br_stp_timer_init(struct net_bridge *br); 2062 void br_stp_port_timer_init(struct net_bridge_port *p); 2063 unsigned long br_timer_value(const struct timer_list *timer); 2064 2065 /* br.c */ 2066 #if IS_ENABLED(CONFIG_ATM_LANE) 2067 extern int (*br_fdb_test_addr_hook)(struct net_device *dev, unsigned char *addr); 2068 #endif 2069 2070 /* br_mrp.c */ 2071 #if IS_ENABLED(CONFIG_BRIDGE_MRP) 2072 int br_mrp_parse(struct net_bridge *br, struct net_bridge_port *p, 2073 struct nlattr *attr, int cmd, struct netlink_ext_ack *extack); 2074 bool br_mrp_enabled(struct net_bridge *br); 2075 void br_mrp_port_del(struct net_bridge *br, struct net_bridge_port *p); 2076 int br_mrp_fill_info(struct sk_buff *skb, struct net_bridge *br); 2077 #else 2078 static inline int br_mrp_parse(struct net_bridge *br, struct net_bridge_port *p, 2079 struct nlattr *attr, int cmd, 2080 struct netlink_ext_ack *extack) 2081 { 2082 return -EOPNOTSUPP; 2083 } 2084 2085 static inline bool br_mrp_enabled(struct net_bridge *br) 2086 { 2087 return false; 2088 } 2089 2090 static inline void br_mrp_port_del(struct net_bridge *br, 2091 struct net_bridge_port *p) 2092 { 2093 } 2094 2095 static inline int br_mrp_fill_info(struct sk_buff *skb, struct net_bridge *br) 2096 { 2097 return 0; 2098 } 2099 2100 #endif 2101 2102 /* br_cfm.c */ 2103 #if IS_ENABLED(CONFIG_BRIDGE_CFM) 2104 int br_cfm_parse(struct net_bridge *br, struct net_bridge_port *p, 2105 struct nlattr *attr, int cmd, struct netlink_ext_ack *extack); 2106 bool br_cfm_created(struct net_bridge *br); 2107 void br_cfm_port_del(struct net_bridge *br, struct net_bridge_port *p); 2108 int br_cfm_config_fill_info(struct sk_buff *skb, struct net_bridge *br); 2109 int br_cfm_status_fill_info(struct sk_buff *skb, 2110 struct net_bridge *br, 2111 bool getlink); 2112 int br_cfm_mep_count(struct net_bridge *br, u32 *count); 2113 int br_cfm_peer_mep_count(struct net_bridge *br, u32 *count); 2114 #else 2115 static inline int br_cfm_parse(struct net_bridge *br, struct net_bridge_port *p, 2116 struct nlattr *attr, int cmd, 2117 struct netlink_ext_ack *extack) 2118 { 2119 return -EOPNOTSUPP; 2120 } 2121 2122 static inline bool br_cfm_created(struct net_bridge *br) 2123 { 2124 return false; 2125 } 2126 2127 static inline void br_cfm_port_del(struct net_bridge *br, 2128 struct net_bridge_port *p) 2129 { 2130 } 2131 2132 static inline int br_cfm_config_fill_info(struct sk_buff *skb, struct net_bridge *br) 2133 { 2134 return -EOPNOTSUPP; 2135 } 2136 2137 static inline int br_cfm_status_fill_info(struct sk_buff *skb, 2138 struct net_bridge *br, 2139 bool getlink) 2140 { 2141 return -EOPNOTSUPP; 2142 } 2143 2144 static inline int br_cfm_mep_count(struct net_bridge *br, u32 *count) 2145 { 2146 *count = 0; 2147 return -EOPNOTSUPP; 2148 } 2149 2150 static inline int br_cfm_peer_mep_count(struct net_bridge *br, u32 *count) 2151 { 2152 *count = 0; 2153 return -EOPNOTSUPP; 2154 } 2155 #endif 2156 2157 /* br_netlink.c */ 2158 extern struct rtnl_link_ops br_link_ops; 2159 int br_netlink_init(void); 2160 void br_netlink_fini(void); 2161 void br_ifinfo_notify(int event, const struct net_bridge *br, 2162 const struct net_bridge_port *port); 2163 void br_info_notify(int event, const struct net_bridge *br, 2164 const struct net_bridge_port *port, u32 filter); 2165 int br_setlink(struct net_device *dev, struct nlmsghdr *nlmsg, u16 flags, 2166 struct netlink_ext_ack *extack); 2167 int br_dellink(struct net_device *dev, struct nlmsghdr *nlmsg, u16 flags); 2168 int br_getlink(struct sk_buff *skb, u32 pid, u32 seq, struct net_device *dev, 2169 u32 filter_mask, int nlflags); 2170 int br_process_vlan_info(struct net_bridge *br, 2171 struct net_bridge_port *p, int cmd, 2172 struct bridge_vlan_info *vinfo_curr, 2173 struct bridge_vlan_info **vinfo_last, 2174 bool *changed, 2175 struct netlink_ext_ack *extack); 2176 2177 #ifdef CONFIG_SYSFS 2178 /* br_sysfs_if.c */ 2179 extern const struct sysfs_ops brport_sysfs_ops; 2180 int br_sysfs_addif(struct net_bridge_port *p); 2181 int br_sysfs_renameif(struct net_bridge_port *p); 2182 2183 /* br_sysfs_br.c */ 2184 int br_sysfs_addbr(struct net_device *dev); 2185 void br_sysfs_delbr(struct net_device *dev); 2186 2187 #else 2188 2189 static inline int br_sysfs_addif(struct net_bridge_port *p) { return 0; } 2190 static inline int br_sysfs_renameif(struct net_bridge_port *p) { return 0; } 2191 static inline int br_sysfs_addbr(struct net_device *dev) { return 0; } 2192 static inline void br_sysfs_delbr(struct net_device *dev) { return; } 2193 #endif /* CONFIG_SYSFS */ 2194 2195 /* br_switchdev.c */ 2196 #ifdef CONFIG_NET_SWITCHDEV 2197 int br_switchdev_port_offload(struct net_bridge_port *p, 2198 struct net_device *dev, const void *ctx, 2199 struct notifier_block *atomic_nb, 2200 struct notifier_block *blocking_nb, 2201 bool tx_fwd_offload, 2202 struct netlink_ext_ack *extack); 2203 2204 void br_switchdev_port_unoffload(struct net_bridge_port *p, const void *ctx, 2205 struct notifier_block *atomic_nb, 2206 struct notifier_block *blocking_nb); 2207 2208 int br_switchdev_port_replay(struct net_bridge_port *p, 2209 struct net_device *dev, const void *ctx, 2210 struct notifier_block *atomic_nb, 2211 struct notifier_block *blocking_nb, 2212 struct netlink_ext_ack *extack); 2213 2214 bool br_switchdev_frame_uses_tx_fwd_offload(struct sk_buff *skb); 2215 2216 void br_switchdev_frame_set_offload_fwd_mark(struct sk_buff *skb); 2217 2218 void nbp_switchdev_frame_mark_tx_fwd_offload(const struct net_bridge_port *p, 2219 struct sk_buff *skb); 2220 void nbp_switchdev_frame_mark_tx_fwd_to_hwdom(const struct net_bridge_port *p, 2221 struct sk_buff *skb); 2222 void nbp_switchdev_frame_mark(const struct net_bridge_port *p, 2223 struct sk_buff *skb); 2224 bool nbp_switchdev_allowed_egress(const struct net_bridge_port *p, 2225 const struct sk_buff *skb); 2226 int br_switchdev_set_port_flag(struct net_bridge_port *p, 2227 unsigned long flags, 2228 unsigned long mask, 2229 struct netlink_ext_ack *extack); 2230 void br_switchdev_fdb_notify(struct net_bridge *br, 2231 const struct net_bridge_fdb_entry *fdb, int type); 2232 void br_switchdev_mdb_notify(struct net_device *dev, 2233 struct net_bridge_mdb_entry *mp, 2234 struct net_bridge_port_group *pg, 2235 int type); 2236 int br_switchdev_port_vlan_add(struct net_device *dev, u16 vid, u16 flags, 2237 bool changed, struct netlink_ext_ack *extack); 2238 int br_switchdev_port_vlan_no_foreign_add(struct net_device *dev, u16 vid, u16 flags, 2239 bool changed, struct netlink_ext_ack *extack); 2240 int br_switchdev_port_vlan_del(struct net_device *dev, u16 vid); 2241 void br_switchdev_init(struct net_bridge *br); 2242 2243 static inline void br_switchdev_frame_unmark(struct sk_buff *skb) 2244 { 2245 skb->offload_fwd_mark = 0; 2246 } 2247 #else 2248 static inline int 2249 br_switchdev_port_offload(struct net_bridge_port *p, 2250 struct net_device *dev, const void *ctx, 2251 struct notifier_block *atomic_nb, 2252 struct notifier_block *blocking_nb, 2253 bool tx_fwd_offload, 2254 struct netlink_ext_ack *extack) 2255 { 2256 return -EOPNOTSUPP; 2257 } 2258 2259 static inline void 2260 br_switchdev_port_unoffload(struct net_bridge_port *p, const void *ctx, 2261 struct notifier_block *atomic_nb, 2262 struct notifier_block *blocking_nb) 2263 { 2264 } 2265 2266 static inline int 2267 br_switchdev_port_replay(struct net_bridge_port *p, 2268 struct net_device *dev, const void *ctx, 2269 struct notifier_block *atomic_nb, 2270 struct notifier_block *blocking_nb, 2271 struct netlink_ext_ack *extack) 2272 { 2273 return -EOPNOTSUPP; 2274 } 2275 2276 static inline bool br_switchdev_frame_uses_tx_fwd_offload(struct sk_buff *skb) 2277 { 2278 return false; 2279 } 2280 2281 static inline void br_switchdev_frame_set_offload_fwd_mark(struct sk_buff *skb) 2282 { 2283 } 2284 2285 static inline void 2286 nbp_switchdev_frame_mark_tx_fwd_offload(const struct net_bridge_port *p, 2287 struct sk_buff *skb) 2288 { 2289 } 2290 2291 static inline void 2292 nbp_switchdev_frame_mark_tx_fwd_to_hwdom(const struct net_bridge_port *p, 2293 struct sk_buff *skb) 2294 { 2295 } 2296 2297 static inline void nbp_switchdev_frame_mark(const struct net_bridge_port *p, 2298 struct sk_buff *skb) 2299 { 2300 } 2301 2302 static inline bool nbp_switchdev_allowed_egress(const struct net_bridge_port *p, 2303 const struct sk_buff *skb) 2304 { 2305 return true; 2306 } 2307 2308 static inline int br_switchdev_set_port_flag(struct net_bridge_port *p, 2309 unsigned long flags, 2310 unsigned long mask, 2311 struct netlink_ext_ack *extack) 2312 { 2313 return 0; 2314 } 2315 2316 static inline int br_switchdev_port_vlan_add(struct net_device *dev, u16 vid, 2317 u16 flags, bool changed, 2318 struct netlink_ext_ack *extack) 2319 { 2320 return -EOPNOTSUPP; 2321 } 2322 2323 static inline int br_switchdev_port_vlan_no_foreign_add(struct net_device *dev, u16 vid, 2324 u16 flags, bool changed, 2325 struct netlink_ext_ack *extack) 2326 { 2327 return -EOPNOTSUPP; 2328 } 2329 2330 static inline int br_switchdev_port_vlan_del(struct net_device *dev, u16 vid) 2331 { 2332 return -EOPNOTSUPP; 2333 } 2334 2335 static inline void 2336 br_switchdev_fdb_notify(struct net_bridge *br, 2337 const struct net_bridge_fdb_entry *fdb, int type) 2338 { 2339 } 2340 2341 static inline void br_switchdev_mdb_notify(struct net_device *dev, 2342 struct net_bridge_mdb_entry *mp, 2343 struct net_bridge_port_group *pg, 2344 int type) 2345 { 2346 } 2347 2348 static inline void br_switchdev_frame_unmark(struct sk_buff *skb) 2349 { 2350 } 2351 2352 static inline void br_switchdev_init(struct net_bridge *br) 2353 { 2354 } 2355 2356 #endif /* CONFIG_NET_SWITCHDEV */ 2357 2358 /* br_arp_nd_proxy.c */ 2359 void br_recalculate_neigh_suppress_enabled(struct net_bridge *br); 2360 void br_do_proxy_suppress_arp(struct sk_buff *skb, struct net_bridge *br, 2361 u16 vid, struct net_bridge_port *p); 2362 void br_do_suppress_nd(struct sk_buff *skb, struct net_bridge *br, 2363 u16 vid, struct net_bridge_port *p, struct nd_msg *msg); 2364 struct nd_msg *br_is_nd_neigh_msg(const struct sk_buff *skb, struct nd_msg *m); 2365 bool br_is_neigh_suppress_enabled(const struct net_bridge_port *p, u16 vid); 2366 #endif 2367