aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/sfc/rx.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/sfc/rx.c')
-rw-r--r--drivers/net/sfc/rx.c30
1 files changed, 15 insertions, 15 deletions
diff --git a/drivers/net/sfc/rx.c b/drivers/net/sfc/rx.c
index 6d0959b5158e..3925fd621177 100644
--- a/drivers/net/sfc/rx.c
+++ b/drivers/net/sfc/rx.c
@@ -37,7 +37,7 @@
37 * This driver supports two methods for allocating and using RX buffers: 37 * This driver supports two methods for allocating and using RX buffers:
38 * each RX buffer may be backed by an skb or by an order-n page. 38 * each RX buffer may be backed by an skb or by an order-n page.
39 * 39 *
40 * When LRO is in use then the second method has a lower overhead, 40 * When GRO is in use then the second method has a lower overhead,
41 * since we don't have to allocate then free skbs on reassembled frames. 41 * since we don't have to allocate then free skbs on reassembled frames.
42 * 42 *
43 * Values: 43 * Values:
@@ -50,25 +50,25 @@
50 * 50 *
51 * - Since pushing and popping descriptors are separated by the rx_queue 51 * - Since pushing and popping descriptors are separated by the rx_queue
52 * size, so the watermarks should be ~rxd_size. 52 * size, so the watermarks should be ~rxd_size.
53 * - The performance win by using page-based allocation for LRO is less 53 * - The performance win by using page-based allocation for GRO is less
54 * than the performance hit of using page-based allocation of non-LRO, 54 * than the performance hit of using page-based allocation of non-GRO,
55 * so the watermarks should reflect this. 55 * so the watermarks should reflect this.
56 * 56 *
57 * Per channel we maintain a single variable, updated by each channel: 57 * Per channel we maintain a single variable, updated by each channel:
58 * 58 *
59 * rx_alloc_level += (lro_performed ? RX_ALLOC_FACTOR_LRO : 59 * rx_alloc_level += (gro_performed ? RX_ALLOC_FACTOR_GRO :
60 * RX_ALLOC_FACTOR_SKB) 60 * RX_ALLOC_FACTOR_SKB)
61 * Per NAPI poll interval, we constrain rx_alloc_level to 0..MAX (which 61 * Per NAPI poll interval, we constrain rx_alloc_level to 0..MAX (which
62 * limits the hysteresis), and update the allocation strategy: 62 * limits the hysteresis), and update the allocation strategy:
63 * 63 *
64 * rx_alloc_method = (rx_alloc_level > RX_ALLOC_LEVEL_LRO ? 64 * rx_alloc_method = (rx_alloc_level > RX_ALLOC_LEVEL_GRO ?
65 * RX_ALLOC_METHOD_PAGE : RX_ALLOC_METHOD_SKB) 65 * RX_ALLOC_METHOD_PAGE : RX_ALLOC_METHOD_SKB)
66 */ 66 */
67static int rx_alloc_method = RX_ALLOC_METHOD_AUTO; 67static int rx_alloc_method = RX_ALLOC_METHOD_AUTO;
68 68
69#define RX_ALLOC_LEVEL_LRO 0x2000 69#define RX_ALLOC_LEVEL_GRO 0x2000
70#define RX_ALLOC_LEVEL_MAX 0x3000 70#define RX_ALLOC_LEVEL_MAX 0x3000
71#define RX_ALLOC_FACTOR_LRO 1 71#define RX_ALLOC_FACTOR_GRO 1
72#define RX_ALLOC_FACTOR_SKB (-2) 72#define RX_ALLOC_FACTOR_SKB (-2)
73 73
74/* This is the percentage fill level below which new RX descriptors 74/* This is the percentage fill level below which new RX descriptors
@@ -441,19 +441,19 @@ static void efx_rx_packet__check_len(struct efx_rx_queue *rx_queue,
441 efx_rx_queue_channel(rx_queue)->n_rx_overlength++; 441 efx_rx_queue_channel(rx_queue)->n_rx_overlength++;
442} 442}
443 443
444/* Pass a received packet up through the generic LRO stack 444/* Pass a received packet up through the generic GRO stack
445 * 445 *
446 * Handles driverlink veto, and passes the fragment up via 446 * Handles driverlink veto, and passes the fragment up via
447 * the appropriate LRO method 447 * the appropriate GRO method
448 */ 448 */
449static void efx_rx_packet_lro(struct efx_channel *channel, 449static void efx_rx_packet_gro(struct efx_channel *channel,
450 struct efx_rx_buffer *rx_buf, 450 struct efx_rx_buffer *rx_buf,
451 bool checksummed) 451 bool checksummed)
452{ 452{
453 struct napi_struct *napi = &channel->napi_str; 453 struct napi_struct *napi = &channel->napi_str;
454 gro_result_t gro_result; 454 gro_result_t gro_result;
455 455
456 /* Pass the skb/page into the LRO engine */ 456 /* Pass the skb/page into the GRO engine */
457 if (rx_buf->page) { 457 if (rx_buf->page) {
458 struct efx_nic *efx = channel->efx; 458 struct efx_nic *efx = channel->efx;
459 struct page *page = rx_buf->page; 459 struct page *page = rx_buf->page;
@@ -499,7 +499,7 @@ static void efx_rx_packet_lro(struct efx_channel *channel,
499 if (gro_result == GRO_NORMAL) { 499 if (gro_result == GRO_NORMAL) {
500 channel->rx_alloc_level += RX_ALLOC_FACTOR_SKB; 500 channel->rx_alloc_level += RX_ALLOC_FACTOR_SKB;
501 } else if (gro_result != GRO_DROP) { 501 } else if (gro_result != GRO_DROP) {
502 channel->rx_alloc_level += RX_ALLOC_FACTOR_LRO; 502 channel->rx_alloc_level += RX_ALLOC_FACTOR_GRO;
503 channel->irq_mod_score += 2; 503 channel->irq_mod_score += 2;
504 } 504 }
505} 505}
@@ -605,7 +605,7 @@ void __efx_rx_packet(struct efx_channel *channel,
605 } 605 }
606 606
607 if (likely(checksummed || rx_buf->page)) { 607 if (likely(checksummed || rx_buf->page)) {
608 efx_rx_packet_lro(channel, rx_buf, checksummed); 608 efx_rx_packet_gro(channel, rx_buf, checksummed);
609 return; 609 return;
610 } 610 }
611 611
@@ -628,7 +628,7 @@ void efx_rx_strategy(struct efx_channel *channel)
628{ 628{
629 enum efx_rx_alloc_method method = rx_alloc_method; 629 enum efx_rx_alloc_method method = rx_alloc_method;
630 630
631 /* Only makes sense to use page based allocation if LRO is enabled */ 631 /* Only makes sense to use page based allocation if GRO is enabled */
632 if (!(channel->efx->net_dev->features & NETIF_F_GRO)) { 632 if (!(channel->efx->net_dev->features & NETIF_F_GRO)) {
633 method = RX_ALLOC_METHOD_SKB; 633 method = RX_ALLOC_METHOD_SKB;
634 } else if (method == RX_ALLOC_METHOD_AUTO) { 634 } else if (method == RX_ALLOC_METHOD_AUTO) {
@@ -639,7 +639,7 @@ void efx_rx_strategy(struct efx_channel *channel)
639 channel->rx_alloc_level = RX_ALLOC_LEVEL_MAX; 639 channel->rx_alloc_level = RX_ALLOC_LEVEL_MAX;
640 640
641 /* Decide on the allocation method */ 641 /* Decide on the allocation method */
642 method = ((channel->rx_alloc_level > RX_ALLOC_LEVEL_LRO) ? 642 method = ((channel->rx_alloc_level > RX_ALLOC_LEVEL_GRO) ?
643 RX_ALLOC_METHOD_PAGE : RX_ALLOC_METHOD_SKB); 643 RX_ALLOC_METHOD_PAGE : RX_ALLOC_METHOD_SKB);
644 } 644 }
645 645