]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/blame - releases/4.4.133/bridge-check-iface-upper-dev-when-setting-master-via-ioctl.patch
Fixes for 4.19
[thirdparty/kernel/stable-queue.git] / releases / 4.4.133 / bridge-check-iface-upper-dev-when-setting-master-via-ioctl.patch
CommitLineData
d55578af
GKH
1From foo@baz Wed May 16 16:57:32 CEST 2018
2From: Hangbin Liu <liuhangbin@gmail.com>
3Date: Fri, 27 Apr 2018 20:59:24 +0800
4Subject: bridge: check iface upper dev when setting master via ioctl
5
6From: Hangbin Liu <liuhangbin@gmail.com>
7
8[ Upstream commit e8238fc2bd7b4c3c7554fa2df067e796610212fc ]
9
10When we set a bond slave's master to bridge via ioctl, we only check
11the IFF_BRIDGE_PORT flag. Although we will find the slave's real master
12at netdev_master_upper_dev_link() later, it already does some settings
13and allocates some resources. It would be better to return as early
14as possible.
15
16v1 -> v2:
17use netdev_master_upper_dev_get() instead of netdev_has_any_upper_dev()
18to check if we have a master, because not all upper devs are masters,
19e.g. vlan device.
20
21Reported-by: syzbot+de73361ee4971b6e6f75@syzkaller.appspotmail.com
22Signed-off-by: Hangbin Liu <liuhangbin@gmail.com>
23Acked-by: Nikolay Aleksandrov <nikolay@cumulusnetworks.com>
24Signed-off-by: David S. Miller <davem@davemloft.net>
25Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
26---
27 net/bridge/br_if.c | 4 ++--
28 1 file changed, 2 insertions(+), 2 deletions(-)
29
30--- a/net/bridge/br_if.c
31+++ b/net/bridge/br_if.c
32@@ -456,8 +456,8 @@ int br_add_if(struct net_bridge *br, str
33 if (dev->netdev_ops->ndo_start_xmit == br_dev_xmit)
34 return -ELOOP;
35
36- /* Device is already being bridged */
37- if (br_port_exists(dev))
38+ /* Device has master upper dev */
39+ if (netdev_master_upper_dev_get(dev))
40 return -EBUSY;
41
42 /* No bridging devices that dislike that (e.g. wireless) */