Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758994AbZAHRRv (ORCPT ); Thu, 8 Jan 2009 12:17:51 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1754107AbZAHRRl (ORCPT ); Thu, 8 Jan 2009 12:17:41 -0500 Received: from 1wt.eu ([62.212.114.60]:1256 "EHLO 1wt.eu" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752508AbZAHRRk (ORCPT ); Thu, 8 Jan 2009 12:17:40 -0500 Date: Thu, 8 Jan 2009 18:14:19 +0100 From: Willy Tarreau To: Ingo Molnar Cc: Jarek Poplawski , Ben Mansell , Jens Axboe , linux-kernel@vger.kernel.org, netdev@vger.kernel.org Subject: Re: Data corruption issue with splice() on 2.6.27.10 Message-ID: <20090108171419.GE5038@1wt.eu> References: <20090106181559.GA29426@1wt.eu> <20090108071651.GA4496@ff.dom.local> <20090108080520.GG30749@1wt.eu> <20090108145259.GF18120@elte.hu> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20090108145259.GF18120@elte.hu> User-Agent: Mutt/1.5.11 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2028 Lines: 45 On Thu, Jan 08, 2009 at 03:53:00PM +0100, Ingo Molnar wrote: > > * Willy Tarreau wrote: > > > On Thu, Jan 08, 2009 at 07:16:51AM +0000, Jarek Poplawski wrote: > > > On 06-01-2009 19:15, Willy Tarreau wrote: > > > ... > > > > Ah, so you might also have discovered a few annoyances with the API, eg > > > > the fact that splice() returns after the first read in non-blocking mode, > > > > as well as the fact that it never returns zero on close, but -EAGAIN, > > > > which requires an additional recv(MSG_PEEK) to distinguish between a > > > > close and a lack of data. But I leave that for a later discussion, let's > > > > address the corruption issue first. > > > > > > FYI, this should be just fixed: > > > http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commitdiff;h=4f7d54f59bc470f0aaa932f747a95232d7ebf8b1 > > > > > > > Ah cool, thanks Jarek for notifying us. Indeed, it's the exact same patch > > I had pending here ;-) > > > > I'll ping Greg for a backport into -stable, as applications relying on > > this will clearly not work without that fix. > > > > The other one I had consists in removing "|| !timeo" at the end of the > > loop, because otherwise splice() returns very small chunks (typically > > 1448 or 1460 bytes), leading to disastrous performance on high bandwidth > > links. At 10 Gbps, this means about 800000 calls to splice() per second! > > looks interesting - would you mind to submit it? OK I will. I preferred to focus on the bug first, which is clearly more annoying since it basically makes splice() unusuable in a proxy. I wanted to avoid changes before the bug is fixed, but now, with the first investigations, it seems that the fix will be in a different area anyway so that doesn't matter. Regards, Willy -- 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/