netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver
@ 2007-10-15 16:00 Moni Shoua
  2007-10-15 16:03 ` [ofa-general] [PATCH V7 1/8] IB/ipoib: Bound the net device to the ipoib_neigh structue Moni Shoua
                   ` (9 more replies)
  0 siblings, 10 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:00 UTC (permalink / raw)
  To: jgarzik, fubar, rdreier; +Cc: netdev, general

This is the 7th version of this patch series. See link to V6 below.

Changes from the previous version
---------------------------------

* Some patches required modifications to remove offsets so they can be applied with git-apply
* Patch #3 was first modified by Jay and later by me to make it work with header_ops
* patch #8 was changed to fix the problem that caused 'ifconfig down' to stuck (dev_close was called twice)

Jay,
I removed the Acked-by lines from patches 3 & 8. Can you please add them back after you approve?

thanks
	MoniS

Link to V6: 
	http://lists.openfabrics.org/pipermail/general/2007-September/041139.html



^ permalink raw reply	[flat|nested] 18+ messages in thread

* [ofa-general] [PATCH V7 1/8] IB/ipoib: Bound the net device to the ipoib_neigh structue
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
@ 2007-10-15 16:03 ` Moni Shoua
  2007-10-15 16:08 ` [ofa-general] [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
                   ` (8 subsequent siblings)
  9 siblings, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:03 UTC (permalink / raw)
  To: jgarzik, fubar, rdreier; +Cc: netdev, general


IPoIB uses a two layer neighboring scheme, such that for each struct neighbour
whose device is an ipoib one, there is a struct ipoib_neigh buddy which is
created on demand at the tx flow by an ipoib_neigh_alloc(skb->dst->neighbour)
call.

When using the bonding driver, neighbours are created by the net stack on behalf
of the bonding (master) device. On the tx flow the bonding code gets an skb such
that skb->dev points to the master device, it changes this skb to point on the
slave device and calls the slave hard_start_xmit function.

Under this scheme, ipoib_neigh_destructor assumption that for each struct
neighbour it gets, n->dev is an ipoib device and hence netdev_priv(n->dev)
can be casted to struct ipoib_dev_priv is buggy.

To fix it, this patch adds a dev field to struct ipoib_neigh which is used
instead of the struct neighbour dev one, when n->dev->flags has the
IFF_MASTER bit set.

Signed-off-by: Moni Shoua <monis at voltaire.com>
Signed-off-by: Or Gerlitz <ogerlitz at voltaire.com>
Acked-by: Roland Dreier <rdreier@cisco.com>
---
 drivers/infiniband/ulp/ipoib/ipoib.h           |    4 +++-
 drivers/infiniband/ulp/ipoib/ipoib_main.c      |   24 +++++++++++++++---------
 drivers/infiniband/ulp/ipoib/ipoib_multicast.c |    3 ++-
 3 files changed, 20 insertions(+), 11 deletions(-)

diff --git a/drivers/infiniband/ulp/ipoib/ipoib.h b/drivers/infiniband/ulp/ipoib/ipoib.h
index 6545fa7..1b3327a 100644
--- a/drivers/infiniband/ulp/ipoib/ipoib.h
+++ b/drivers/infiniband/ulp/ipoib/ipoib.h
@@ -349,6 +349,7 @@ #endif
 	struct sk_buff_head queue;
 
 	struct neighbour   *neighbour;
+	struct net_device *dev;
 
 	struct list_head    list;
 };
@@ -365,7 +366,8 @@ static inline struct ipoib_neigh **to_ip
 				     INFINIBAND_ALEN, sizeof(void *));
 }
 
-struct ipoib_neigh *ipoib_neigh_alloc(struct neighbour *neigh);
+struct ipoib_neigh *ipoib_neigh_alloc(struct neighbour *neigh,
+				      struct net_device *dev);
 void ipoib_neigh_free(struct net_device *dev, struct ipoib_neigh *neigh);
 
 extern struct workqueue_struct *ipoib_workqueue;
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_main.c b/drivers/infiniband/ulp/ipoib/ipoib_main.c
index e072f3c..cae026c 100644
--- a/drivers/infiniband/ulp/ipoib/ipoib_main.c
+++ b/drivers/infiniband/ulp/ipoib/ipoib_main.c
@@ -517,7 +517,7 @@ static void neigh_add_path(struct sk_buf
 	struct ipoib_path *path;
 	struct ipoib_neigh *neigh;
 
-	neigh = ipoib_neigh_alloc(skb->dst->neighbour);
+	neigh = ipoib_neigh_alloc(skb->dst->neighbour, skb->dev);
 	if (!neigh) {
 		++dev->stats.tx_dropped;
 		dev_kfree_skb_any(skb);
@@ -817,6 +817,13 @@ static void ipoib_neigh_cleanup(struct n
 	unsigned long flags;
 	struct ipoib_ah *ah = NULL;
 
+	neigh = *to_ipoib_neigh(n);
+	if (neigh) {
+		priv = netdev_priv(neigh->dev);
+		ipoib_dbg(priv, "neigh_destructor for bonding device: %s\n",
+			  n->dev->name);
+	} else
+		return;
 	ipoib_dbg(priv,
 		  "neigh_cleanup for %06x " IPOIB_GID_FMT "\n",
 		  IPOIB_QPN(n->ha),
@@ -824,13 +831,10 @@ static void ipoib_neigh_cleanup(struct n
 
 	spin_lock_irqsave(&priv->lock, flags);
 
-	neigh = *to_ipoib_neigh(n);
-	if (neigh) {
-		if (neigh->ah)
-			ah = neigh->ah;
-		list_del(&neigh->list);
-		ipoib_neigh_free(n->dev, neigh);
-	}
+	if (neigh->ah)
+		ah = neigh->ah;
+	list_del(&neigh->list);
+	ipoib_neigh_free(n->dev, neigh);
 
 	spin_unlock_irqrestore(&priv->lock, flags);
 
@@ -838,7 +842,8 @@ static void ipoib_neigh_cleanup(struct n
 		ipoib_put_ah(ah);
 }
 
-struct ipoib_neigh *ipoib_neigh_alloc(struct neighbour *neighbour)
+struct ipoib_neigh *ipoib_neigh_alloc(struct neighbour *neighbour,
+				      struct net_device *dev)
 {
 	struct ipoib_neigh *neigh;
 
@@ -847,6 +852,7 @@ struct ipoib_neigh *ipoib_neigh_alloc(st
 		return NULL;
 
 	neigh->neighbour = neighbour;
+	neigh->dev = dev;
 	*to_ipoib_neigh(neighbour) = neigh;
 	skb_queue_head_init(&neigh->queue);
 	ipoib_cm_set(neigh, NULL);
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_multicast.c b/drivers/infiniband/ulp/ipoib/ipoib_multicast.c
index 827820e..9bcfc7a 100644
--- a/drivers/infiniband/ulp/ipoib/ipoib_multicast.c
+++ b/drivers/infiniband/ulp/ipoib/ipoib_multicast.c
@@ -705,7 +705,8 @@ out:
 		if (skb->dst            &&
 		    skb->dst->neighbour &&
 		    !*to_ipoib_neigh(skb->dst->neighbour)) {
-			struct ipoib_neigh *neigh = ipoib_neigh_alloc(skb->dst->neighbour);
+			struct ipoib_neigh *neigh = ipoib_neigh_alloc(skb->dst->neighbour,
+									skb->dev);
 
 			if (neigh) {
 				kref_get(&mcast->ah->ref);

^ permalink raw reply related	[flat|nested] 18+ messages in thread

* Re: [ofa-general] [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
  2007-10-15 16:03 ` [ofa-general] [PATCH V7 1/8] IB/ipoib: Bound the net device to the ipoib_neigh structue Moni Shoua
@ 2007-10-15 16:08 ` Moni Shoua
  2007-10-15 16:09 ` [ofa-general] [PATCH V7 2/8] IB/ipoib: Verify address handle validity on send Moni Shoua
                   ` (7 subsequent siblings)
  9 siblings, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:08 UTC (permalink / raw)
  To: Moni Shoua; +Cc: netdev, rdreier, fubar, jgarzik, general

Moni Shoua wrote:
> This is the 7th version of this patch series. See link to V6 below.
> 

I forgot to mention that the patches are relative to jgarzik/netdev-2.6.git#master.
I couldn't compile the 2.6.24 or the upstream branches so I used master branch to test the fixes.

^ permalink raw reply	[flat|nested] 18+ messages in thread

* [ofa-general] [PATCH V7 2/8] IB/ipoib: Verify address handle validity on send
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
  2007-10-15 16:03 ` [ofa-general] [PATCH V7 1/8] IB/ipoib: Bound the net device to the ipoib_neigh structue Moni Shoua
  2007-10-15 16:08 ` [ofa-general] [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
@ 2007-10-15 16:09 ` Moni Shoua
  2007-10-15 16:10 ` [PATCH V7 3/8] net/bonding: Enable bonding to enslave non ARPHRD_ETHER Moni Shoua
                   ` (6 subsequent siblings)
  9 siblings, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:09 UTC (permalink / raw)
  To: jgarzik, fubar, rdreier; +Cc: netdev, general


When the bonding device senses a carrier loss of its active slave it replaces
that slave with a new one. In between the times when the carrier of an IPoIB
device goes down and ipoib_neigh is destroyed, it is possible that the
bonding driver will send a packet on a new slave that uses an old ipoib_neigh.
This patch detects and prevents this from happenning.

Signed-off-by: Moni Shoua <monis at voltaire.com>
Signed-off-by: Or Gerlitz <ogerlitz at voltaire.com>
Acked-by: Roland Dreier <rdreier@cisco.com>
---
 drivers/infiniband/ulp/ipoib/ipoib_main.c |    5 +++--
 1 files changed, 3 insertions(+), 2 deletions(-)

diff --git a/drivers/infiniband/ulp/ipoib/ipoib_main.c b/drivers/infiniband/ulp/ipoib/ipoib_main.c
index cae026c..362610d 100644
--- a/drivers/infiniband/ulp/ipoib/ipoib_main.c
+++ b/drivers/infiniband/ulp/ipoib/ipoib_main.c
@@ -692,9 +692,10 @@ static int ipoib_start_xmit(struct sk_bu
 				goto out;
 			}
 		} else if (neigh->ah) {
-			if (unlikely(memcmp(&neigh->dgid.raw,
+			if (unlikely((memcmp(&neigh->dgid.raw,
 					    skb->dst->neighbour->ha + 4,
-					    sizeof(union ib_gid)))) {
+					    sizeof(union ib_gid))) ||
+					 (neigh->dev != dev))) {
 				spin_lock(&priv->lock);
 				/*
 				 * It's safe to call ipoib_put_ah() inside

^ permalink raw reply related	[flat|nested] 18+ messages in thread

* [PATCH V7 3/8] net/bonding: Enable bonding to enslave non ARPHRD_ETHER
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
                   ` (2 preceding siblings ...)
  2007-10-15 16:09 ` [ofa-general] [PATCH V7 2/8] IB/ipoib: Verify address handle validity on send Moni Shoua
@ 2007-10-15 16:10 ` Moni Shoua
  2007-10-15 16:11 ` [PATCH V7 4/8] net/bonding: Enable bonding to enslave netdevices not supporting set_mac_address() Moni Shoua
                   ` (5 subsequent siblings)
  9 siblings, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:10 UTC (permalink / raw)
  To: jgarzik, fubar, rdreier; +Cc: netdev, general


This patch changes some of the bond netdevice attributes and functions
to be that of the active slave for the case of the enslaved device not being
of ARPHRD_ETHER type. Basically it overrides those setting done by ether_setup(),
which are netdevice **type** dependent and hence might be not appropriate for
devices of other types. It also enforces mutual exclusion on bonding slaves
from dissimilar ether types, as was concluded over the v1 discussion.

IPoIB (see Documentation/infiniband/ipoib.txt) MAC address is made of a 3 bytes
IB QP (Queue Pair) number and 16 bytes IB port GID (Global ID) of the port this
IPoIB device is bounded to. The QP is a resource created by the IB HW and the
GID is an identifier burned into the HCA (i have omitted here some details which
are not important for the bonding RFC).

Signed-off-by: Moni Shoua <monis at voltaire.com>
Signed-off-by: Or Gerlitz <ogerlitz at voltaire.com>
---
 drivers/net/bonding/bond_main.c |   34 ++++++++++++++++++++++++++++++++++
 1 files changed, 34 insertions(+)

diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
index 64bfec3..4f61958 100644
--- a/drivers/net/bonding/bond_main.c
+++ b/drivers/net/bonding/bond_main.c
@@ -1238,6 +1238,21 @@ static int bond_compute_features(struct 
 	return 0;
 }
 
+
+static void bond_setup_by_slave(struct net_device *bond_dev,
+				struct net_device *slave_dev)
+{
+	bond_dev->neigh_setup       = slave_dev->neigh_setup;
+
+	bond_dev->type		    = slave_dev->type;
+	bond_dev->hard_header_len   = slave_dev->hard_header_len;
+	bond_dev->addr_len	    = slave_dev->addr_len;
+	bond_dev->header_ops	    = slave_dev->header_ops;
+
+	memcpy(bond_dev->broadcast, slave_dev->broadcast,
+		slave_dev->addr_len);
+}
+
 /* enslave device <slave> to bond device <master> */
 int bond_enslave(struct net_device *bond_dev, struct net_device *slave_dev)
 {
@@ -1312,6 +1327,25 @@ int bond_enslave(struct net_device *bond
 		goto err_undo_flags;
 	}
 
+	/* set bonding device ether type by slave - bonding netdevices are
+	 * created with ether_setup, so when the slave type is not ARPHRD_ETHER
+	 * there is a need to override some of the type dependent attribs/funcs.
+	 *
+	 * bond ether type mutual exclusion - don't allow slaves of dissimilar
+	 * ether type (eg ARPHRD_ETHER and ARPHRD_INFINIBAND) share the same bond
+	 */
+	if (bond->slave_cnt == 0) {
+		if (slave_dev->type != ARPHRD_ETHER)
+			bond_setup_by_slave(bond_dev, slave_dev);
+	} else if (bond_dev->type != slave_dev->type) {
+		printk(KERN_ERR DRV_NAME ": %s ether type (%d) is different "
+			"from other slaves (%d), can not enslave it.\n",
+			slave_dev->name,
+			slave_dev->type, bond_dev->type);
+			res = -EINVAL;
+			goto err_undo_flags;
+	}
+
 	if (slave_dev->set_mac_address == NULL) {
 		printk(KERN_ERR DRV_NAME
 			": %s: Error: The slave device you specified does "


^ permalink raw reply related	[flat|nested] 18+ messages in thread

* [PATCH V7 4/8] net/bonding: Enable bonding to enslave netdevices not supporting set_mac_address()
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
                   ` (3 preceding siblings ...)
  2007-10-15 16:10 ` [PATCH V7 3/8] net/bonding: Enable bonding to enslave non ARPHRD_ETHER Moni Shoua
@ 2007-10-15 16:11 ` Moni Shoua
  2007-10-15 16:12 ` [PATCH V7 5/8] net/bonding: Enable IP multicast for bonding IPoIB devices Moni Shoua
                   ` (4 subsequent siblings)
  9 siblings, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:11 UTC (permalink / raw)
  To: jgarzik, fubar, rdreier; +Cc: netdev, general


This patch allows for enslaving netdevices which do not support
the set_mac_address() function. In that case the bond mac address is the one
of the active slave, where remote peers are notified on the mac address
(neighbour) change by Gratuitous ARP sent by bonding when fail-over occurs
(this is already done by the bonding code).

Signed-off-by: Moni Shoua <monis at voltaire.com>
Signed-off-by: Or Gerlitz <ogerlitz at voltaire.com>
Acked-by: Jay Vosburgh <fubar@us.ibm.com>
---
 drivers/net/bonding/bond_main.c |   87 +++++++++++++++++++++++++++-------------
 drivers/net/bonding/bonding.h   |    1 
 2 files changed, 60 insertions(+), 28 deletions(-)

diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
index 4f61958..32dc75e 100644
--- a/drivers/net/bonding/bond_main.c
+++ b/drivers/net/bonding/bond_main.c
@@ -1096,6 +1096,14 @@ void bond_change_active_slave(struct bon
 		if (new_active) {
 			bond_set_slave_active_flags(new_active);
 		}
+
+		/* when bonding does not set the slave MAC address, the bond MAC
+		 * address is the one of the active slave.
+		 */
+		if (new_active && !bond->do_set_mac_addr)
+			memcpy(bond->dev->dev_addr,  new_active->dev->dev_addr,
+				new_active->dev->addr_len);
+
 		bond_send_gratuitous_arp(bond);
 	}
 }
@@ -1347,13 +1355,22 @@ int bond_enslave(struct net_device *bond
 	}
 
 	if (slave_dev->set_mac_address == NULL) {
-		printk(KERN_ERR DRV_NAME
-			": %s: Error: The slave device you specified does "
-			"not support setting the MAC address. "
-			"Your kernel likely does not support slave "
-			"devices.\n", bond_dev->name);
-  		res = -EOPNOTSUPP;
-		goto err_undo_flags;
+		if (bond->slave_cnt == 0) {
+			printk(KERN_WARNING DRV_NAME
+				": %s: Warning: The first slave device you "
+				"specified does not support setting the MAC "
+				"address. This bond MAC address would be that "
+				"of the active slave.\n", bond_dev->name);
+			bond->do_set_mac_addr = 0;
+		} else if (bond->do_set_mac_addr) {
+			printk(KERN_ERR DRV_NAME
+				": %s: Error: The slave device you specified "
+				"does not support setting the MAC addres,."
+				"but this bond uses this practice. \n"
+				, bond_dev->name);
+			res = -EOPNOTSUPP;
+			goto err_undo_flags;
+		}
 	}
 
 	new_slave = kzalloc(sizeof(struct slave), GFP_KERNEL);
@@ -1374,16 +1391,18 @@ int bond_enslave(struct net_device *bond
 	 */
 	memcpy(new_slave->perm_hwaddr, slave_dev->dev_addr, ETH_ALEN);
 
-	/*
-	 * Set slave to master's mac address.  The application already
-	 * set the master's mac address to that of the first slave
-	 */
-	memcpy(addr.sa_data, bond_dev->dev_addr, bond_dev->addr_len);
-	addr.sa_family = slave_dev->type;
-	res = dev_set_mac_address(slave_dev, &addr);
-	if (res) {
-		dprintk("Error %d calling set_mac_address\n", res);
-		goto err_free;
+	if (bond->do_set_mac_addr) {
+		/*
+		 * Set slave to master's mac address.  The application already
+		 * set the master's mac address to that of the first slave
+		 */
+		memcpy(addr.sa_data, bond_dev->dev_addr, bond_dev->addr_len);
+		addr.sa_family = slave_dev->type;
+		res = dev_set_mac_address(slave_dev, &addr);
+		if (res) {
+			dprintk("Error %d calling set_mac_address\n", res);
+			goto err_free;
+		}
 	}
 
 	res = netdev_set_master(slave_dev, bond_dev);
@@ -1608,9 +1627,11 @@ err_close:
 	dev_close(slave_dev);
 
 err_restore_mac:
-	memcpy(addr.sa_data, new_slave->perm_hwaddr, ETH_ALEN);
-	addr.sa_family = slave_dev->type;
-	dev_set_mac_address(slave_dev, &addr);
+	if (bond->do_set_mac_addr) {
+		memcpy(addr.sa_data, new_slave->perm_hwaddr, ETH_ALEN);
+		addr.sa_family = slave_dev->type;
+		dev_set_mac_address(slave_dev, &addr);
+	}
 
 err_free:
 	kfree(new_slave);
@@ -1783,10 +1804,12 @@ int bond_release(struct net_device *bond
 	/* close slave before restoring its mac address */
 	dev_close(slave_dev);
 
-	/* restore original ("permanent") mac address */
-	memcpy(addr.sa_data, slave->perm_hwaddr, ETH_ALEN);
-	addr.sa_family = slave_dev->type;
-	dev_set_mac_address(slave_dev, &addr);
+	if (bond->do_set_mac_addr) {
+		/* restore original ("permanent") mac address */
+		memcpy(addr.sa_data, slave->perm_hwaddr, ETH_ALEN);
+		addr.sa_family = slave_dev->type;
+		dev_set_mac_address(slave_dev, &addr);
+	}
 
 	slave_dev->priv_flags &= ~(IFF_MASTER_8023AD | IFF_MASTER_ALB |
 				   IFF_SLAVE_INACTIVE | IFF_BONDING |
@@ -1873,10 +1896,12 @@ static int bond_release_all(struct net_d
 		/* close slave before restoring its mac address */
 		dev_close(slave_dev);
 
-		/* restore original ("permanent") mac address*/
-		memcpy(addr.sa_data, slave->perm_hwaddr, ETH_ALEN);
-		addr.sa_family = slave_dev->type;
-		dev_set_mac_address(slave_dev, &addr);
+		if (bond->do_set_mac_addr) {
+			/* restore original ("permanent") mac address*/
+			memcpy(addr.sa_data, slave->perm_hwaddr, ETH_ALEN);
+			addr.sa_family = slave_dev->type;
+			dev_set_mac_address(slave_dev, &addr);
+		}
 
 		slave_dev->priv_flags &= ~(IFF_MASTER_8023AD | IFF_MASTER_ALB |
 					   IFF_SLAVE_INACTIVE);
@@ -3914,6 +3939,9 @@ static int bond_set_mac_address(struct n
 
 	dprintk("bond=%p, name=%s\n", bond, (bond_dev ? bond_dev->name : "None"));
 
+	if (!bond->do_set_mac_addr)
+		return -EOPNOTSUPP;
+
 	if (!is_valid_ether_addr(sa->sa_data)) {
 		return -EADDRNOTAVAIL;
 	}
@@ -4300,6 +4328,9 @@ #ifdef CONFIG_PROC_FS
 	bond_create_proc_entry(bond);
 #endif
 
+	/* set do_set_mac_addr to true on startup */
+	bond->do_set_mac_addr = 1;
+
 	list_add_tail(&bond->bond_list, &bond_dev_list);
 
 	return 0;
diff --git a/drivers/net/bonding/bonding.h b/drivers/net/bonding/bonding.h
index 2a6af7d..5011ba9 100644
--- a/drivers/net/bonding/bonding.h
+++ b/drivers/net/bonding/bonding.h
@@ -185,6 +185,7 @@ struct bonding {
 	struct   timer_list mii_timer;
 	struct   timer_list arp_timer;
 	s8       kill_timers;
+	s8       do_set_mac_addr;
 	struct   net_device_stats stats;
 #ifdef CONFIG_PROC_FS
 	struct   proc_dir_entry *proc_entry;


^ permalink raw reply related	[flat|nested] 18+ messages in thread

* [PATCH V7 5/8] net/bonding: Enable IP multicast for bonding IPoIB devices
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
                   ` (4 preceding siblings ...)
  2007-10-15 16:11 ` [PATCH V7 4/8] net/bonding: Enable bonding to enslave netdevices not supporting set_mac_address() Moni Shoua
@ 2007-10-15 16:12 ` Moni Shoua
  2007-10-15 16:13 ` [PATCH V7 6/8] net/bonding: Handlle wrong assumptions that slave is always an Ethernet device Moni Shoua
                   ` (3 subsequent siblings)
  9 siblings, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:12 UTC (permalink / raw)
  To: jgarzik, fubar, rdreier; +Cc: netdev, general


Allow to enslave devices when the bonding device is not up. Over the discussion
held at the previous post this seemed to be the most clean way to go, where it
is not expected to cause instabilities.

Normally, the bonding driver is UP before any enslavement takes place.
Once a netdevice is UP, the network stack acts to have it join some multicast groups
(eg the all-hosts 224.0.0.1). Now, since ether_setup() have set the bonding device
type to be ARPHRD_ETHER and address len to be ETHER_ALEN, the net core code
computes a wrong multicast link address. This is b/c ip_eth_mc_map() is called
where for multicast joins taking place after the enslavement another ip_xxx_mc_map()
is called (eg ip_ib_mc_map() when the bond type is ARPHRD_INFINIBAND)

Signed-off-by: Moni Shoua <monis at voltaire.com>
Signed-off-by: Or Gerlitz <ogerlitz at voltaire.com>
Acked-by: Jay Vosburgh <fubar@us.ibm.com>
---
 drivers/net/bonding/bond_main.c  |    5 +++--
 drivers/net/bonding/bond_sysfs.c |    6 ++----
 2 files changed, 5 insertions(+), 6 deletions(-)

diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
index 32dc75e..d7e43ba 100644
--- a/drivers/net/bonding/bond_main.c
+++ b/drivers/net/bonding/bond_main.c
@@ -1281,8 +1281,9 @@ int bond_enslave(struct net_device *bond
 
 	/* bond must be initialized by bond_open() before enslaving */
 	if (!(bond_dev->flags & IFF_UP)) {
-		dprintk("Error, master_dev is not up\n");
-		return -EPERM;
+		printk(KERN_WARNING DRV_NAME
+			" %s: master_dev is not up in bond_enslave\n",
+			bond_dev->name);
 	}
 
 	/* already enslaved */
diff --git a/drivers/net/bonding/bond_sysfs.c b/drivers/net/bonding/bond_sysfs.c
index 6f49ca7..ca4e429 100644
--- a/drivers/net/bonding/bond_sysfs.c
+++ b/drivers/net/bonding/bond_sysfs.c
@@ -266,11 +266,9 @@ static ssize_t bonding_store_slaves(stru
 
 	/* Quick sanity check -- is the bond interface up? */
 	if (!(bond->dev->flags & IFF_UP)) {
-		printk(KERN_ERR DRV_NAME
-		       ": %s: Unable to update slaves because interface is down.\n",
+		printk(KERN_WARNING DRV_NAME
+		       ": %s: doing slave updates when interface is down.\n",
 		       bond->dev->name);
-		ret = -EPERM;
-		goto out;
 	}
 
 	/* Note:  We can't hold bond->lock here, as bond_create grabs it. */


^ permalink raw reply related	[flat|nested] 18+ messages in thread

* [PATCH V7 6/8] net/bonding: Handlle wrong assumptions that slave is always an Ethernet device
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
                   ` (5 preceding siblings ...)
  2007-10-15 16:12 ` [PATCH V7 5/8] net/bonding: Enable IP multicast for bonding IPoIB devices Moni Shoua
@ 2007-10-15 16:13 ` Moni Shoua
  2007-10-15 16:13 ` PATCH V6 7/8] net/bonding: Delay sending of gratuitous ARP to avoid failure Moni Shoua
                   ` (2 subsequent siblings)
  9 siblings, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:13 UTC (permalink / raw)
  To: jgarzik, fubar, rdreier; +Cc: netdev, general


bonding sometimes uses Ethernet constants (such as MTU and address length) which
are not good when it enslaves non Ethernet devices (such as InfiniBand).

Signed-off-by: Moni Shoua <monis at voltaire.com>
Acked-by: Jay Vosburgh <fubar@us.ibm.com>
---
 drivers/net/bonding/bond_main.c  |    3 ++-
 drivers/net/bonding/bond_sysfs.c |   10 ++++++++--
 drivers/net/bonding/bonding.h    |    1 +
 3 files changed, 11 insertions(+), 3 deletions(-)

diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
index d7e43ba..3f082dc 100644
--- a/drivers/net/bonding/bond_main.c
+++ b/drivers/net/bonding/bond_main.c
@@ -1225,7 +1225,8 @@ static int bond_compute_features(struct 
 	struct slave *slave;
 	struct net_device *bond_dev = bond->dev;
 	unsigned long features = bond_dev->features;
-	unsigned short max_hard_header_len = ETH_HLEN;
+	unsigned short max_hard_header_len = max((u16)ETH_HLEN,
+						bond_dev->hard_header_len);
 	int i;
 
 	features &= ~(NETIF_F_ALL_CSUM | BOND_VLAN_FEATURES);
diff --git a/drivers/net/bonding/bond_sysfs.c b/drivers/net/bonding/bond_sysfs.c
index ca4e429..583c568 100644
--- a/drivers/net/bonding/bond_sysfs.c
+++ b/drivers/net/bonding/bond_sysfs.c
@@ -260,6 +260,7 @@ static ssize_t bonding_store_slaves(stru
 	char command[IFNAMSIZ + 1] = { 0, };
 	char *ifname;
 	int i, res, found, ret = count;
+	u32 original_mtu;
 	struct slave *slave;
 	struct net_device *dev = NULL;
 	struct bonding *bond = to_bond(d);
@@ -325,6 +326,7 @@ static ssize_t bonding_store_slaves(stru
 		}
 
 		/* Set the slave's MTU to match the bond */
+		original_mtu = dev->mtu;
 		if (dev->mtu != bond->dev->mtu) {
 			if (dev->change_mtu) {
 				res = dev->change_mtu(dev,
@@ -339,6 +341,9 @@ static ssize_t bonding_store_slaves(stru
 		}
 		rtnl_lock();
 		res = bond_enslave(bond->dev, dev);
+		bond_for_each_slave(bond, slave, i)
+			if (strnicmp(slave->dev->name, ifname, IFNAMSIZ) == 0)
+				slave->original_mtu = original_mtu;
 		rtnl_unlock();
 		if (res) {
 			ret = res;
@@ -351,6 +356,7 @@ static ssize_t bonding_store_slaves(stru
 		bond_for_each_slave(bond, slave, i)
 			if (strnicmp(slave->dev->name, ifname, IFNAMSIZ) == 0) {
 				dev = slave->dev;
+				original_mtu = slave->original_mtu;
 				break;
 			}
 		if (dev) {
@@ -365,9 +371,9 @@ static ssize_t bonding_store_slaves(stru
 			}
 			/* set the slave MTU to the default */
 			if (dev->change_mtu) {
-				dev->change_mtu(dev, 1500);
+				dev->change_mtu(dev, original_mtu);
 			} else {
-				dev->mtu = 1500;
+				dev->mtu = original_mtu;
 			}
 		}
 		else {
diff --git a/drivers/net/bonding/bonding.h b/drivers/net/bonding/bonding.h
index 5011ba9..ad9c632 100644
--- a/drivers/net/bonding/bonding.h
+++ b/drivers/net/bonding/bonding.h
@@ -156,6 +156,7 @@ struct slave {
 	s8     link;    /* one of BOND_LINK_XXXX */
 	s8     state;   /* one of BOND_STATE_XXXX */
 	u32    original_flags;
+	u32    original_mtu;
 	u32    link_failure_count;
 	u16    speed;
 	u8     duplex;


^ permalink raw reply related	[flat|nested] 18+ messages in thread

* PATCH V6 7/8] net/bonding: Delay sending of gratuitous ARP to avoid failure
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
                   ` (6 preceding siblings ...)
  2007-10-15 16:13 ` [PATCH V7 6/8] net/bonding: Handlle wrong assumptions that slave is always an Ethernet device Moni Shoua
@ 2007-10-15 16:13 ` Moni Shoua
  2007-10-15 16:14 ` [PATCH V7 8/8] net/bonding: Destroy bonding master when last slave is gone Moni Shoua
  2007-10-15 18:23 ` [ofa-general] Re: [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Jeff Garzik
  9 siblings, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:13 UTC (permalink / raw)
  To: jgarzik, fubar, rdreier; +Cc: netdev, general


Delay sending a gratuitous_arp when LINK_STATE_LINKWATCH_PENDING bit
in dev->state field is on. This improves the chances for the arp packet to
be transmitted.

Signed-off-by: Moni Shoua <monis at voltaire.com>
Acked-by: Jay Vosburgh <fubar@us.ibm.com>
---
 drivers/net/bonding/bond_main.c |   24 +++++++++++++++++++++---
 drivers/net/bonding/bonding.h   |    1 +
 2 files changed, 22 insertions(+), 3 deletions(-)

diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
index 3f082dc..c017042 100644
--- a/drivers/net/bonding/bond_main.c
+++ b/drivers/net/bonding/bond_main.c
@@ -1103,8 +1103,14 @@ void bond_change_active_slave(struct bon
 		if (new_active && !bond->do_set_mac_addr)
 			memcpy(bond->dev->dev_addr,  new_active->dev->dev_addr,
 				new_active->dev->addr_len);
-
-		bond_send_gratuitous_arp(bond);
+		if (bond->curr_active_slave &&
+			test_bit(__LINK_STATE_LINKWATCH_PENDING,
+					&bond->curr_active_slave->dev->state)) {
+			dprintk("delaying gratuitous arp on %s\n",
+				bond->curr_active_slave->dev->name);
+			bond->send_grat_arp = 1;
+		} else
+			bond_send_gratuitous_arp(bond);
 	}
 }
 
@@ -2074,6 +2080,17 @@ void bond_mii_monitor(struct net_device 
 	 * program could monitor the link itself if needed.
 	 */
 
+	if (bond->send_grat_arp) {
+		if (bond->curr_active_slave && test_bit(__LINK_STATE_LINKWATCH_PENDING,
+				&bond->curr_active_slave->dev->state))
+			dprintk("Needs to send gratuitous arp but not yet\n");
+		else {
+			dprintk("sending delayed gratuitous arp on on %s\n",
+				bond->curr_active_slave->dev->name);
+			bond_send_gratuitous_arp(bond);
+			bond->send_grat_arp = 0;
+		}
+	}
 	read_lock(&bond->curr_slave_lock);
 	oldcurrent = bond->curr_active_slave;
 	read_unlock(&bond->curr_slave_lock);
@@ -2475,7 +2492,7 @@ static void bond_send_gratuitous_arp(str
 
 	if (bond->master_ip) {
 		bond_arp_send(slave->dev, ARPOP_REPLY, bond->master_ip,
-				  bond->master_ip, 0);
+				bond->master_ip, 0);
 	}
 
 	list_for_each_entry(vlan, &bond->vlan_list, vlan_list) {
@@ -4281,6 +4298,7 @@ static int bond_init(struct net_device *
 	bond->current_arp_slave = NULL;
 	bond->primary_slave = NULL;
 	bond->dev = bond_dev;
+	bond->send_grat_arp = 0;
 	INIT_LIST_HEAD(&bond->vlan_list);
 
 	/* Initialize the device entry points */
diff --git a/drivers/net/bonding/bonding.h b/drivers/net/bonding/bonding.h
index ad9c632..e0e06a8 100644
--- a/drivers/net/bonding/bonding.h
+++ b/drivers/net/bonding/bonding.h
@@ -187,6 +187,7 @@ struct bonding {
 	struct   timer_list arp_timer;
 	s8       kill_timers;
 	s8       do_set_mac_addr;
+	s8	 send_grat_arp;
 	struct   net_device_stats stats;
 #ifdef CONFIG_PROC_FS
 	struct   proc_dir_entry *proc_entry;


^ permalink raw reply related	[flat|nested] 18+ messages in thread

* [PATCH V7 8/8] net/bonding: Destroy bonding master when last slave is gone
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
                   ` (7 preceding siblings ...)
  2007-10-15 16:13 ` PATCH V6 7/8] net/bonding: Delay sending of gratuitous ARP to avoid failure Moni Shoua
@ 2007-10-15 16:14 ` Moni Shoua
  2007-10-15 18:23 ` [ofa-general] Re: [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Jeff Garzik
  9 siblings, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-15 16:14 UTC (permalink / raw)
  To: Moni Shoua, jgarzik, fubar; +Cc: rdreier, netdev, general


When bonding enslaves non Ethernet devices it takes pointers to functions
in the module that owns the slaves. In this case it becomes unsafe
to keep the bonding master registered after last slave was unenslaved
because we don't know if the pointers are still valid.  Destroying the bond when slave_cnt is zero
ensures that these functions be used anymore.

Signed-off-by: Moni Shoua <monis at voltaire.com>
---
 drivers/net/bonding/bond_main.c  |   37 ++++++++++++++++++++++++++++++++++++-
 drivers/net/bonding/bond_sysfs.c |    9 +++++----
 drivers/net/bonding/bonding.h    |    3 +++
 3 files changed, 44 insertions(+), 5 deletions(-)

diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
index c017042..23edf18 100644
--- a/drivers/net/bonding/bond_main.c
+++ b/drivers/net/bonding/bond_main.c
@@ -1257,6 +1257,7 @@ static int bond_compute_features(struct 
 static void bond_setup_by_slave(struct net_device *bond_dev,
 				struct net_device *slave_dev)
 {
+	struct bonding *bond = bond_dev->priv;
 	bond_dev->neigh_setup       = slave_dev->neigh_setup;
 
 	bond_dev->type		    = slave_dev->type;
@@ -1266,6 +1267,7 @@ static void bond_setup_by_slave(struct n
 
 	memcpy(bond_dev->broadcast, slave_dev->broadcast,
 		slave_dev->addr_len);
+	bond->setup_by_slave = 1;
 }
 
 /* enslave device <slave> to bond device <master> */
@@ -1829,6 +1831,35 @@ int bond_release(struct net_device *bond
 }
 
 /*
+* Destroy a bonding device.
+* Must be under rtnl_lock when this function is called.
+*/
+void bond_destroy(struct bonding *bond)
+{
+	bond_deinit(bond->dev);
+	bond_destroy_sysfs_entry(bond);
+	unregister_netdevice(bond->dev);
+}
+
+/*
+* First release a slave and than destroy the bond if no more slaves iare left.
+* Must be under rtnl_lock when this function is called.
+*/
+int  bond_release_and_destroy(struct net_device *bond_dev, struct net_device *slave_dev)
+{
+	struct bonding *bond = bond_dev->priv;
+	int ret;
+
+	ret = bond_release(bond_dev, slave_dev);
+	if ((ret == 0) && (bond->slave_cnt == 0)) {
+		printk(KERN_INFO DRV_NAME ": %s: destroying bond %s.\n",
+		       bond_dev->name, bond_dev->name);
+		bond_destroy(bond);
+	}
+	return ret;
+}
+
+/*
  * This function releases all slaves.
  */
 static int bond_release_all(struct net_device *bond_dev)
@@ -3311,7 +3342,10 @@ static int bond_slave_netdev_event(unsig
 	switch (event) {
 	case NETDEV_UNREGISTER:
 		if (bond_dev) {
-			bond_release(bond_dev, slave_dev);
+			if (bond->setup_by_slave)
+				bond_release_and_destroy(bond_dev, slave_dev);
+			else
+				bond_release(bond_dev, slave_dev);
 		}
 		break;
 	case NETDEV_CHANGE:
@@ -4299,6 +4333,7 @@ static int bond_init(struct net_device *
 	bond->primary_slave = NULL;
 	bond->dev = bond_dev;
 	bond->send_grat_arp = 0;
+	bond->setup_by_slave = 0;
 	INIT_LIST_HEAD(&bond->vlan_list);
 
 	/* Initialize the device entry points */
diff --git a/drivers/net/bonding/bond_sysfs.c b/drivers/net/bonding/bond_sysfs.c
index 583c568..b5d2a13 100644
--- a/drivers/net/bonding/bond_sysfs.c
+++ b/drivers/net/bonding/bond_sysfs.c
@@ -164,9 +164,7 @@ static ssize_t bonding_store_bonds(struc
 				printk(KERN_INFO DRV_NAME
 					": %s is being deleted...\n",
 					bond->dev->name);
-				bond_deinit(bond->dev);
-		        	bond_destroy_sysfs_entry(bond);
-				unregister_netdevice(bond->dev);
+				bond_destroy(bond);
 				rtnl_unlock();
 				goto out;
 			}
@@ -363,7 +361,10 @@ static ssize_t bonding_store_slaves(stru
 			printk(KERN_INFO DRV_NAME ": %s: Removing slave %s\n",
 				bond->dev->name, dev->name);
 			rtnl_lock();
-			res = bond_release(bond->dev, dev);
+			if (bond->setup_by_slave)
+				res = bond_release_and_destroy(bond->dev, dev);
+			else
+				res = bond_release(bond->dev, dev);
 			rtnl_unlock();
 			if (res) {
 				ret = res;
diff --git a/drivers/net/bonding/bonding.h b/drivers/net/bonding/bonding.h
index e0e06a8..85e579b 100644
--- a/drivers/net/bonding/bonding.h
+++ b/drivers/net/bonding/bonding.h
@@ -188,6 +188,7 @@ struct bonding {
 	s8       kill_timers;
 	s8       do_set_mac_addr;
 	s8	 send_grat_arp;
+	s8	 setup_by_slave;
 	struct   net_device_stats stats;
 #ifdef CONFIG_PROC_FS
 	struct   proc_dir_entry *proc_entry;
@@ -295,6 +296,8 @@ static inline void bond_unset_master_alb
 struct vlan_entry *bond_next_vlan(struct bonding *bond, struct vlan_entry *curr);
 int bond_dev_queue_xmit(struct bonding *bond, struct sk_buff *skb, struct net_device *slave_dev);
 int bond_create(char *name, struct bond_params *params, struct bonding **newbond);
+void bond_destroy(struct bonding *bond);
+int  bond_release_and_destroy(struct net_device *bond_dev, struct net_device *slave_dev);
 void bond_deinit(struct net_device *bond_dev);
 int bond_create_sysfs(void);
 void bond_destroy_sysfs(void);


^ permalink raw reply related	[flat|nested] 18+ messages in thread

* [ofa-general] Re: [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver
  2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
                   ` (8 preceding siblings ...)
  2007-10-15 16:14 ` [PATCH V7 8/8] net/bonding: Destroy bonding master when last slave is gone Moni Shoua
@ 2007-10-15 18:23 ` Jeff Garzik
  2007-10-15 20:34   ` Jay Vosburgh
  9 siblings, 1 reply; 18+ messages in thread
From: Jeff Garzik @ 2007-10-15 18:23 UTC (permalink / raw)
  To: Moni Shoua; +Cc: netdev, rdreier, fubar, general

Moni Shoua wrote:
> This is the 7th version of this patch series. See link to V6 below.
> 
> Changes from the previous version
> ---------------------------------
> 
> * Some patches required modifications to remove offsets so they can be applied with git-apply
> * Patch #3 was first modified by Jay and later by me to make it work with header_ops
> * patch #8 was changed to fix the problem that caused 'ifconfig down' to stuck (dev_close was called twice)

I just applied the latest version Jay sent, are there any remaining changes?

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver
  2007-10-15 18:23 ` [ofa-general] Re: [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Jeff Garzik
@ 2007-10-15 20:34   ` Jay Vosburgh
  2007-10-15 20:50     ` [ofa-general] " Jeff Garzik
  0 siblings, 1 reply; 18+ messages in thread
From: Jay Vosburgh @ 2007-10-15 20:34 UTC (permalink / raw)
  To: Jeff Garzik; +Cc: Moni Shoua, rdreier, netdev, general

Jeff Garzik <jgarzik@pobox.com> wrote:

>Moni Shoua wrote:
>> This is the 7th version of this patch series. See link to V6 below.
>>
>> Changes from the previous version
>> ---------------------------------
>>
>> * Some patches required modifications to remove offsets so they can be applied with git-apply
>> * Patch #3 was first modified by Jay and later by me to make it work with header_ops
>> * patch #8 was changed to fix the problem that caused 'ifconfig down' to stuck (dev_close was called twice)
>
>I just applied the latest version Jay sent, are there any remaining changes?

	Yes, Moni changed patches 3 and 8 from the series I posted to
fix a couple of problems.  The others aren't changed from my posting of
the series.

	Since I see you've just pushed it, do you want a patch to
correct just the two individual things, or would you rather have new
patches?

	-J

---
	-Jay Vosburgh, IBM Linux Technology Center, fubar@us.ibm.com

^ permalink raw reply	[flat|nested] 18+ messages in thread

* [ofa-general] Re: [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver
  2007-10-15 20:34   ` Jay Vosburgh
@ 2007-10-15 20:50     ` Jeff Garzik
  2007-10-15 21:53       ` Jay Vosburgh
  0 siblings, 1 reply; 18+ messages in thread
From: Jeff Garzik @ 2007-10-15 20:50 UTC (permalink / raw)
  To: Jay Vosburgh; +Cc: netdev, rdreier, general

Jay Vosburgh wrote:
> 	Since I see you've just pushed it, do you want a patch to
> correct just the two individual things, or would you rather have new
> patches?


On top of what was just pushed, please.

	Jeff

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver
  2007-10-15 20:50     ` [ofa-general] " Jeff Garzik
@ 2007-10-15 21:53       ` Jay Vosburgh
  2007-10-15 21:56         ` Jeff Garzik
  0 siblings, 1 reply; 18+ messages in thread
From: Jay Vosburgh @ 2007-10-15 21:53 UTC (permalink / raw)
  To: Jeff Garzik; +Cc: Moni Shoua, rdreier, netdev, general

Jeff Garzik <jgarzik@pobox.com> wrote:

>Jay Vosburgh wrote:
>> 	Since I see you've just pushed it, do you want a patch to
>> correct just the two individual things, or would you rather have new
>> patches?
>
>
>On top of what was just pushed, please.

	Ok, I'll figure that out and then rebase the locking stuff on
top of that.

	-J

---
	-Jay Vosburgh, IBM Linux Technology Center, fubar@us.ibm.com

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver
  2007-10-15 21:53       ` Jay Vosburgh
@ 2007-10-15 21:56         ` Jeff Garzik
  2007-10-15 23:44           ` [PATCH linux-2.6] bonding: two small fixes for IPoIB support Jay Vosburgh
  0 siblings, 1 reply; 18+ messages in thread
From: Jeff Garzik @ 2007-10-15 21:56 UTC (permalink / raw)
  To: Jay Vosburgh; +Cc: Moni Shoua, rdreier, netdev, general

Jay Vosburgh wrote:
> Jeff Garzik <jgarzik@pobox.com> wrote:
> 
>> Jay Vosburgh wrote:
>>> 	Since I see you've just pushed it, do you want a patch to
>>> correct just the two individual things, or would you rather have new
>>> patches?
>>
>> On top of what was just pushed, please.
> 
> 	Ok, I'll figure that out and then rebase the locking stuff on
> top of that.

FWIW Linus just pulled, so you may diff against mainline if you wish.

Whatever is easiest for you...

	Jeff




^ permalink raw reply	[flat|nested] 18+ messages in thread

* [PATCH linux-2.6] bonding: two small fixes for IPoIB support
  2007-10-15 21:56         ` Jeff Garzik
@ 2007-10-15 23:44           ` Jay Vosburgh
  2007-10-16  7:56             ` Moni Shoua
  2007-10-17  1:15             ` [ofa-general] " Jeff Garzik
  0 siblings, 2 replies; 18+ messages in thread
From: Jay Vosburgh @ 2007-10-15 23:44 UTC (permalink / raw)
  To: Jeff Garzik; +Cc: Moni Shoua, rdreier, netdev, general


	Two small fixes to IPoIB support for bonding:

	1- copy header_ops from slave to bonding for IPoIB slaves
	2- move release and destroy logic to UNREGISTER from GOING_DOWN
	   notifier to avoid double release

	Set bonding to version 3.2.1.

Signed-off-by: Moni Shoua <monis at voltaire.com>
Signed-off-by: Jay Vosburgh <fubar@us.ibm.com>

---
 drivers/net/bonding/bond_main.c |   11 +++++------
 drivers/net/bonding/bonding.h   |    4 ++--
 2 files changed, 7 insertions(+), 8 deletions(-)

diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
index db80f24..6f85cc3 100644
--- a/drivers/net/bonding/bond_main.c
+++ b/drivers/net/bonding/bond_main.c
@@ -1263,6 +1263,7 @@ static void bond_setup_by_slave(struct net_device *bond_dev,
 	struct bonding *bond = bond_dev->priv;
 
 	bond_dev->neigh_setup           = slave_dev->neigh_setup;
+	bond_dev->header_ops		= slave_dev->header_ops;
 
 	bond_dev->type		    = slave_dev->type;
 	bond_dev->hard_header_len   = slave_dev->hard_header_len;
@@ -3351,7 +3352,10 @@ static int bond_slave_netdev_event(unsigned long event, struct net_device *slave
 	switch (event) {
 	case NETDEV_UNREGISTER:
 		if (bond_dev) {
-			bond_release(bond_dev, slave_dev);
+			if (bond->setup_by_slave)
+				bond_release_and_destroy(bond_dev, slave_dev);
+			else
+				bond_release(bond_dev, slave_dev);
 		}
 		break;
 	case NETDEV_CHANGE:
@@ -3366,11 +3370,6 @@ static int bond_slave_netdev_event(unsigned long event, struct net_device *slave
 		 * ... Or is it this?
 		 */
 		break;
-	case NETDEV_GOING_DOWN:
-		dprintk("slave %s is going down\n", slave_dev->name);
-		if (bond->setup_by_slave)
-			bond_release_and_destroy(bond_dev, slave_dev);
-		break;
 	case NETDEV_CHANGEMTU:
 		/*
 		 * TODO: Should slaves be allowed to
diff --git a/drivers/net/bonding/bonding.h b/drivers/net/bonding/bonding.h
index a8bbd56..b818060 100644
--- a/drivers/net/bonding/bonding.h
+++ b/drivers/net/bonding/bonding.h
@@ -22,8 +22,8 @@
 #include "bond_3ad.h"
 #include "bond_alb.h"
 
-#define DRV_VERSION	"3.2.0"
-#define DRV_RELDATE	"September 13, 2007"
+#define DRV_VERSION	"3.2.1"
+#define DRV_RELDATE	"October 15, 2007"
 #define DRV_NAME	"bonding"
 #define DRV_DESCRIPTION	"Ethernet Channel Bonding Driver"
 
-- 
1.5.3.1


^ permalink raw reply related	[flat|nested] 18+ messages in thread

* Re: [PATCH linux-2.6] bonding: two small fixes for IPoIB support
  2007-10-15 23:44           ` [PATCH linux-2.6] bonding: two small fixes for IPoIB support Jay Vosburgh
@ 2007-10-16  7:56             ` Moni Shoua
  2007-10-17  1:15             ` [ofa-general] " Jeff Garzik
  1 sibling, 0 replies; 18+ messages in thread
From: Moni Shoua @ 2007-10-16  7:56 UTC (permalink / raw)
  To: Jay Vosburgh, Jeff Garzik; +Cc: rdreier, netdev, general, Or Gerlitz, Moni Levy

Jay Vosburgh wrote:
> 	Two small fixes to IPoIB support for bonding:
> 
> 	1- copy header_ops from slave to bonding for IPoIB slaves
> 	2- move release and destroy logic to UNREGISTER from GOING_DOWN
> 	   notifier to avoid double release
> 
> 	Set bonding to version 3.2.1.
> 
> Signed-off-by: Moni Shoua <monis at voltaire.com>
> Signed-off-by: Jay Vosburgh <fubar@us.ibm.com>
> 
> ---
>  drivers/net/bonding/bond_main.c |   11 +++++------
>  drivers/net/bonding/bonding.h   |    4 ++--
>  2 files changed, 7 insertions(+), 8 deletions(-)
> 
> diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
> index db80f24..6f85cc3 100644
> --- a/drivers/net/bonding/bond_main.c
> +++ b/drivers/net/bonding/bond_main.c
> @@ -1263,6 +1263,7 @@ static void bond_setup_by_slave(struct net_device *bond_dev,
>  	struct bonding *bond = bond_dev->priv;
>  
>  	bond_dev->neigh_setup           = slave_dev->neigh_setup;
> +	bond_dev->header_ops		= slave_dev->header_ops;
>  
>  	bond_dev->type		    = slave_dev->type;
>  	bond_dev->hard_header_len   = slave_dev->hard_header_len;
> @@ -3351,7 +3352,10 @@ static int bond_slave_netdev_event(unsigned long event, struct net_device *slave
>  	switch (event) {
>  	case NETDEV_UNREGISTER:
>  		if (bond_dev) {
> -			bond_release(bond_dev, slave_dev);
> +			if (bond->setup_by_slave)
> +				bond_release_and_destroy(bond_dev, slave_dev);
> +			else
> +				bond_release(bond_dev, slave_dev);
>  		}
>  		break;
>  	case NETDEV_CHANGE:
> @@ -3366,11 +3370,6 @@ static int bond_slave_netdev_event(unsigned long event, struct net_device *slave
>  		 * ... Or is it this?
>  		 */
>  		break;
> -	case NETDEV_GOING_DOWN:
> -		dprintk("slave %s is going down\n", slave_dev->name);
> -		if (bond->setup_by_slave)
> -			bond_release_and_destroy(bond_dev, slave_dev);
> -		break;
>  	case NETDEV_CHANGEMTU:
>  		/*
>  		 * TODO: Should slaves be allowed to
> diff --git a/drivers/net/bonding/bonding.h b/drivers/net/bonding/bonding.h
> index a8bbd56..b818060 100644
> --- a/drivers/net/bonding/bonding.h
> +++ b/drivers/net/bonding/bonding.h
> @@ -22,8 +22,8 @@
>  #include "bond_3ad.h"
>  #include "bond_alb.h"
>  
> -#define DRV_VERSION	"3.2.0"
> -#define DRV_RELDATE	"September 13, 2007"
> +#define DRV_VERSION	"3.2.1"
> +#define DRV_RELDATE	"October 15, 2007"
>  #define DRV_NAME	"bonding"
>  #define DRV_DESCRIPTION	"Ethernet Channel Bonding Driver"
>  
Jay,
Thanks for this work.

Jeff,
Thanks for applying.
I noticed that this patch isn't applied. It includes important fixes. 
Can you please apply it also?


	MoniS



^ permalink raw reply	[flat|nested] 18+ messages in thread

* [ofa-general] Re: [PATCH linux-2.6] bonding: two small fixes for IPoIB support
  2007-10-15 23:44           ` [PATCH linux-2.6] bonding: two small fixes for IPoIB support Jay Vosburgh
  2007-10-16  7:56             ` Moni Shoua
@ 2007-10-17  1:15             ` Jeff Garzik
  1 sibling, 0 replies; 18+ messages in thread
From: Jeff Garzik @ 2007-10-17  1:15 UTC (permalink / raw)
  To: Jay Vosburgh; +Cc: netdev, rdreier, general

Jay Vosburgh wrote:
> 	Two small fixes to IPoIB support for bonding:
> 
> 	1- copy header_ops from slave to bonding for IPoIB slaves
> 	2- move release and destroy logic to UNREGISTER from GOING_DOWN
> 	   notifier to avoid double release
> 
> 	Set bonding to version 3.2.1.
> 
> Signed-off-by: Moni Shoua <monis at voltaire.com>
> Signed-off-by: Jay Vosburgh <fubar@us.ibm.com>
> 

applied

^ permalink raw reply	[flat|nested] 18+ messages in thread

end of thread, other threads:[~2007-10-17  1:15 UTC | newest]

Thread overview: 18+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-10-15 16:00 [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
2007-10-15 16:03 ` [ofa-general] [PATCH V7 1/8] IB/ipoib: Bound the net device to the ipoib_neigh structue Moni Shoua
2007-10-15 16:08 ` [ofa-general] [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Moni Shoua
2007-10-15 16:09 ` [ofa-general] [PATCH V7 2/8] IB/ipoib: Verify address handle validity on send Moni Shoua
2007-10-15 16:10 ` [PATCH V7 3/8] net/bonding: Enable bonding to enslave non ARPHRD_ETHER Moni Shoua
2007-10-15 16:11 ` [PATCH V7 4/8] net/bonding: Enable bonding to enslave netdevices not supporting set_mac_address() Moni Shoua
2007-10-15 16:12 ` [PATCH V7 5/8] net/bonding: Enable IP multicast for bonding IPoIB devices Moni Shoua
2007-10-15 16:13 ` [PATCH V7 6/8] net/bonding: Handlle wrong assumptions that slave is always an Ethernet device Moni Shoua
2007-10-15 16:13 ` PATCH V6 7/8] net/bonding: Delay sending of gratuitous ARP to avoid failure Moni Shoua
2007-10-15 16:14 ` [PATCH V7 8/8] net/bonding: Destroy bonding master when last slave is gone Moni Shoua
2007-10-15 18:23 ` [ofa-general] Re: [PATCH V7 0/8] net/bonding: ADD IPoIB support for the bonding driver Jeff Garzik
2007-10-15 20:34   ` Jay Vosburgh
2007-10-15 20:50     ` [ofa-general] " Jeff Garzik
2007-10-15 21:53       ` Jay Vosburgh
2007-10-15 21:56         ` Jeff Garzik
2007-10-15 23:44           ` [PATCH linux-2.6] bonding: two small fixes for IPoIB support Jay Vosburgh
2007-10-16  7:56             ` Moni Shoua
2007-10-17  1:15             ` [ofa-general] " Jeff Garzik

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).