From 42b2ad0d3be427b1915a523c87555bcf4b507c01 Mon Sep 17 00:00:00 2001 From: nbd Date: Fri, 21 Sep 2012 00:13:12 +0000 Subject: [PATCH] cns3xxx: add a small optimization for rx offload git-svn-id: svn://svn.openwrt.org/openwrt/trunk@33500 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../420-ethernet_optimize_rx_offload.patch | 27 +++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 target/linux/cns3xxx/patches-3.3/420-ethernet_optimize_rx_offload.patch diff --git a/target/linux/cns3xxx/patches-3.3/420-ethernet_optimize_rx_offload.patch b/target/linux/cns3xxx/patches-3.3/420-ethernet_optimize_rx_offload.patch new file mode 100644 index 000000000..67929ef89 --- /dev/null +++ b/target/linux/cns3xxx/patches-3.3/420-ethernet_optimize_rx_offload.patch @@ -0,0 +1,27 @@ +--- a/drivers/net/ethernet/cavium/cns3xxx_eth.c ++++ b/drivers/net/ethernet/cavium/cns3xxx_eth.c +@@ -653,17 +653,17 @@ static int eth_poll(struct napi_struct * + case 6: + case 13: + case 14: +- if (desc->l4f) ++ if (!desc->l4f) { ++ skb->ip_summed = CHECKSUM_UNNECESSARY; ++ napi_gro_receive(napi, skb); + break; +- +- skb->ip_summed = CHECKSUM_UNNECESSARY; +- break; ++ } ++ /* fall through */ + default: +- break; ++ netif_receive_skb(skb); ++ break; + } + +- napi_gro_receive(napi, skb); +- + sw->frag_first = NULL; + sw->frag_last = NULL; + }