From: Wu Fengguang <wfg@mail.ustc.edu.cn>
To: Andrew Morton <akpm@osdl.org>
Cc: linux-kernel@vger.kernel.org, Wu Fengguang <wfg@mail.ustc.edu.cn>
Subject: [PATCH 16/28] readahead: initial method - guiding sizes
Date: Wed, 15 Nov 2006 15:50:23 +0800 [thread overview]
Message-ID: <363577026.23099@ustc.edu.cn> (raw)
Message-ID: <20061115075029.519507130@localhost.localdomain> (raw)
In-Reply-To: 20061115075007.832957580@localhost.localdomain
[-- Attachment #1: readahead-initial-method-guiding-sizes.patch --]
[-- Type: text/plain, Size: 2509 bytes --]
Introduce three guiding sizes for the initial readahead method.
- ra_pages0: min readahead on start-of-file
- ra_thrash_bytes: estimated thrashing threshold
ra_thrash_bytes defaults to large value:
- most systems don't have the danger of thrashing
- it increases slowly and drops rapidly
Signed-off-by: Wu Fengguang <wfg@mail.ustc.edu.cn>
Signed-off-by: Andrew Morton <akpm@osdl.org>
--- linux-2.6.19-rc5-mm2.orig/include/linux/backing-dev.h
+++ linux-2.6.19-rc5-mm2/include/linux/backing-dev.h
@@ -26,6 +26,8 @@ typedef int (congested_fn)(void *, int);
struct backing_dev_info {
unsigned long ra_pages; /* max readahead in PAGE_CACHE_SIZE units */
+ unsigned long ra_pages0; /* min readahead on start of file */
+ unsigned long ra_thrash_bytes; /* estimated thrashing threshold */
unsigned long state; /* Always use atomic bitops on this */
unsigned int capabilities; /* Device capabilities */
congested_fn *congested_fn; /* Function pointer if device is md/dm */
--- linux-2.6.19-rc5-mm2.orig/mm/readahead.c
+++ linux-2.6.19-rc5-mm2/mm/readahead.c
@@ -32,6 +32,9 @@
* Adaptive read-ahead parameters.
*/
+/* Default initial read-ahead size. */
+#define INITIAL_RA_PAGES DIV_ROUND_UP(64*1024, PAGE_CACHE_SIZE)
+
/* In laptop mode, poll delayed look-ahead on every ## pages read. */
#define LAPTOP_POLL_INTERVAL 16
@@ -114,6 +117,8 @@ EXPORT_SYMBOL(default_unplug_io_fn);
struct backing_dev_info default_backing_dev_info = {
.ra_pages = MAX_RA_PAGES,
+ .ra_pages0 = INITIAL_RA_PAGES,
+ .ra_thrash_bytes = MAX_RA_PAGES * PAGE_CACHE_SIZE,
.state = 0,
.capabilities = BDI_CAP_MAP_COPY,
.unplug_io_fn = default_unplug_io_fn,
--- linux-2.6.19-rc5-mm2.orig/block/ll_rw_blk.c
+++ linux-2.6.19-rc5-mm2/block/ll_rw_blk.c
@@ -214,9 +214,6 @@ void blk_queue_make_request(request_queu
blk_queue_max_phys_segments(q, MAX_PHYS_SEGMENTS);
blk_queue_max_hw_segments(q, MAX_HW_SEGMENTS);
q->make_request_fn = mfn;
- q->backing_dev_info.ra_pages = (VM_MAX_READAHEAD * 1024) / PAGE_CACHE_SIZE;
- q->backing_dev_info.state = 0;
- q->backing_dev_info.capabilities = BDI_CAP_MAP_COPY;
blk_queue_max_sectors(q, SAFE_MAX_SECTORS);
blk_queue_hardsect_size(q, 512);
blk_queue_dma_alignment(q, 511);
@@ -1848,6 +1845,7 @@ request_queue_t *blk_alloc_queue_node(gf
q->kobj.ktype = &queue_ktype;
kobject_init(&q->kobj);
+ q->backing_dev_info = default_backing_dev_info;
q->backing_dev_info.unplug_io_fn = blk_backing_dev_unplug;
q->backing_dev_info.unplug_io_data = q;
--
next prev parent reply other threads:[~2006-11-15 7:53 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20061115075007.832957580@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 00/28] Adaptive readahead V16 Wu Fengguang
[not found] ` <20061115075024.180138257@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 01/28] readahead: kconfig options Wu Fengguang
[not found] ` <20061115075024.503627543@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 02/28] radixtree: introduce scan hole/data functions Wu Fengguang
[not found] ` <20061115075024.850542829@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 03/28] mm: introduce probe_page() Wu Fengguang
[not found] ` <20061115075025.438524224@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 04/28] mm: introduce PG_readahead Wu Fengguang
[not found] ` <20061115075026.121499794@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 06/28] readahead: insert cond_resched() calls Wu Fengguang
[not found] ` <20061115075027.139255636@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 09/28] readahead: rescue_pages() Wu Fengguang
[not found] ` <20061115075027.832896629@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 11/28] readahead: min/max sizes Wu Fengguang
[not found] ` <20061115075028.178039166@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 12/28] readahead: state based method - aging accounting Wu Fengguang
2006-11-15 16:54 ` Christoph Lameter
[not found] ` <20061116133919.GA6645@mail.ustc.edu.cn>
2006-11-16 13:39 ` Wu Fengguang
[not found] ` <20061115075028.494374406@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 13/28] readahead: state based method - routines Wu Fengguang
[not found] ` <20061115075028.829507795@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 14/28] readahead: state based method Wu Fengguang
[not found] ` <20061115075029.205178794@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 15/28] readahead: context " Wu Fengguang
[not found] ` <20061115075029.519507130@localhost.localdomain>
2006-11-15 7:50 ` Wu Fengguang [this message]
[not found] ` <20061115075029.869472273@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 17/28] readahead: initial method - thrashing guard size Wu Fengguang
[not found] ` <20061115075030.229339867@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 18/28] readahead: initial method - user recommended size Wu Fengguang
[not found] ` <20061115075030.942942737@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 20/28] readahead: backward prefetching method Wu Fengguang
[not found] ` <20061115075031.286178806@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 21/28] readahead: thrashing recovery method Wu Fengguang
[not found] ` <20061115075031.524129110@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 22/28] readahead: call scheme Wu Fengguang
[not found] ` <20061115075031.909090639@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 23/28] readahead: laptop mode Wu Fengguang
[not found] ` <20061115075032.213167260@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 24/28] readahead: loop case Wu Fengguang
[not found] ` <20061115075032.515501374@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 25/28] readahead: nfsd case Wu Fengguang
[not found] ` <20061115075032.945192537@localhost.localdomain>
2006-11-15 7:50 ` [PATCH 26/28] readahead: turn on by default Wu Fengguang
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=363577026.23099@ustc.edu.cn \
--to=wfg@mail.ustc.edu.cn \
--cc=akpm@osdl.org \
--cc=linux-kernel@vger.kernel.org \
/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