Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753772AbZAKNQN (ORCPT ); Sun, 11 Jan 2009 08:16:13 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1751367AbZAKNPz (ORCPT ); Sun, 11 Jan 2009 08:15:55 -0500 Received: from gw1.cosmosbay.com ([86.65.150.130]:39020 "EHLO gw1.cosmosbay.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751233AbZAKNPy convert rfc822-to-8bit (ORCPT ); Sun, 11 Jan 2009 08:15:54 -0500 Message-ID: <4969F0D1.8020504@cosmosbay.com> Date: Sun, 11 Jan 2009 14:14:57 +0100 From: Eric Dumazet User-Agent: Thunderbird 2.0.0.19 (Windows/20081209) MIME-Version: 1.0 To: Evgeniy Polyakov CC: Willy Tarreau , David Miller , ben@zeus.com, jarkao2@gmail.com, mingo@elte.hu, linux-kernel@vger.kernel.org, netdev@vger.kernel.org, jens.axboe@oracle.com Subject: Re: [PATCH] tcp: splice as many packets as possible at once References: <4966F2F4.9080901@cosmosbay.com> <49677074.5090802@cosmosbay.com> <20090109185448.GA1999@1wt.eu> <4967B8C5.10803@cosmosbay.com> <20090109212400.GA3727@1wt.eu> <20090109220737.GA4111@1wt.eu> <4967CBB9.1060403@cosmosbay.com> <20090109221744.GA4819@1wt.eu> <20090109224258.GA10257@ioremap.net> <496850D5.8040907@cosmosbay.com> <20090111125759.GB24173@ioremap.net> In-Reply-To: <20090111125759.GB24173@ioremap.net> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 8BIT X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-1.6 (gw1.cosmosbay.com [0.0.0.0]); Sun, 11 Jan 2009 14:15:00 +0100 (CET) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1695 Lines: 44 Evgeniy Polyakov a ?crit : > Hi Eric. > > On Sat, Jan 10, 2009 at 08:40:05AM +0100, Eric Dumazet (dada1@cosmosbay.com) wrote: >>> Not to interrupt the discussion, but for the clarification, that >>> release_sock/lock_sock is used to process the backlog accumulated while >>> socket was locked. And while dropping additional pair before the final >>> release is ok, but moving this itself should be thought of twice. >>> >> Hum... I just caught the release_sock(sk)/lock_sock(sk) done in skb_splice_bits() >> >> So : >> >> 1) the release_sock/lock_sock done in tcp_splice_read() is not necessary >> to process backlog. Its already done in skb_splice_bits() > > Yes, in the tcp_splice_read() they are added to remove a deadlock. Could you elaborate ? A deadlock only if !SPLICE_F_NONBLOCK ? > >> 2) If we loop in tcp_read_sock() calling skb_splice_bits() several times >> then we should perform the following tests inside this loop ? >> >> if (sk->sk_err || sk->sk_state == TCP_CLOSE || (sk->sk_shutdown & RCV_SHUTDOWN) || >> signal_pending(current)) break; >> >> And removie them from tcp_splice_read() ? > > It could be done, but for what reason? To detect disconnected socket early? > Does it worth the changes? > I was thinking about the case your thread is doing a splice() from tcp socket to a pipe, while another thread is doing the splice from this pipe to something else. Once patched, tcp_read_sock() could loop a long time... -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/