diff options
author | Felix Fietkau <nbd@openwrt.org> | 2008-10-28 17:54:22 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2008-10-28 17:54:22 +0000 |
commit | d1b986bd54b12bf193ae102feb9fd70b9e839121 (patch) | |
tree | e93ee7a108ce42647dc070d033120d1121c15a22 /target/linux/generic-2.6 | |
parent | 3166a619460dd4a2e43b60c0c953df798d5549b1 (diff) | |
download | upstream-d1b986bd54b12bf193ae102feb9fd70b9e839121.tar.gz upstream-d1b986bd54b12bf193ae102feb9fd70b9e839121.tar.bz2 upstream-d1b986bd54b12bf193ae102feb9fd70b9e839121.zip |
improve routing/nat performance for devices using the marvell 88e6060 switch
SVN-Revision: 13060
Diffstat (limited to 'target/linux/generic-2.6')
3 files changed, 12 insertions, 5 deletions
diff --git a/target/linux/generic-2.6/files/drivers/net/phy/mvswitch.c b/target/linux/generic-2.6/files/drivers/net/phy/mvswitch.c index 78e5afe9bd..f5a292a80d 100644 --- a/target/linux/generic-2.6/files/drivers/net/phy/mvswitch.c +++ b/target/linux/generic-2.6/files/drivers/net/phy/mvswitch.c @@ -338,6 +338,7 @@ mvswitch_config_init(struct phy_device *pdev) ); /* hook into the tx function */ + pdev->pkt_align = 2; priv->hardstart = dev->hard_start_xmit; pdev->netif_receive_skb = mvswitch_netif_receive_skb; pdev->netif_rx = mvswitch_netif_rx; diff --git a/target/linux/generic-2.6/patches-2.6.26/630-phy_packets.patch b/target/linux/generic-2.6/patches-2.6.26/630-phy_packets.patch index f1c1580e0d..a561bb29c1 100644 --- a/target/linux/generic-2.6/patches-2.6.26/630-phy_packets.patch +++ b/target/linux/generic-2.6/patches-2.6.26/630-phy_packets.patch @@ -30,7 +30,7 @@ --- a/include/linux/phy.h +++ b/include/linux/phy.h -@@ -309,6 +309,17 @@ +@@ -309,6 +309,20 @@ void (*adjust_link)(struct net_device *dev); void (*adjust_state)(struct net_device *dev); @@ -45,6 +45,9 @@ + */ + int (*netif_receive_skb)(struct sk_buff *skb); + int (*netif_rx)(struct sk_buff *skb); ++ ++ /* alignment offset for packets */ ++ int pkt_align; }; #define to_phy_device(d) container_of(d, struct phy_device, dev) diff --git a/target/linux/generic-2.6/patches-2.6.27/630-phy_packets.patch b/target/linux/generic-2.6/patches-2.6.27/630-phy_packets.patch index 4fe1357913..a561bb29c1 100644 --- a/target/linux/generic-2.6/patches-2.6.27/630-phy_packets.patch +++ b/target/linux/generic-2.6/patches-2.6.27/630-phy_packets.patch @@ -1,6 +1,6 @@ --- a/drivers/net/phy/phy_device.c +++ b/drivers/net/phy/phy_device.c -@@ -143,6 +143,18 @@ int phy_scan_fixups(struct phy_device *p +@@ -143,6 +143,18 @@ } EXPORT_SYMBOL(phy_scan_fixups); @@ -19,7 +19,7 @@ struct phy_device* phy_device_create(struct mii_bus *bus, int addr, int phy_id) { struct phy_device *dev; -@@ -168,6 +180,8 @@ struct phy_device* phy_device_create(str +@@ -168,6 +180,8 @@ dev->bus = bus; dev->state = PHY_DOWN; @@ -30,7 +30,7 @@ --- a/include/linux/phy.h +++ b/include/linux/phy.h -@@ -309,6 +309,17 @@ struct phy_device { +@@ -309,6 +309,20 @@ void (*adjust_link)(struct net_device *dev); void (*adjust_state)(struct net_device *dev); @@ -45,12 +45,15 @@ + */ + int (*netif_receive_skb)(struct sk_buff *skb); + int (*netif_rx)(struct sk_buff *skb); ++ ++ /* alignment offset for packets */ ++ int pkt_align; }; #define to_phy_device(d) container_of(d, struct phy_device, dev) --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h -@@ -613,6 +613,7 @@ struct net_device +@@ -613,6 +613,7 @@ void *ax25_ptr; /* AX.25 specific data */ struct wireless_dev *ieee80211_ptr; /* IEEE 802.11 specific data, assign before registering */ |