Commit 29454cf6 authored by Kaixu Xia's avatar Kaixu Xia Committed by Andrew Morton

mm/damon/core: simplify the kdamond stop mechanism by removing 'done'

When the 'kdamond_wait_activation()' function or 'after_sampling()' or
'after_aggregation()' DAMON callbacks return an error, it is unnecessary
to use bool 'done' to check if kdamond should be finished.  This commit
simplifies the kdamond stop mechanism by removing 'done' and break the
while loop directly in the cases.

Link: https://lkml.kernel.org/r/1663060287-30201-4-git-send-email-kaixuxia@tencent.comSigned-off-by: default avatarKaixu Xia <kaixuxia@tencent.com>
Reviewed-by: default avatarSeongJae Park <sj@kernel.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent f1c71c28
...@@ -1152,30 +1152,25 @@ static int kdamond_fn(void *data) ...@@ -1152,30 +1152,25 @@ static int kdamond_fn(void *data)
struct damon_region *r, *next; struct damon_region *r, *next;
unsigned int max_nr_accesses = 0; unsigned int max_nr_accesses = 0;
unsigned long sz_limit = 0; unsigned long sz_limit = 0;
bool done = false;
pr_debug("kdamond (%d) starts\n", current->pid); pr_debug("kdamond (%d) starts\n", current->pid);
if (ctx->ops.init) if (ctx->ops.init)
ctx->ops.init(ctx); ctx->ops.init(ctx);
if (ctx->callback.before_start && ctx->callback.before_start(ctx)) if (ctx->callback.before_start && ctx->callback.before_start(ctx))
done = true; goto done;
sz_limit = damon_region_sz_limit(ctx); sz_limit = damon_region_sz_limit(ctx);
while (!kdamond_need_stop(ctx) && !done) { while (!kdamond_need_stop(ctx)) {
if (kdamond_wait_activation(ctx)) { if (kdamond_wait_activation(ctx))
done = true; break;
continue;
}
if (ctx->ops.prepare_access_checks) if (ctx->ops.prepare_access_checks)
ctx->ops.prepare_access_checks(ctx); ctx->ops.prepare_access_checks(ctx);
if (ctx->callback.after_sampling && if (ctx->callback.after_sampling &&
ctx->callback.after_sampling(ctx)) { ctx->callback.after_sampling(ctx))
done = true; break;
continue;
}
kdamond_usleep(ctx->attrs.sample_interval); kdamond_usleep(ctx->attrs.sample_interval);
...@@ -1187,10 +1182,8 @@ static int kdamond_fn(void *data) ...@@ -1187,10 +1182,8 @@ static int kdamond_fn(void *data)
max_nr_accesses / 10, max_nr_accesses / 10,
sz_limit); sz_limit);
if (ctx->callback.after_aggregation && if (ctx->callback.after_aggregation &&
ctx->callback.after_aggregation(ctx)) { ctx->callback.after_aggregation(ctx))
done = true; break;
continue;
}
kdamond_apply_schemes(ctx); kdamond_apply_schemes(ctx);
kdamond_reset_aggregated(ctx); kdamond_reset_aggregated(ctx);
kdamond_split_regions(ctx); kdamond_split_regions(ctx);
...@@ -1204,6 +1197,7 @@ static int kdamond_fn(void *data) ...@@ -1204,6 +1197,7 @@ static int kdamond_fn(void *data)
sz_limit = damon_region_sz_limit(ctx); sz_limit = damon_region_sz_limit(ctx);
} }
} }
done:
damon_for_each_target(t, ctx) { damon_for_each_target(t, ctx) {
damon_for_each_region_safe(r, next, t) damon_for_each_region_safe(r, next, t)
damon_destroy_region(r, t); damon_destroy_region(r, t);
......
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