From: Shane Shrybman <shrybman@aei.ca>
To: Ram Pai <linuxram@us.ibm.com>
Cc: Andrew Morton <akpm@osdl.org>,
miklos@szeredi.hu, linux-kernel <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH] fix readahead breakage for sequential after random reads
Date: Wed, 04 Aug 2004 15:39:51 -0400 [thread overview]
Message-ID: <1091648391.3486.13.camel@mars> (raw)
In-Reply-To: <1091641117.15334.89.camel@localhost.localdomain>
On Wed, 2004-08-04 at 13:38, Ram Pai wrote:
> On Mon, 2004-07-26 at 21:18, Ram Pai wrote:
> > On Mon, 2004-07-26 at 17:08, Andrew Morton wrote:
> > > Ram Pai <linuxram@us.ibm.com> wrote:
> > > >
> > > > Andrew,
> > > > Yes the patch fixes a valid bug.
> > > >
> > >
> > > Please don't top-post :(
> > > > RP
> > > >
> > > > On Mon, 2004-07-26 at 16:29, Andrew Morton wrote:
> > > > > Miklos Szeredi <miklos@szeredi.hu> wrote:
> > > > > >
> > > > > > Current readahead logic is broken when a random read pattern is
> > > > > > followed by a long sequential read. The cause is that on a window
> > > > > > miss ra->next_size is set to ra->average, but ra->average is only
> > > > > > updated at the end of a sequence, so window size will remain 1 until
> > > > > > the end of the sequential read.
> > > > > >
> > > > > > This patch fixes this by taking the current sequence length into
> > > > > > account (code taken from towards end of page_cache_readahead()), and
> > > > > > also setting ra->average to a decent value in handle_ra_miss() when
> > > > > > sequential access is detected.
> > > > >
> > > > > Thanks. Do you have any performance testing results from this patch?
> > > > >
> > > > Ram Pai <linuxram@us.ibm.com> wrote:
> > > >
> > > > Andrew,
> > > > Yes the patch fixes a valid bug.
> > >
> > > Fine, but the readahead code is performance-sensitive, and it takes quite
> > > some time for any regressions to be discovered. So I'm going to need to
> > > either sit on this patch for a very long time, or extensively test it
> > > myself, or await convincing test results from someone else.
> > >
> > > Can you help with that?
> >
> > yes I will run all my standard testsuites before we take this patch.
> > (DSS workload, iozone, sysbench). I will get back with some results
> > sooon. Probably by the end of this week.
>
> Ok I have enclosed the results. The summary is: there is no significant
> improvement or decrease in performance of (DSS workload, iozone,
> sysbench) The increase or decrease is in the margin of errors.
>
> I have also enclosed a patch that partially backs off Miklos's fix.
> Shane Shrybman correctly pointed out that the real fix is to set
> ra->average value to max/2 when we move from readahead-off mode to
> readahead-on mode. The other part of Miklos's fix becomes irrelevent.
>
The patch looks fine to me.
>
> Sorry it took some time to get back on this. Its almost automated so
> turnaround time should be quick now-on-wards.
>
For these types of bugs the difference is not in the IO performance
numbers but in the processing overhead. Does it make sense to track
processor statistics (sys/user/io-wait...) during the benchmarks. So we
could say that this patch doesn't change IO performance but uses 1% less
system time?
Maybe use /usr/bin/time -v sysbench ...
> RP
Regards,
Shane
prev parent reply other threads:[~2004-08-04 19:40 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-07-18 22:30 [PATCH] fix readahead breakage for sequential after random reads Miklos Szeredi
2004-07-26 23:29 ` Andrew Morton
2004-07-26 23:56 ` Ram Pai
2004-07-27 0:08 ` Andrew Morton
2004-07-27 4:18 ` Ram Pai
2004-07-27 7:40 ` Miklos Szeredi
2004-07-27 15:34 ` Ram Pai
2004-08-04 17:38 ` Ram Pai
2004-08-04 19:39 ` Shane Shrybman [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1091648391.3486.13.camel@mars \
--to=shrybman@aei.ca \
--cc=akpm@osdl.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linuxram@us.ibm.com \
--cc=miklos@szeredi.hu \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox