Commit a62518ab authored by SeongJae Park's avatar SeongJae Park Committed by Andrew Morton

mm/damon/lru_sort: deduplicate hot/cold schemes generators

damon_lru_sort_new_{hot,cold}_scheme() have quite a lot of duplicates. 
This commit factors out the duplicate to a separate function and use it
for reducing the duplicate.

Link: https://lkml.kernel.org/r/20220913174449.50645-23-sj@kernel.orgSigned-off-by: default avatarSeongJae Park <sj@kernel.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 45b8212f
...@@ -135,6 +135,25 @@ DEFINE_DAMON_MODULES_DAMOS_STATS_PARAMS(damon_lru_sort_cold_stat, ...@@ -135,6 +135,25 @@ DEFINE_DAMON_MODULES_DAMOS_STATS_PARAMS(damon_lru_sort_cold_stat,
static struct damon_ctx *ctx; static struct damon_ctx *ctx;
static struct damon_target *target; static struct damon_target *target;
static struct damos *damon_lru_sort_new_scheme(
struct damos_access_pattern *pattern, enum damos_action action)
{
struct damos_quota quota = damon_lru_sort_quota;
/* Use half of total quota for hot/cold pages sorting */
quota.ms = quota.ms / 2;
return damon_new_scheme(
/* find the pattern, and */
pattern,
/* (de)prioritize on LRU-lists */
action,
/* under the quota. */
&quota,
/* (De)activate this according to the watermarks. */
&damon_lru_sort_wmarks);
}
/* Create a DAMON-based operation scheme for hot memory regions */ /* Create a DAMON-based operation scheme for hot memory regions */
static struct damos *damon_lru_sort_new_hot_scheme(unsigned int hot_thres) static struct damos *damon_lru_sort_new_hot_scheme(unsigned int hot_thres)
{ {
...@@ -149,19 +168,8 @@ static struct damos *damon_lru_sort_new_hot_scheme(unsigned int hot_thres) ...@@ -149,19 +168,8 @@ static struct damos *damon_lru_sort_new_hot_scheme(unsigned int hot_thres)
.min_age_region = 0, .min_age_region = 0,
.max_age_region = UINT_MAX, .max_age_region = UINT_MAX,
}; };
struct damos_quota quota = damon_lru_sort_quota;
/* Use half of total quota for hot pages sorting */
quota.ms = quota.ms / 2;
return damon_new_scheme( return damon_lru_sort_new_scheme(&pattern, DAMOS_LRU_PRIO);
&pattern,
/* prioritize those on LRU lists, as soon as found */
DAMOS_LRU_PRIO,
/* under the quota. */
&quota,
/* (De)activate this according to the watermarks. */
&damon_lru_sort_wmarks);
} }
/* Create a DAMON-based operation scheme for cold memory regions */ /* Create a DAMON-based operation scheme for cold memory regions */
...@@ -178,19 +186,8 @@ static struct damos *damon_lru_sort_new_cold_scheme(unsigned int cold_thres) ...@@ -178,19 +186,8 @@ static struct damos *damon_lru_sort_new_cold_scheme(unsigned int cold_thres)
.min_age_region = cold_thres, .min_age_region = cold_thres,
.max_age_region = UINT_MAX, .max_age_region = UINT_MAX,
}; };
struct damos_quota quota = damon_lru_sort_quota;
/* Use half of total quota for cold pages sorting */ return damon_lru_sort_new_scheme(&pattern, DAMOS_LRU_DEPRIO);
quota.ms = quota.ms / 2;
return damon_new_scheme(
&pattern,
/* mark those as not accessed, as soon as found */
DAMOS_LRU_DEPRIO,
/* under the quota. */
&quota,
/* (De)activate this according to the watermarks. */
&damon_lru_sort_wmarks);
} }
static int damon_lru_sort_apply_parameters(void) static int damon_lru_sort_apply_parameters(void)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment