The patch titled readahead: thrashing recovery method: refill holes has been added to the -mm tree. Its filename is readahead-thrashing-recovery-method-refill-holes.patch *** Remember to use Documentation/SubmitChecklist when testing your code *** See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: readahead: thrashing recovery method: refill holes From: Fengguang Wu <wfg@xxxxxxxxxxxxxxxx> When thrashing happened in the following abnormal cases: 1) the old chunk is lost; 2) random pages are lost due to unbalanced aging. There will be hole(s) in the otherwise continuous readahead pages. We recover from it by simply refilling all possible holes and turning off lookahead. These kind of abnormal situations are not expected to repeatable for the same stream. They happen in a random fashion and do not tell much about the system load. So the best thing we can do is to do nothing more than refilling the holes. If thrashing persists, it will quickly fail into the 3) case where we get the exact thrashing threshold: 3) the new chunk is thrashed. Signed-off-by: Fengguang Wu <wfg@xxxxxxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- mm/readahead.c | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff -puN mm/readahead.c~readahead-thrashing-recovery-method-refill-holes mm/readahead.c --- a/mm/readahead.c~readahead-thrashing-recovery-method-refill-holes +++ a/mm/readahead.c @@ -1552,20 +1552,23 @@ thrashing_recovery_readahead(struct addr RA_EVENT_READAHEAD_THRASHING, ra->readahead_index - offset); - if (offset < ra->ra_index) { + if (offset < ra->ra_index || unbalanced_aging) { /* - * Thrashed when we are in [la_index, ra_index), i.e. - * the old chunk is lost soon after the new one is allocated. - * Ensure that we recover all needed pages in the old chunk. - * And futher keep the lookahead_index untouched. + * 1) The old chunk is lost. + * 2) Some random pages are lost due to unbalanced zone/node aging. + * Refill the hole(s). + * Further thrashings will bring us back to case (3) below. */ - ra_size = ra->lookahead_index - offset; + ra_size = ra->readahead_index - offset; } else { - /* After thrashing, we know the exact thrashing-threshold. */ + /* + * 3) The new chunk is lost. + * It tells us about the thrashing-threshold. + */ ra_size = offset - ra->la_index; update_ra_thrash_bytes(mapping->backing_dev_info, ra_size); - /* And be cooperative: the system may be hunting for memory. */ + /* Be cooperative: the system may be hunting for memory. */ ra_size = MIN_RA_PAGES + ra_size / 2; } _ Patches currently in -mm which might be from wfg@xxxxxxxxxxxxxxxx are readahead-kconfig-options.patch radixtree-introduce-scan-hole-data-functions.patch mm-introduce-probe_page.patch mm-introduce-pg_readahead.patch readahead-add-look-ahead-support-to-__do_page_cache_readahead.patch readahead-insert-cond_resched-calls.patch readahead-minmax_ra_pages.patch readahead-events-accounting.patch readahead-rescue_pages.patch readahead-sysctl-parameters.patch readahead-min-max-sizes.patch readahead-state-based-method-aging-accounting.patch readahead-state-based-method-routines.patch readahead-state-based-method.patch readahead-state-based-method-check-node-id.patch readahead-state-based-method-decouple-readahead_ratio-from-growth_limit.patch readahead-state-based-method-cancel-lookahead-gracefully.patch readahead-context-based-method.patch readahead-initial-method-guiding-sizes.patch readahead-initial-method-thrashing-guard-size.patch readahead-initial-method-user-recommended-size.patch readahead-initial-method.patch readahead-backward-prefetching-method.patch readahead-thrashing-recovery-method.patch readahead-thrashing-recovery-method-check-unbalanced-aging.patch readahead-thrashing-recovery-method-refill-holes.patch readahead-call-scheme.patch readahead-call-scheme-cleanup.patch readahead-call-scheme-catch-thrashing-on-lookahead-time.patch readahead-laptop-mode.patch readahead-loop-case.patch readahead-nfsd-case.patch readahead-remove-parameter-ra_max-from-thrashing_recovery_readahead.patch readahead-remove-parameter-ra_max-from-adjust_rala.patch readahead-state-based-method-protect-against-tiny-size.patch readahead-rename-state_based_readahead-to-clock_based_readahead.patch readahead-account-i-o-block-times-for-stock-readahead.patch readahead-rescue_pages-updates.patch readahead-remove-noaction-shrink-events.patch readahead-remove-size-limit-on-read_ahead_kb.patch readahead-remove-size-limit-of-max_sectors_kb-on-read_ahead_kb.patch readahead-partial-sendfile-fix.patch readahead-turn-on-by-default.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html