diff mbox

[net-next] igb: Add support for byte queue limits.

Message ID 1324480695.2301.4.camel@edumazet-HP-Compaq-6005-Pro-SFF-PC
State Awaiting Upstream, archived
Delegated to: David Miller
Headers show

Commit Message

Eric Dumazet Dec. 21, 2011, 3:18 p.m. UTC
This adds support for byte queue limits (BQL)

Since this driver collects bytes count in 'bytecount' field, use it also
in igb_tx_map()

Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
CC: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
CC: Alexander Duyck <alexander.h.duyck@intel.com>
---
 drivers/net/ethernet/intel/igb/igb.h      |    5 +++++
 drivers/net/ethernet/intel/igb/igb_main.c |    5 +++++
 2 files changed, 10 insertions(+)



--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Comments

David Miller Dec. 21, 2011, 7:42 p.m. UTC | #1
From: Eric Dumazet <eric.dumazet@gmail.com>
Date: Wed, 21 Dec 2011 16:18:15 +0100

> This adds support for byte queue limits (BQL)
> 
> Since this driver collects bytes count in 'bytecount' field, use it also
> in igb_tx_map()
> 
> Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
> CC: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
> CC: Alexander Duyck <alexander.h.duyck@intel.com>

Intel folks, you got this?
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Wyborny, Carolyn Dec. 21, 2011, 9:17 p.m. UTC | #2
>-----Original Message-----
>From: netdev-owner@vger.kernel.org [mailto:netdev-owner@vger.kernel.org]
>On Behalf Of David Miller
>Sent: Wednesday, December 21, 2011 11:42 AM
>To: eric.dumazet@gmail.com
>Cc: netdev@vger.kernel.org; Kirsher, Jeffrey T; Duyck, Alexander H
>Subject: Re: [PATCH net-next] igb: Add support for byte queue limits.
>
>From: Eric Dumazet <eric.dumazet@gmail.com>
>Date: Wed, 21 Dec 2011 16:18:15 +0100
>
>> This adds support for byte queue limits (BQL)
>>
>> Since this driver collects bytes count in 'bytecount' field, use it
>also
>> in igb_tx_map()
>>
>> Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
>> CC: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
>> CC: Alexander Duyck <alexander.h.duyck@intel.com>
>
>Intel folks, you got this?
>--
>To unsubscribe from this list: send the line "unsubscribe netdev" in
>the body of a message to majordomo@vger.kernel.org
>More majordomo info at  http://vger.kernel.org/majordomo-info.html

Yes, although many are out for the holidays. 

ACK.  We'll get it into our queue for testing.

Thanks,

Carolyn Wyborny
Linux Development
LAN Access Division
Intel Corporation


--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Eric Dumazet Jan. 3, 2012, 6:07 a.m. UTC | #3
Le mercredi 21 décembre 2011 à 21:17 +0000, Wyborny, Carolyn a écrit :
> 
> >-----Original Message-----
> >From: netdev-owner@vger.kernel.org [mailto:netdev-owner@vger.kernel.org]
> >On Behalf Of David Miller
> >Sent: Wednesday, December 21, 2011 11:42 AM
> >To: eric.dumazet@gmail.com
> >Cc: netdev@vger.kernel.org; Kirsher, Jeffrey T; Duyck, Alexander H
> >Subject: Re: [PATCH net-next] igb: Add support for byte queue limits.
> >
> >From: Eric Dumazet <eric.dumazet@gmail.com>
> >Date: Wed, 21 Dec 2011 16:18:15 +0100
> >
> >> This adds support for byte queue limits (BQL)
> >>
> >> Since this driver collects bytes count in 'bytecount' field, use it
> >also
> >> in igb_tx_map()
> >>
> >> Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
> >> CC: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
> >> CC: Alexander Duyck <alexander.h.duyck@intel.com>
> >
> >Intel folks, you got this?
> >--
> >To unsubscribe from this list: send the line "unsubscribe netdev" in
> >the body of a message to majordomo@vger.kernel.org
> >More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
> Yes, although many are out for the holidays. 
> 
> ACK.  We'll get it into our queue for testing.

Any news on this patch ?

I would like it being added for next merge window.

By the way I did test it on my machine.

Thanks


