From nobody Mon Feb 9 00:31:14 2026 Received: from mail-ej1-f51.google.com (mail-ej1-f51.google.com [209.85.218.51]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 18C78331A4F for ; Mon, 10 Nov 2025 21:45:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.218.51 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1762811122; cv=none; b=Ym4de0B2LXV6LI++R732y8xN6Y5o+aoaQgVoHlerOSL6gyiTHoqxpLhEdl6eadSYPuhXER7fkiKsXo6KJd3e2r8JyPeXde1rGsOZHcpq8Y7ohaFMpT7DF8m5m9tCPEKQ2TEtjWhfB6dlonzYZQKdhdKUo9H9qFzP/hSr4uxNRnI= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1762811122; c=relaxed/simple; bh=4JXbHE4jomV2cfwYF80hI5yre6LwFMYOFIy0n9rH/fg=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=mCG66EYyJfe5Tq9ax00lQHK/DrqA/7vgkW1x0JeXUoGTzsYUR5thg3cd6X0vsfceSCG2x1E41pbVQpsOvapEZ+5r9Lt78iRvDsAiF2ERUG06gS71pBwo+vQlzFKp9KaPK5bn/UAPr46IyqLqxe75hQWiJQh6K65A/qdbkgE6MhQ= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=erDTu0KC; arc=none smtp.client-ip=209.85.218.51 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="erDTu0KC" Received: by mail-ej1-f51.google.com with SMTP id a640c23a62f3a-b7321b03aecso3707366b.3 for ; Mon, 10 Nov 2025 13:45:19 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1762811118; x=1763415918; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=840dLR3TffmVB9X6YIETKfX5Uiq2NyaIKt8jaa7Xq4E=; b=erDTu0KCqQLNZOBANn5of3UYM692MKqExlk4BCFGlcwVQfcUBevJtj6pp8kVAQSTfk 2YHQ3wSoy1B5AeoAyzlz3AkDjLdxYamZ21Gx2zM29Kr56PIWMQXYDvi63igbdzVhhzCw PB83p9H/idov9/DMOvNcZzgnM83co1LxU+IbA0iGHkcxxS87x4VHj5xjo4yvxT/6xC2R 9IxbeCyOmSldhBXKDvSvLGbA5pQgvrAnsukiIhOV+eAr40KEAaT4F6aCDI/DowG6BIza F6eClCObqPDVtmfMrfmfrLcHaWKgFmOee9gDqq6P11fKhfMtc2M1xBuqrqcLL3Z/tjyn Dn2Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1762811118; x=1763415918; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=840dLR3TffmVB9X6YIETKfX5Uiq2NyaIKt8jaa7Xq4E=; b=qI7cyUI9eqvDReV+4wtjruss7XJXqUTvv6PrXz9zZlcL9nBuMJzLOx2w3jNwBaO1ZX 1P8zh3GbWPzxqpxgRrzC90CHoPHywIYlaSWcv0OSHzVQyLUwTP50r5DwIUccQiySsYL5 0nvXuw+hvMmG4nmVLoElj8FfK7rf5iQFzWXAJBTs+F+uAiEeS3Q8thiJPJiQduqGvqqd AD219u6FwO8eIR/aZ68veuzBXFCvO9kZIsSojvx3R7FRCKXgj9nm+w0rVHFXbIu8UKdS GfM3GzHQTcUa4QNhL7ozDgK/Hb4kyadJKub1Qj9wlzdoJOIQLeHaADNxiKA3kLTb9gxq +g1g== X-Forwarded-Encrypted: i=1; AJvYcCXd8CpqefZ2rOtHz1BBnlmmOa4LlyPzC70P51s47m0lUkTqPaBhlYuXOawudfVDdT9j3YRjX1o6PoB9Txo=@vger.kernel.org X-Gm-Message-State: AOJu0YzXxpzvYUi8XsHugUcMqNTzCDzrOrLkibcBuTQ7vJ4TbN6mkLUt FJt8qEtH+O3ckMR6C5DE7c+EQLyttjZ6d+uWgKdUwKNs7sEcD/Np5GjH X-Gm-Gg: ASbGncvb718XBNAG0uMZt4T2Du0mhnJdDFaKZPOMl9cVjrR4hpZs1hP3oqX1cfy+0LA iEB2w1svBW41E510v8XCfIt8Qcn1sdKBlJv4nWmkoNN8hXgCrZWYJZoJtPZl70+zAB1pCIvByYj FvN0IbsUgOErQJvgSznW8uris8kQ6QSsldf7jSV6xQFFHgdzREenURC1ye+oMU52v9T4ozVZ/Wu zfVPlJlcQ2P2kWgn0M41sT3nU39OiYlVXSPDjVfqC0V0BhmBBq9fj8bEZaLAacdmc7e0YkpbMeb /8MrYqUbKsk0zXDFVqDRSg0Uq4jagm0UNZ7EdHnUYPOc0oRwI3MWJoEeVhr8m8grrntky91CHIg VHEwO1V/F9rZUTCy6KxshnZh8dOV0bvnnNX3fdxYLxnH9FVQm9Fe635LGhUeAn9dVOogX9bXBko D6n//yOqN/eSQJXv8TzIoAn93IEJdQhbG7c02PrJE6NLS0dzX9XnkYwxYfDGDrho8sbFk= X-Google-Smtp-Source: AGHT+IFhtB35qNO40KIb+McYDI8DuYUDh30HMzmkWInvkJciIVeFC/FNvZaoK/NXqRGDmTtF5HjxIw== X-Received: by 2002:a17:907:3f99:b0:b72:58b6:b26f with SMTP id a640c23a62f3a-b72e04e368bmr815459966b.42.1762811118270; Mon, 10 Nov 2025 13:45:18 -0800 (PST) Received: from localhost (dslb-002-205-018-238.002.205.pools.vodafone-ip.de. [2.205.18.238]) by smtp.gmail.com with ESMTPSA id a640c23a62f3a-b72bf97e447sm1260901666b.42.2025.11.10.13.45.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 10 Nov 2025 13:45:17 -0800 (PST) From: Jonas Gorski To: Andrew Lunn , Vladimir Oltean , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Simon Horman , Florian Fainelli Cc: Vladimir Oltean , netdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH RFC net-next 2/3] net: dsa: deny multiple 8021q uppers on bridged ports for the same VLAN Date: Mon, 10 Nov 2025 22:44:42 +0100 Message-ID: <20251110214443.342103-3-jonas.gorski@gmail.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20251110214443.342103-1-jonas.gorski@gmail.com> References: <20251110214443.342103-1-jonas.gorski@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" When creating 8021q uppers on bridged ports on a vlan filtering bridge, we will configure the VLAN on the ports. For the dsa driver, there is no difference between a 8021q upper on bridged port and a port vlan configured within the bridge. For that reason, if we configure a second 8021q upper for the same VLAN on a different port of the bridge, we implicitly enable forwarding between these ports on that VLAN. This breaks the requirement for 8021q uppers for the VLAN to be consumed, so we need to reject these configurations. Reuse dsa_user_vlan_check_for_8021q_uppers() and change its argument to just the vlan id. Before: $ ip link add br0 type bridge vlan_filtering 1 $ ip link set swp1 master br0 $ ip link set swp2 master br0 $ ip link add swp1.100 link GbE1 type vlan id 100 $ ip link add swp2.100 link GbE2 type vlan id 100 $ After: $ ip link add br0 type bridge vlan_filtering 1 $ ip link set swp1 master br0 $ ip link set swp2 master br0 $ ip link add swp1.100 link GbE1 type vlan id 100 $ ip link add swp2.100 link GbE2 type vlan id 100 RTNETLINK answers: Resource busy Signed-off-by: Jonas Gorski --- net/dsa/user.c | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/net/dsa/user.c b/net/dsa/user.c index fa1fe0f1493a..e8c6452780b0 100644 --- a/net/dsa/user.c +++ b/net/dsa/user.c @@ -653,8 +653,7 @@ static int dsa_user_port_attr_set(struct net_device *de= v, const void *ctx, =20 /* Must be called under rcu_read_lock() */ static int -dsa_user_vlan_check_for_8021q_uppers(struct dsa_port *dp, - const struct switchdev_obj_port_vlan *vlan) +dsa_user_vlan_check_for_8021q_uppers(struct dsa_port *dp, u16 other_vid) { struct dsa_switch *ds =3D dp->ds; struct dsa_port *other_dp; @@ -674,7 +673,7 @@ dsa_user_vlan_check_for_8021q_uppers(struct dsa_port *d= p, continue; =20 vid =3D vlan_dev_vlan_id(upper_dev); - if (vid =3D=3D vlan->vid) + if (vid =3D=3D other_vid) return -EBUSY; } } @@ -702,7 +701,7 @@ static int dsa_user_vlan_add(struct net_device *dev, */ if (br_vlan_enabled(dsa_port_bridge_dev_get(dp))) { rcu_read_lock(); - err =3D dsa_user_vlan_check_for_8021q_uppers(dp, vlan); + err =3D dsa_user_vlan_check_for_8021q_uppers(dp, vlan->vid); rcu_read_unlock(); if (err) { NL_SET_ERR_MSG_MOD(extack, @@ -3185,6 +3184,16 @@ dsa_user_check_8021q_upper(struct net_device *dev, return notifier_from_errno(-EBUSY); } =20 + rcu_read_lock(); + err =3D dsa_user_vlan_check_for_8021q_uppers(dp, vid); + rcu_read_unlock(); + + if (err) { + NL_SET_ERR_MSG_MOD(extack, + "This VLAN already has an upper configured on a bridge port"); + return notifier_from_errno(err); + } + return NOTIFY_DONE; } =20 --=20 2.43.0