aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/e1000/e1000_main.c
diff options
context:
space:
mode:
authorJesse Brandeburg <jesse.brandeburg@intel.com>2007-01-18 12:25:31 -0500
committerJeff Garzik <jeff@garzik.org>2007-02-05 16:58:41 -0500
commit7753b171c4e7604294060d4039214c8c8319bfca (patch)
treecdb080bcef6cbb4d413f335100d75a3a7218b942 /drivers/net/e1000/e1000_main.c
parentf6c57bafcdebed4429cdda206149ddcbb1d46e91 (diff)
e1000: tune our dynamic itr transmit packet accounting
The driver was still mis-calculating the number of bytes sent during transmit, now the driver computes what appears to be exactly 100% correct byte counts (not including CRC) when figuring out how many bytes and frames were sent during the current transmit packet.
Diffstat (limited to 'drivers/net/e1000/e1000_main.c')
-rw-r--r--drivers/net/e1000/e1000_main.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/net/e1000/e1000_main.c b/drivers/net/e1000/e1000_main.c
index 8c6c74d1284a..ae76479d89d1 100644
--- a/drivers/net/e1000/e1000_main.c
+++ b/drivers/net/e1000/e1000_main.c
@@ -4020,10 +4020,13 @@ e1000_clean_tx_irq(struct e1000_adapter *adapter,
4020 4020
4021 if (cleaned) { 4021 if (cleaned) {
4022 struct sk_buff *skb = buffer_info->skb; 4022 struct sk_buff *skb = buffer_info->skb;
4023 unsigned int segs = skb_shinfo(skb)->gso_segs; 4023 unsigned int segs, bytecount;
4024 segs = skb_shinfo(skb)->gso_segs ?: 1;
4025 /* multiply data chunks by size of headers */
4026 bytecount = ((segs - 1) * skb_headlen(skb)) +
4027 skb->len;
4024 total_tx_packets += segs; 4028 total_tx_packets += segs;
4025 total_tx_packets++; 4029 total_tx_bytes += bytecount;
4026 total_tx_bytes += skb->len;
4027 } 4030 }
4028 e1000_unmap_and_free_tx_resource(adapter, buffer_info); 4031 e1000_unmap_and_free_tx_resource(adapter, buffer_info);
4029 tx_desc->upper.data = 0; 4032 tx_desc->upper.data = 0;