--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Kirsher, Jeffrey T Jan. 3, 2012, 10:15 a.m. UTC | #4
On Tue, 2012-01-03 at 07:07 +0100, Eric Dumazet wrote:
> Le mercredi 21 décembre 2011 à 21:17 +0000, Wyborny, Carolyn a écrit :
> > 
> > >-----Original Message-----
> > >From: netdev-owner@vger.kernel.org [mailto:netdev-owner@vger.kernel.org]
> > >On Behalf Of David Miller
> > >Sent: Wednesday, December 21, 2011 11:42 AM
> > >To: eric.dumazet@gmail.com
> > >Cc: netdev@vger.kernel.org; Kirsher, Jeffrey T; Duyck, Alexander H
> > >Subject: Re: [PATCH net-next] igb: Add support for byte queue limits.
> > >
> > >From: Eric Dumazet <eric.dumazet@gmail.com>
> > >Date: Wed, 21 Dec 2011 16:18:15 +0100
> > >
> > >> This adds support for byte queue limits (BQL)
> > >>
> > >> Since this driver collects bytes count in 'bytecount' field, use it
> > >also
> > >> in igb_tx_map()
> > >>
> > >> Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
> > >> CC: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
> > >> CC: Alexander Duyck <alexander.h.duyck@intel.com>
> > >
> > >Intel folks, you got this?
> > >--
> > >To unsubscribe from this list: send the line "unsubscribe netdev" in
> > >the body of a message to majordomo@vger.kernel.org
> > >More majordomo info at  http://vger.kernel.org/majordomo-info.html
> > 
> > Yes, although many are out for the holidays. 
> > 
> > ACK.  We'll get it into our queue for testing.
> 
> Any news on this patch ?
> 
> I would like it being added for next merge window.
> 
> By the way I did test it on my machine.
> 
> Thanks
> 

Yes, it passed testing, so I will push it in my next series of patches.
Just waiting on the current series to be accepted before I push it.
Eric Dumazet Jan. 5, 2012, 6:26 a.m. UTC | #5
Le mardi 03 janvier 2012 à 02:15 -0800, Jeff Kirsher a écrit :
> On Tue, 2012-01-03 at 07:07 +0100, Eric Dumazet wrote:
> > 
> > Any news on this patch ?
> > 
> > I would like it being added for next merge window.
> > 
> > Thanks
> > 
> 
> Yes, it passed testing, so I will push it in my next series of patches.
> Just waiting on the current series to be accepted before I push it.

Thanks Jeff !


--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/drivers/net/ethernet/intel/igb/igb.h b/drivers/net/ethernet/intel/igb/igb.h
index c69feeb..3d12e67 100644
--- a/drivers/net/ethernet/intel/igb/igb.h
+++ b/drivers/net/ethernet/intel/igb/igb.h
@@ -447,4 +447,9 @@  static inline s32 igb_get_phy_info(struct e1000_hw *hw)
 	return 0;
 }
 
+static inline struct netdev_queue *txring_txq(const struct igb_ring *tx_ring)
+{
+	return netdev_get_tx_queue(tx_ring->netdev, tx_ring->queue_index);
+}
+
 #endif /* _IGB_H_ */
diff --git a/drivers/net/ethernet/intel/igb/igb_main.c b/drivers/net/ethernet/intel/igb/igb_main.c
index 89d576c..dcc68cc 100644
--- a/drivers/net/ethernet/intel/igb/igb_main.c
+++ b/drivers/net/ethernet/intel/igb/igb_main.c
@@ -3201,6 +3201,7 @@  static void igb_clean_tx_ring(struct igb_ring *tx_ring)
 		buffer_info = &tx_ring->tx_buffer_info[i];
 		igb_unmap_and_free_tx_resource(tx_ring, buffer_info);
 	}
+	netdev_tx_reset_queue(txring_txq(tx_ring));
 
 	size = sizeof(struct igb_tx_buffer) * tx_ring->count;
 	memset(tx_ring->tx_buffer_info, 0, size);
@@ -4238,6 +4239,8 @@  static void igb_tx_map(struct igb_ring *tx_ring,
 		frag++;
 	}
 
+	netdev_tx_sent_queue(txring_txq(tx_ring), first->bytecount);
+
 	/* write last descriptor with RS and EOP bits */
 	cmd_type |= cpu_to_le32(size) | cpu_to_le32(IGB_TXD_DCMD);
 	tx_desc->read.cmd_type_len = cmd_type;
@@ -5777,6 +5780,8 @@  static bool igb_clean_tx_irq(struct igb_q_vector *q_vector)
 		}
 	}
 
+	netdev_tx_completed_queue(txring_txq(tx_ring),
+				  total_packets, total_bytes);
 	i += tx_ring->count;
 	tx_ring->next_to_clean = i;
 	u64_stats_update_begin(&tx_ring->tx_syncp);