login
Login
/
Register
Search
Search this site:
Forums
News
Blogs
Features
Site
Home
»
Mailing list archives
»
linux-kernel
»
2007
»
May
»
7
Re: [RFC] splice() and readahead interaction
view
thread
Previous message: [thread] [
date
] [
author
]
Next message: [thread] [
date
] [
author
]
[view in full thread]
From: Andrew Morton
Subject:
Re: [RFC] splice() and readahead interaction
Date: Monday, May 7, 2007 - 2:54 pm
On Sat, 5 May 2007 05:04:29 -0400 "Fengguang Wu" <fengguang.wu@gmail.com> wrote:
quoted text
> Readahead logic somehow fails to populate the page range with data. > It can be because > 1) the readahead routine is not always called in the following lines of > fs/splice.c: > if (!loff || nr_pages > 1) > page_cache_readahead(mapping, &in->f_ra, in, index, > nr_pages); > 2) even called, page_cache_readahead() wont guarantee the pages are there. > It wont submit readahead I/O for pages already in the radix tree, or when > (ra_pages == 0), or after 256 cache hits. > > In your case, it should be because of the retried reads, which lead to > excessive cache hits, and disables readahead at some time. > > And that _one_ failure of readahead blocks the whole read process. > The application receives EAGAIN and retries the read, but > __generic_file_splice_read() refuse to make progress: > - in the previous invocation, it has allocated a blank page and inserted it > into the radix tree, but never has the chance to start I/O for it: the test > of SPLICE_F_NONBLOCK goes before that. > - in the retried invocation, the readahead code will neither get out of the > cache hit mode, nor will it submit I/O for an already existing page. > > The attached patch should fix the critical splice bug. Sorry for not being > able to test it locally for now - I'm at home and running knoppix. And the > readahead bug will be fixed by the upcoming on-demand readahead patch. I > should be back and submit it after a week. > > Thank you, > Fengguang Wu > > > [splice-nonblock-fix.patch text/x-patch (506B)] > --- linux-2.6.21.1/fs/splice.c.old 2007-05-05 04:40:38.000000000 -0400 > +++ linux-2.6.21.1/fs/splice.c 2007-05-05 04:41:59.000000000 -0400 > @@ -378,10 +378,11 @@ > * If in nonblock mode then dont block on waiting > * for an in-flight io page > */ > - if (flags & SPLICE_F_NONBLOCK) > - break; > - > - lock_page(page); > + if (flags & SPLICE_F_NONBLOCK) { > + if (TestSetPageLocked(page)) > + break; > + } else > + lock_page(page); > > /* > * page was truncated, stop here. if this isn't the
So.. afaik we're awaiting testing results for this change? -
unsubscribe notice
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/
Previous message: [thread] [
date
] [
author
]
Next message: [thread] [
date
] [
author
]
Messages in current thread:
Re: [RFC] splice() and readahead interaction
, Andrew Morton
, (Mon May 7, 2:54 pm)
Navigation
Mailing list archives
Recent posts
Popular discussions
linux-kernel
:
Fortier,Vincent [Montreal]
2.6.21.5 june 30th to july 1st date hang?
Jeff Dike
[ PATCH 2/6 ] UML - Formatting fixes around os_{read_write}_file callers
Liam Girdwood
[PATCH 07/13] regulator: regulator test harness
Oleg Nesterov
Re: Getting the new RxRPC patches upstream
Stefan Seyfried
Re: 2.6.19-rc5: grub is much slower resuming from suspend-to-disk than in 2.6.18
linux-netdev
:
Arnaud Ebalard
Re: [REGRESSION,BISECTED] MIPv6 support broken by f4f914b58019f0
Jan Engelhardt
Re: [PATCH iptables] extension: add xt_cpu match
Jarek Poplawski
Re: [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock().
Sebastian Andrzej Siewior
[PATCH 8/8] net/emergency: remove locking from reycling pool if emergncy pools are...
David Miller
Re: [PATCH] qlcnic: dont assume NET_IP_ALIGN is 2
git
:
Jakub Narebski
Re: git on MacOSX and files with decomposed utf-8 file names
Brandon Casey
Re: Thunderbird and patches (was Re: [PATCH v2] Enable setting attach as the def...
Christian Couder
[PATCH 1/3] rev-parse: add test script for "--verify"
Ramkumar Ramachandra
Re: [GSoC update] git-remote-svn: The final one
Junio C Hamano
Re: git-rm isn't the inverse action of git-add
openbsd-misc
:
Joachim Schipper
Re: UVC Webcams
Florin Andrei
SOLVED [was: firewall is very slow, something's wrong]
Todd Alan Smith
Re: Microsoft gets the Most Secure Operating Systems award
Neal Hogan
Re: Need Advice: Thinkpad T60 or T61?
Sam Fourman Jr.
Re: Real men don't attack straw men
git-commits-head
:
Linux Kernel Mailing List
ACPI: Disable ARB_DISABLE on platforms where it is not needed
Linux Kernel Mailing List
m68knommu: add read_barrier_depends() and irqs_disabled_flags()
Linux Kernel Mailing List
[MTD] Add mtd panic_write function pointer
Linux Kernel Mailing List
[ARM] pxa: remove duplicate select statements from Kconfig
Linux Kernel Mailing List
mlx4_core: Don't read reserved fields in mlx4_QUERY_ADAPTER()
Colocation donated by:
Syndicate