Commit 70e09b6b authored by Scott Feldman's avatar Scott Feldman Committed by Jeff Garzik

[netdrvr e1000] add a bit of source cross-version compat

* Wrap TSO support with NETIF_F_TSO to keep same driver
  source between 2.4 and 2.5.
parent f7c20150
...@@ -63,7 +63,9 @@ ...@@ -63,7 +63,9 @@
#include <net/pkt_sched.h> #include <net/pkt_sched.h>
#include <linux/list.h> #include <linux/list.h>
#include <linux/reboot.h> #include <linux/reboot.h>
#ifdef NETIF_F_TSO
#include <net/checksum.h> #include <net/checksum.h>
#endif
#include <linux/workqueue.h> #include <linux/workqueue.h>
#include <linux/mii.h> #include <linux/mii.h>
#include <linux/ethtool.h> #include <linux/ethtool.h>
......
...@@ -61,7 +61,7 @@ ...@@ -61,7 +61,7 @@
char e1000_driver_name[] = "e1000"; char e1000_driver_name[] = "e1000";
char e1000_driver_string[] = "Intel(R) PRO/1000 Network Driver"; char e1000_driver_string[] = "Intel(R) PRO/1000 Network Driver";
char e1000_driver_version[] = "5.0.43-k2"; char e1000_driver_version[] = "5.0.43-k3";
char e1000_copyright[] = "Copyright (c) 1999-2003 Intel Corporation."; char e1000_copyright[] = "Copyright (c) 1999-2003 Intel Corporation.";
/* e1000_pci_tbl - PCI Device ID Table /* e1000_pci_tbl - PCI Device ID Table
...@@ -455,9 +455,11 @@ e1000_probe(struct pci_dev *pdev, ...@@ -455,9 +455,11 @@ e1000_probe(struct pci_dev *pdev,
netdev->features = NETIF_F_SG; netdev->features = NETIF_F_SG;
} }
#ifdef NETIF_F_TSO
if((adapter->hw.mac_type >= e1000_82544) && if((adapter->hw.mac_type >= e1000_82544) &&
(adapter->hw.mac_type != e1000_82547)) (adapter->hw.mac_type != e1000_82547))
netdev->features |= NETIF_F_TSO; netdev->features |= NETIF_F_TSO;
#endif
if(pci_using_dac) if(pci_using_dac)
netdev->features |= NETIF_F_HIGHDMA; netdev->features |= NETIF_F_HIGHDMA;
...@@ -1434,6 +1436,7 @@ e1000_watchdog(unsigned long data) ...@@ -1434,6 +1436,7 @@ e1000_watchdog(unsigned long data)
static inline boolean_t static inline boolean_t
e1000_tso(struct e1000_adapter *adapter, struct sk_buff *skb, int tx_flags) e1000_tso(struct e1000_adapter *adapter, struct sk_buff *skb, int tx_flags)
{ {
#ifdef NETIF_F_TSO
struct e1000_context_desc *context_desc; struct e1000_context_desc *context_desc;
int i; int i;
uint8_t ipcss, ipcso, tucss, tucso, hdr_len; uint8_t ipcss, ipcso, tucss, tucso, hdr_len;
...@@ -1477,6 +1480,7 @@ e1000_tso(struct e1000_adapter *adapter, struct sk_buff *skb, int tx_flags) ...@@ -1477,6 +1480,7 @@ e1000_tso(struct e1000_adapter *adapter, struct sk_buff *skb, int tx_flags)
return TRUE; return TRUE;
} }
#endif
return FALSE; return FALSE;
} }
...@@ -1520,7 +1524,9 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb) ...@@ -1520,7 +1524,9 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb)
struct e1000_desc_ring *tx_ring = &adapter->tx_ring; struct e1000_desc_ring *tx_ring = &adapter->tx_ring;
int len = skb->len, offset = 0, size, count = 0, i; int len = skb->len, offset = 0, size, count = 0, i;
#ifdef NETIF_F_TSO
int tso = skb_shinfo(skb)->tso_size; int tso = skb_shinfo(skb)->tso_size;
#endif
int nr_frags = skb_shinfo(skb)->nr_frags; int nr_frags = skb_shinfo(skb)->nr_frags;
int f; int f;
len -= skb->data_len; len -= skb->data_len;
...@@ -1529,10 +1535,12 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb) ...@@ -1529,10 +1535,12 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb)
while(len) { while(len) {
size = min(len, E1000_MAX_DATA_PER_TXD); size = min(len, E1000_MAX_DATA_PER_TXD);
#ifdef NETIF_F_TSO
/* Workaround for premature desc write-backs /* Workaround for premature desc write-backs
* in TSO mode. Append 4-byte sentinel desc */ * in TSO mode. Append 4-byte sentinel desc */
if(tso && !nr_frags && size == len && size > 4) if(tso && !nr_frags && size == len && size > 4)
size -= 4; size -= 4;
#endif
tx_ring->buffer_info[i].length = size; tx_ring->buffer_info[i].length = size;
tx_ring->buffer_info[i].dma = tx_ring->buffer_info[i].dma =
pci_map_single(adapter->pdev, pci_map_single(adapter->pdev,
...@@ -1556,10 +1564,12 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb) ...@@ -1556,10 +1564,12 @@ e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb)
while(len) { while(len) {
size = min(len, E1000_MAX_DATA_PER_TXD); size = min(len, E1000_MAX_DATA_PER_TXD);
#ifdef NETIF_F_TSO
/* Workaround for premature desc write-backs /* Workaround for premature desc write-backs
* in TSO mode. Append 4-byte sentinel desc */ * in TSO mode. Append 4-byte sentinel desc */
if(tso && f == (nr_frags-1) && size == len && size > 4) if(tso && f == (nr_frags-1) && size == len && size > 4)
size -= 4; size -= 4;
#endif
tx_ring->buffer_info[i].length = size; tx_ring->buffer_info[i].length = size;
tx_ring->buffer_info[i].dma = tx_ring->buffer_info[i].dma =
pci_map_page(adapter->pdev, pci_map_page(adapter->pdev,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment