Re: [Bonding-devel][PATCH]Zero Copy Transmit Support (Update)

From: Jay Vosburgh
Date: Fri Nov 12 2004 - 17:03:02 EST



David S. Miller <davem@xxxxxxxxxxxxx> wrote:
>> I had similar thoughts but then, the bond device does not have any
>> slaves attached to it at load time. By publishing them upfront the bond
>> device is able to take advantage of hardware acceleration if it is later
>> available...

"Shlomi Yaakobovich" <Shlomi@xxxxxxxxxx> posted a patch to
update the features as slaves are added and removed, based on the
features advertised by the slaves. His original patch wasn't properly
based; this is the same change set redone to patch against 2.6.9.

-J

---
-Jay Vosburgh, IBM Linux Technology Center, fubar@xxxxxxxxxx


Index: linux-2681-bd/drivers/net/bonding/bond_main.c
===================================================================
RCS file: /sda7/CVS/linux-2681-bd/drivers/net/bonding/bond_main.c,v
retrieving revision 1.2
retrieving revision 1.3
diff -u -u -r1.2 -r1.3
--- linux-2681-bd/drivers/net/bonding/bond_main.c 15 Oct 2004 22:11:14 -0000 1.2
+++ linux-2681-bd/drivers/net/bonding/bond_main.c 15 Oct 2004 23:27:34 -0000 1.3
@@ -1580,6 +1580,32 @@
return 0;
}

+enum { /* don't set these here */
+ BOND_MAINTAINED_FEATURES =
+ NETIF_F_VLAN_CHALLENGED|NETIF_F_HW_VLAN_TX |
+ NETIF_F_HW_VLAN_RX |NETIF_F_HW_VLAN_FILTER
+};
+
+static void bond_set_features(struct net_device *bond_dev)
+{
+ struct bonding *bond = bond_dev->priv;
+ struct slave *slave;
+ int i, features = 0;
+
+ bond_for_each_slave(bond, slave, i) {
+ struct net_device *slave_dev = slave->dev;
+ if (i == 0) {
+ features = slave_dev->features;
+ } else {
+ features &= slave_dev->features;
+ }
+ }
+ /* clear all previous features */
+ bond_dev->features &= BOND_MAINTAINED_FEATURES;
+ /* add common features, don't touch driver maintained ones */
+ bond_dev->features |= (features & ~BOND_MAINTAINED_FEATURES);
+}
+
/* enslave device <slave> to bond device <master> */
static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_dev)
{
@@ -1972,6 +1998,7 @@
new_slave->link != BOND_LINK_DOWN ? "n up" : " down");

/* enslave is successful */
+ bond_set_features(bond_dev);
return 0;

/* Undo stages on error */
@@ -2177,6 +2204,7 @@

kfree(slave);

+ bond_set_features(bond_dev);
return 0; /* deletion OK */
}

@@ -2292,6 +2320,7 @@
printk(KERN_INFO DRV_NAME
": %s: released all slaves\n",
bond_dev->name);
+ bond_set_features(bond_dev);

out:
write_unlock_bh(&bond->lock);
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/