]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
mm/damon/core: avoid destroyed target reference from DAMOS quota
authorAkinobu Mita <akinobu.mita@gmail.com>
Sat, 17 May 2025 14:18:52 +0000 (23:18 +0900)
committerAndrew Morton <akpm@linux-foundation.org>
Sun, 1 Jun 2025 05:46:09 +0000 (22:46 -0700)
When the number of the monitoring targets in running contexts is reduced,
there may be DAMOS quotas referencing the targets that will be destroyed.

Applying the scheme action for such DAMOS scheme will be skipped forever
looking for the starting part of the region for the destroyed monitoring
target.

To fix this issue, when the monitoring target is destroyed, reset the
starting part for all DAMOS quotas that reference the target.

Link: https://lkml.kernel.org/r/20250517141852.142802-1-akinobu.mita@gmail.com
Fixes: da87878010e5 ("mm/damon/sysfs: support online inputs update")
Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
Reviewed-by: SeongJae Park <sj@kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
mm/damon/core.c

index 0bb71e2ab713138ba35aef1164fc02cb80c88230..b217e0120e09e1c2e44862ae765aa59a7ff2d2d6 100644 (file)
@@ -1093,9 +1093,17 @@ static int damon_commit_targets(
                        if (err)
                                return err;
                } else {
+                       struct damos *s;
+
                        if (damon_target_has_pid(dst))
                                put_pid(dst_target->pid);
                        damon_destroy_target(dst_target);
+                       damon_for_each_scheme(s, dst) {
+                               if (s->quota.charge_target_from == dst_target) {
+                                       s->quota.charge_target_from = NULL;
+                                       s->quota.charge_addr_from = 0;
+                               }
+                       }
                }
        }