Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754439AbdCPWg7 (ORCPT ); Thu, 16 Mar 2017 18:36:59 -0400 Received: from mail-it0-f66.google.com ([209.85.214.66]:34674 "EHLO mail-it0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752357AbdCPWgw (ORCPT ); Thu, 16 Mar 2017 18:36:52 -0400 MIME-Version: 1.0 In-Reply-To: <1489701893.28631.248.camel@edumazet-glaptop3.roam.corp.google.com> References: <20170316183142.15806.38824.stgit@localhost.localdomain> <20170316183244.15806.77453.stgit@localhost.localdomain> <1489701893.28631.248.camel@edumazet-glaptop3.roam.corp.google.com> From: Alexander Duyck Date: Thu, 16 Mar 2017 15:36:21 -0700 Message-ID: Subject: Re: [net-next PATCH 2/5] net: Call sk_mark_napi_id() in the ACK receive path To: Eric Dumazet Cc: Netdev , "linux-kernel@vger.kernel.org" , "Samudrala, Sridhar" , Eric Dumazet , David Miller Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1422 Lines: 37 On Thu, Mar 16, 2017 at 3:04 PM, Eric Dumazet wrote: > On Thu, 2017-03-16 at 11:32 -0700, Alexander Duyck wrote: >> From: Sridhar Samudrala >> >> Call sk_mark_napi_id() in the ACK receive path of a TCP_NEW_SYN_RECV >> socket, so that sk->napi_id is set even if the socket hasn't yet received >> any data. With this change we should be able to start busy polling >> slightly earlier. >> >> Signed-off-by: Sridhar Samudrala >> Signed-off-by: Alexander Duyck >> --- >> net/ipv4/tcp_ipv4.c | 1 + >> 1 file changed, 1 insertion(+) >> >> diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c >> index 08d870e45658..b86002a296f1 100644 >> --- a/net/ipv4/tcp_ipv4.c >> +++ b/net/ipv4/tcp_ipv4.c >> @@ -1687,6 +1687,7 @@ int tcp_v4_rcv(struct sk_buff *skb) >> tcp_v4_send_reset(nsk, skb); >> goto discard_and_relse; >> } else { >> + sk_mark_napi_id(nsk, skb); >> sock_put(sk); >> return 0; >> } >> > > Seems good, but what about IPv6 ? Sorry, I spaced out and overlooked that this would also be an issue for IPv6. > Frankly this calls for the sk_mark_napi_id() being done in > tcp_child_process() instead of its four callers. We can look into that for the next version.