diff options
| -rw-r--r-- | drivers/net/bonding/bond_main.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c index b47fa0421e01..e5628fc725c3 100644 --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c | |||
| @@ -1197,6 +1197,11 @@ int bond_enslave(struct net_device *bond_dev, struct net_device *slave_dev) | |||
| 1197 | return -EBUSY; | 1197 | return -EBUSY; |
| 1198 | } | 1198 | } |
| 1199 | 1199 | ||
| 1200 | if (bond_dev == slave_dev) { | ||
| 1201 | pr_err("%s: cannot enslave bond to itself.\n", bond_dev->name); | ||
| 1202 | return -EPERM; | ||
| 1203 | } | ||
| 1204 | |||
| 1200 | /* vlan challenged mutual exclusion */ | 1205 | /* vlan challenged mutual exclusion */ |
| 1201 | /* no need to lock since we're protected by rtnl_lock */ | 1206 | /* no need to lock since we're protected by rtnl_lock */ |
| 1202 | if (slave_dev->features & NETIF_F_VLAN_CHALLENGED) { | 1207 | if (slave_dev->features & NETIF_F_VLAN_CHALLENGED) { |
