lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <485A74D1.10900@Voltaire.COM>
Date:	Thu, 19 Jun 2008 18:01:37 +0300
From:	Moni Shoua <monis@...taire.COM>
To:	Jay Vosburgh <fubar@...ibm.com>
CC:	Olga Stern <olgas@...taire.com>,
	Or Gerlitz <ogerlitz@...taire.com>,
	netdev <netdev@...r.kernel.org>
Subject: [PATCH]  net/bonding: Don't destroy bonding master wehn unensalving
 with a sysfs command


It is wrong to destroy a bonding  master from a context that uses the sysfs of
 that bond. When last IPoIB slave is unenslaved from by writing to a sysfs
 file (for bond0 this would be /sys/class/net/bond0/bonding/slaves) the driver
 tries to destroy the bond. This is wrong and can lead to a lockup or a crash.
 This fix lets the bonding master stay and relies on the user to destroy the
 bonding master if necessary (i.e. before module ib_ipoib is unloaded)

This patch affects only bonds of IPoIB slaves. Ethernet slaves stay unaffected.
Signed-off-by: Moni Shoua <monis@...taire.com>
---
 drivers/net/bonding/bond_sysfs.c |    3 ---
 1 files changed, 0 insertions(+), 3 deletions(-)

diff --git a/drivers/net/bonding/bond_sysfs.c b/drivers/net/bonding/bond_sysfs.c
index 08f3d39..f66f590 100644
--- a/drivers/net/bonding/bond_sysfs.c
+++ b/drivers/net/bonding/bond_sysfs.c
@@ -351,9 +351,6 @@ static ssize_t bonding_store_slaves(struct device *d,
 		if (dev) {
 			printk(KERN_INFO DRV_NAME ": %s: Removing slave %s\n",
 				bond->dev->name, dev->name);
-			if (bond->setup_by_slave)
-				res = bond_release_and_destroy(bond->dev, dev);
-			else
 				res = bond_release(bond->dev, dev);
 			if (res) {
 				ret = res;
-- 
1.5.5

--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