* [PATCH 1/9] mm/damon/core: add damon_target->obsolete for pin-point removal
2025-10-23 1:25 [PATCH 0/9] mm/damon: support pin-point targets removal SeongJae Park
@ 2025-10-23 1:25 ` SeongJae Park
2025-10-23 1:25 ` [PATCH 2/9] mm/damon/sysfs: test commit input against realistic destination SeongJae Park
` (7 subsequent siblings)
8 siblings, 0 replies; 10+ messages in thread
From: SeongJae Park @ 2025-10-23 1:25 UTC (permalink / raw)
To: Andrew Morton
Cc: SeongJae Park, Bijan Tabatabai, damon, linux-kernel, linux-mm
DAMON's monitoring targets parameters update function,
damon_commit_targets(), is not providing a way to remove a target in the
middle of the existing targets list. Extend the API by adding a field
to struct damon_target. If the field of a damon_commit_targets() source
target is set, it indicates the matching target on the existing targets
list is obsolete. damon_commit_targets() understands that and removes
those from the list, while respecting the index based matching for other
non-obsolete targets.
Signed-off-by: SeongJae Park <sj@kernel.org>
Reviewed-by: Bijan Tabatabai <bijan311@gmail.com>
---
include/linux/damon.h | 6 ++++++
mm/damon/core.c | 10 +++++++++-
2 files changed, 15 insertions(+), 1 deletion(-)
diff --git a/include/linux/damon.h b/include/linux/damon.h
index 9ee026c2db53..f3566b978cdf 100644
--- a/include/linux/damon.h
+++ b/include/linux/damon.h
@@ -91,17 +91,23 @@ struct damon_region {
* @nr_regions: Number of monitoring target regions of this target.
* @regions_list: Head of the monitoring target regions of this target.
* @list: List head for siblings.
+ * @obsolete: Whether the commit destination target is obsolete.
*
* Each monitoring context could have multiple targets. For example, a context
* for virtual memory address spaces could have multiple target processes. The
* @pid should be set for appropriate &struct damon_operations including the
* virtual address spaces monitoring operations.
+ *
+ * @obsolete is used only for damon_commit_targets() source targets, to specify
+ * the matching destination targets are obsolete. Read damon_commit_targets()
+ * to see how it is handled.
*/
struct damon_target {
struct pid *pid;
unsigned int nr_regions;
struct list_head regions_list;
struct list_head list;
+ bool obsolete;
};
/**
diff --git a/mm/damon/core.c b/mm/damon/core.c
index 82546d138a5a..d78f4452e536 100644
--- a/mm/damon/core.c
+++ b/mm/damon/core.c
@@ -479,6 +479,7 @@ struct damon_target *damon_new_target(void)
t->nr_regions = 0;
INIT_LIST_HEAD(&t->regions_list);
INIT_LIST_HEAD(&t->list);
+ t->obsolete = false;
return t;
}
@@ -1187,7 +1188,11 @@ static int damon_commit_targets(
damon_for_each_target_safe(dst_target, next, dst) {
src_target = damon_nth_target(i++, src);
- if (src_target) {
+ /*
+ * If src target is obsolete, do not commit the parameters to
+ * the dst target, and further remove the dst target.
+ */
+ if (src_target && !src_target->obsolete) {
err = damon_commit_target(
dst_target, damon_target_has_pid(dst),
src_target, damon_target_has_pid(src),
@@ -1210,6 +1215,9 @@ static int damon_commit_targets(
damon_for_each_target_safe(src_target, next, src) {
if (j++ < i)
continue;
+ /* target to remove has no matching dst */
+ if (src_target->obsolete)
+ return -EINVAL;
new_target = damon_new_target();
if (!new_target)
return -ENOMEM;
--
2.47.3
^ permalink raw reply related [flat|nested] 10+ messages in thread* [PATCH 2/9] mm/damon/sysfs: test commit input against realistic destination
2025-10-23 1:25 [PATCH 0/9] mm/damon: support pin-point targets removal SeongJae Park
2025-10-23 1:25 ` [PATCH 1/9] mm/damon/core: add damon_target->obsolete for pin-point removal SeongJae Park
@ 2025-10-23 1:25 ` SeongJae Park
2025-10-23 1:25 ` [PATCH 3/9] mm/damon/sysfs: implement obsolete_target file SeongJae Park
` (6 subsequent siblings)
8 siblings, 0 replies; 10+ messages in thread
From: SeongJae Park @ 2025-10-23 1:25 UTC (permalink / raw)
To: Andrew Morton
Cc: SeongJae Park, Bijan Tabatabai, damon, linux-kernel, linux-mm
DAMON sysfs interface tests if given online parameters update request is
valid, by committing those using the DAMON kernel API, to a test-purpose
destination context. The test-purpose destination context is
constructed using damon_new_ctx(), so it has no target, no scheme.
If a source target has the obsolete field set, the test-purpose commit
will fail because damon_commit_targets() fails when there is a source
obsolete target that cannot find its matching destination target. DAMON
sysfs interface is not letting users set the field for now, so there is
no problem. However, the following commit will support that. Also
there could be similar future changes that making commit fails based on
current context structure.
Make the test purpose commit destination context similar to the current
running one, by committing the running one to the test purpose context,
before doing the real test-purpose commit.
Signed-off-by: SeongJae Park <sj@kernel.org>
Reviewed-by: Bijan Tabatabai <bijan311@gmail.com>
---
mm/damon/sysfs.c | 22 +++++++++++++++++++++-
1 file changed, 21 insertions(+), 1 deletion(-)
diff --git a/mm/damon/sysfs.c b/mm/damon/sysfs.c
index ccfb624a94b8..0fe6ea68d311 100644
--- a/mm/damon/sysfs.c
+++ b/mm/damon/sysfs.c
@@ -1451,6 +1451,26 @@ static int damon_sysfs_apply_inputs(struct damon_ctx *ctx,
static struct damon_ctx *damon_sysfs_build_ctx(
struct damon_sysfs_context *sys_ctx);
+/*
+ * Return a new damon_ctx for testing new parameters to commit.
+ */
+static struct damon_ctx *damon_sysfs_new_test_ctx(
+ struct damon_ctx *running_ctx)
+{
+ struct damon_ctx *test_ctx;
+ int err;
+
+ test_ctx = damon_new_ctx();
+ if (!test_ctx)
+ return NULL;
+ err = damon_commit_ctx(test_ctx, running_ctx);
+ if (err) {
+ damon_destroy_ctx(test_ctx);
+ return NULL;
+ }
+ return test_ctx;
+}
+
/*
* damon_sysfs_commit_input() - Commit user inputs to a running kdamond.
* @kdamond: The kobject wrapper for the associated kdamond.
@@ -1472,7 +1492,7 @@ static int damon_sysfs_commit_input(void *data)
param_ctx = damon_sysfs_build_ctx(kdamond->contexts->contexts_arr[0]);
if (IS_ERR(param_ctx))
return PTR_ERR(param_ctx);
- test_ctx = damon_new_ctx();
+ test_ctx = damon_sysfs_new_test_ctx(kdamond->damon_ctx);
if (!test_ctx)
return -ENOMEM;
err = damon_commit_ctx(test_ctx, param_ctx);
--
2.47.3
^ permalink raw reply related [flat|nested] 10+ messages in thread* [PATCH 3/9] mm/damon/sysfs: implement obsolete_target file
2025-10-23 1:25 [PATCH 0/9] mm/damon: support pin-point targets removal SeongJae Park
2025-10-23 1:25 ` [PATCH 1/9] mm/damon/core: add damon_target->obsolete for pin-point removal SeongJae Park
2025-10-23 1:25 ` [PATCH 2/9] mm/damon/sysfs: test commit input against realistic destination SeongJae Park
@ 2025-10-23 1:25 ` SeongJae Park
2025-10-23 1:25 ` [PATCH 4/9] Docs/admin-guide/mm/damon/usage: document " SeongJae Park
` (5 subsequent siblings)
8 siblings, 0 replies; 10+ messages in thread
From: SeongJae Park @ 2025-10-23 1:25 UTC (permalink / raw)
To: Andrew Morton
Cc: SeongJae Park, Bijan Tabatabai, damon, linux-kernel, linux-mm
There is no good way to remove DAMON targets in the middle of the
existing targets list. It restricts efficient and flexible DAMON use
cases. Improve the usability by implementing a new DAMON sysfs
interface file, namely obsolete_target, under each target directory. It
is connected to the obsolete field of parameters commit-source targets,
so allows removing arbitrary targets in the middle of existing targets
list.
Note that the sysfs files are not automatically updated. For example,
let's suppose there are three targets in the running context, and a user
removes the third target using this feature. If the user writes
'commit' to the kdamond 'state' file again, DAMON sysfs interface will
again try to remove the third target. But because there is no matching
target in the running context, the commit will fail. It is the user's
responsibility to understand resulting DAMON internal targets list
change, and construct sysfs files (using nr_targets and other sysfs
files) to correctly represent it.
Also note that this is arguably an improvement rather than a fix of
broken things.
Reported-by: Bijan Tabatabai <bijan311@gmail.com>
Closes: https://github.com/damonitor/damo/issues/36
Signed-off-by: SeongJae Park <sj@kernel.org>
Reviewed-by: Bijan Tabatabai <bijan311@gmail.com>
---
mm/damon/sysfs.c | 29 +++++++++++++++++++++++++++++
1 file changed, 29 insertions(+)
diff --git a/mm/damon/sysfs.c b/mm/damon/sysfs.c
index 0fe6ea68d311..43ee9ce4dd84 100644
--- a/mm/damon/sysfs.c
+++ b/mm/damon/sysfs.c
@@ -212,6 +212,7 @@ struct damon_sysfs_target {
struct kobject kobj;
struct damon_sysfs_regions *regions;
int pid;
+ bool obsolete;
};
static struct damon_sysfs_target *damon_sysfs_target_alloc(void)
@@ -263,6 +264,29 @@ static ssize_t pid_target_store(struct kobject *kobj,
return count;
}
+static ssize_t obsolete_target_show(struct kobject *kobj,
+ struct kobj_attribute *attr, char *buf)
+{
+ struct damon_sysfs_target *target = container_of(kobj,
+ struct damon_sysfs_target, kobj);
+
+ return sysfs_emit(buf, "%c\n", target->obsolete ? 'Y' : 'N');
+}
+
+static ssize_t obsolete_target_store(struct kobject *kobj,
+ struct kobj_attribute *attr, const char *buf, size_t count)
+{
+ struct damon_sysfs_target *target = container_of(kobj,
+ struct damon_sysfs_target, kobj);
+ bool obsolete;
+ int err = kstrtobool(buf, &obsolete);
+
+ if (err)
+ return err;
+ target->obsolete = obsolete;
+ return count;
+}
+
static void damon_sysfs_target_release(struct kobject *kobj)
{
kfree(container_of(kobj, struct damon_sysfs_target, kobj));
@@ -271,8 +295,12 @@ static void damon_sysfs_target_release(struct kobject *kobj)
static struct kobj_attribute damon_sysfs_target_pid_attr =
__ATTR_RW_MODE(pid_target, 0600);
+static struct kobj_attribute damon_sysfs_target_obsolete_attr =
+ __ATTR_RW_MODE(obsolete_target, 0600);
+
static struct attribute *damon_sysfs_target_attrs[] = {
&damon_sysfs_target_pid_attr.attr,
+ &damon_sysfs_target_obsolete_attr.attr,
NULL,
};
ATTRIBUTE_GROUPS(damon_sysfs_target);
@@ -1377,6 +1405,7 @@ static int damon_sysfs_add_target(struct damon_sysfs_target *sys_target,
/* caller will destroy targets */
return -EINVAL;
}
+ t->obsolete = sys_target->obsolete;
return damon_sysfs_set_regions(t, sys_target->regions, ctx->min_sz_region);
}
--
2.47.3
^ permalink raw reply related [flat|nested] 10+ messages in thread* [PATCH 4/9] Docs/admin-guide/mm/damon/usage: document obsolete_target file
2025-10-23 1:25 [PATCH 0/9] mm/damon: support pin-point targets removal SeongJae Park
` (2 preceding siblings ...)
2025-10-23 1:25 ` [PATCH 3/9] mm/damon/sysfs: implement obsolete_target file SeongJae Park
@ 2025-10-23 1:25 ` SeongJae Park
2025-10-23 1:25 ` [PATCH 5/9] Docs/ABI/damon: document obsolete_target sysfs file SeongJae Park
` (4 subsequent siblings)
8 siblings, 0 replies; 10+ messages in thread
From: SeongJae Park @ 2025-10-23 1:25 UTC (permalink / raw)
To: Andrew Morton
Cc: SeongJae Park, Liam R. Howlett, Bijan Tabatabai,
David Hildenbrand, Jonathan Corbet, Lorenzo Stoakes, Michal Hocko,
Mike Rapoport, Suren Baghdasaryan, Vlastimil Babka, damon,
linux-doc, linux-kernel, linux-mm
Document the newly added obsolete_target DAMON sysfs file.
Signed-off-by: SeongJae Park <sj@kernel.org>
Reviewed-by: Bijan Tabatabai <bijan311@gmail.com>
---
Documentation/admin-guide/mm/damon/usage.rst | 13 ++++++++++---
1 file changed, 10 insertions(+), 3 deletions(-)
diff --git a/Documentation/admin-guide/mm/damon/usage.rst b/Documentation/admin-guide/mm/damon/usage.rst
index 98958975604d..d8a3d6e740b3 100644
--- a/Documentation/admin-guide/mm/damon/usage.rst
+++ b/Documentation/admin-guide/mm/damon/usage.rst
@@ -67,7 +67,7 @@ comma (",").
│ │ │ │ │ │ │ intervals_goal/access_bp,aggrs,min_sample_us,max_sample_us
│ │ │ │ │ │ nr_regions/min,max
│ │ │ │ │ :ref:`targets <sysfs_targets>`/nr_targets
- │ │ │ │ │ │ :ref:`0 <sysfs_target>`/pid_target
+ │ │ │ │ │ │ :ref:`0 <sysfs_target>`/pid_target,obsolete_target
│ │ │ │ │ │ │ :ref:`regions <sysfs_regions>`/nr_regions
│ │ │ │ │ │ │ │ :ref:`0 <sysfs_region>`/start,end
│ │ │ │ │ │ │ │ ...
@@ -264,13 +264,20 @@ to ``N-1``. Each directory represents each monitoring target.
targets/<N>/
------------
-In each target directory, one file (``pid_target``) and one directory
-(``regions``) exist.
+In each target directory, two files (``pid_target`` and ``obsolete_target``)
+and one directory (``regions``) exist.
If you wrote ``vaddr`` to the ``contexts/<N>/operations``, each target should
be a process. You can specify the process to DAMON by writing the pid of the
process to the ``pid_target`` file.
+Users can selectively remove targets in the middle of the targets array by
+writing non-zero value to ``obsolete_target`` file and committing it (writing
+``commit`` to ``state`` file). DAMON will remove the matching targets from its
+internal targets array. Users are responsible to construct target directories
+again, so that those correctly represent the changed internal targets array.
+
+
.. _sysfs_regions:
targets/<N>/regions
--
2.47.3
^ permalink raw reply related [flat|nested] 10+ messages in thread* [PATCH 5/9] Docs/ABI/damon: document obsolete_target sysfs file
2025-10-23 1:25 [PATCH 0/9] mm/damon: support pin-point targets removal SeongJae Park
` (3 preceding siblings ...)
2025-10-23 1:25 ` [PATCH 4/9] Docs/admin-guide/mm/damon/usage: document " SeongJae Park
@ 2025-10-23 1:25 ` SeongJae Park
2025-10-23 1:25 ` [PATCH 6/9] selftests/damon/_damon_sysfs: support obsolete_target file SeongJae Park
` (3 subsequent siblings)
8 siblings, 0 replies; 10+ messages in thread
From: SeongJae Park @ 2025-10-23 1:25 UTC (permalink / raw)
To: Andrew Morton
Cc: SeongJae Park, Bijan Tabatabai, damon, linux-kernel, linux-mm
Update DAMON ABI document for the newly added obsolete_target DAMON
sysfs file.
Signed-off-by: SeongJae Park <sj@kernel.org>
Reviewed-by: Bijan Tabatabai <bijan311@gmail.com>
---
Documentation/ABI/testing/sysfs-kernel-mm-damon | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/Documentation/ABI/testing/sysfs-kernel-mm-damon b/Documentation/ABI/testing/sysfs-kernel-mm-damon
index dce6c2cda4e8..4fb8b7a6d625 100644
--- a/Documentation/ABI/testing/sysfs-kernel-mm-damon
+++ b/Documentation/ABI/testing/sysfs-kernel-mm-damon
@@ -164,6 +164,13 @@ Description: Writing to and reading from this file sets and gets the pid of
the target process if the context is for virtual address spaces
monitoring, respectively.
+What: /sys/kernel/mm/damon/admin/kdamonds/<K>/contexts/<C>/targets/<T>/obsolete_target
+Date: Oct 2025
+Contact: SeongJae Park <sj@kernel.org>
+Description: Writing to and reading from this file sets and gets the
+ obsoleteness of the matching parameters commit destination
+ target.
+
What: /sys/kernel/mm/damon/admin/kdamonds/<K>/contexts/<C>/targets/<T>/regions/nr_regions
Date: Mar 2022
Contact: SeongJae Park <sj@kernel.org>
--
2.47.3
^ permalink raw reply related [flat|nested] 10+ messages in thread* [PATCH 6/9] selftests/damon/_damon_sysfs: support obsolete_target file
2025-10-23 1:25 [PATCH 0/9] mm/damon: support pin-point targets removal SeongJae Park
` (4 preceding siblings ...)
2025-10-23 1:25 ` [PATCH 5/9] Docs/ABI/damon: document obsolete_target sysfs file SeongJae Park
@ 2025-10-23 1:25 ` SeongJae Park
2025-10-23 1:25 ` [PATCH 7/9] drgn_dump_damon_status: dump damon_target->obsolete SeongJae Park
` (2 subsequent siblings)
8 siblings, 0 replies; 10+ messages in thread
From: SeongJae Park @ 2025-10-23 1:25 UTC (permalink / raw)
To: Andrew Morton
Cc: SeongJae Park, Bijan Tabatabai, Shuah Khan, damon, linux-kernel,
linux-kselftest, linux-mm
A DAMON sysfs file, namely obsolete_target, has been newly introduced.
Add a support of that file to _damon_sysfs.py so that DAMON selftests
for the file can be easily written.
Signed-off-by: SeongJae Park <sj@kernel.org>
---
tools/testing/selftests/damon/_damon_sysfs.py | 11 +++++++++--
1 file changed, 9 insertions(+), 2 deletions(-)
diff --git a/tools/testing/selftests/damon/_damon_sysfs.py b/tools/testing/selftests/damon/_damon_sysfs.py
index a0e6290833fb..748778b563cd 100644
--- a/tools/testing/selftests/damon/_damon_sysfs.py
+++ b/tools/testing/selftests/damon/_damon_sysfs.py
@@ -475,12 +475,14 @@ class Damos:
class DamonTarget:
pid = None
+ obsolete = None
# todo: Support target regions if test is made
idx = None
context = None
- def __init__(self, pid):
+ def __init__(self, pid, obsolete=False):
self.pid = pid
+ self.obsolete = obsolete
def sysfs_dir(self):
return os.path.join(
@@ -491,8 +493,13 @@ class DamonTarget:
os.path.join(self.sysfs_dir(), 'regions', 'nr_regions'), '0')
if err is not None:
return err
- return write_file(
+ err = write_file(
os.path.join(self.sysfs_dir(), 'pid_target'), self.pid)
+ if err is not None:
+ return err
+ return write_file(
+ os.path.join(self.sysfs_dir(), 'obsolete_target'),
+ 'Y' if self.obsolete else 'N')
class IntervalsGoal:
access_bp = None
--
2.47.3
^ permalink raw reply related [flat|nested] 10+ messages in thread* [PATCH 7/9] drgn_dump_damon_status: dump damon_target->obsolete
2025-10-23 1:25 [PATCH 0/9] mm/damon: support pin-point targets removal SeongJae Park
` (5 preceding siblings ...)
2025-10-23 1:25 ` [PATCH 6/9] selftests/damon/_damon_sysfs: support obsolete_target file SeongJae Park
@ 2025-10-23 1:25 ` SeongJae Park
2025-10-23 1:25 ` [PATCH 8/9] sysfs.py: extend assert_ctx_committed() for monitoring targets SeongJae Park
2025-10-23 1:25 ` [PATCH 9/9] selftests/damon/sysfs: add obsolete_target test SeongJae Park
8 siblings, 0 replies; 10+ messages in thread
From: SeongJae Park @ 2025-10-23 1:25 UTC (permalink / raw)
To: Andrew Morton
Cc: SeongJae Park, Bijan Tabatabai, Shuah Khan, damon, linux-kernel,
linux-kselftest, linux-mm
A new field of damon_target for pin-point target removal, namely
obsolete, has newly been added. Extend drgn_dump_damon_status.py to
dump it, for easily writing a future DAMON selftests of it.
Signed-off-by: SeongJae Park <sj@kernel.org>
---
tools/testing/selftests/damon/drgn_dump_damon_status.py | 1 +
1 file changed, 1 insertion(+)
diff --git a/tools/testing/selftests/damon/drgn_dump_damon_status.py b/tools/testing/selftests/damon/drgn_dump_damon_status.py
index 7233369a3a44..cb4fdbe68acb 100755
--- a/tools/testing/selftests/damon/drgn_dump_damon_status.py
+++ b/tools/testing/selftests/damon/drgn_dump_damon_status.py
@@ -73,6 +73,7 @@ def target_to_dict(target):
['pid', int],
['nr_regions', int],
['regions_list', regions_to_list],
+ ['obsolete', bool],
])
def targets_to_list(targets):
--
2.47.3
^ permalink raw reply related [flat|nested] 10+ messages in thread* [PATCH 8/9] sysfs.py: extend assert_ctx_committed() for monitoring targets
2025-10-23 1:25 [PATCH 0/9] mm/damon: support pin-point targets removal SeongJae Park
` (6 preceding siblings ...)
2025-10-23 1:25 ` [PATCH 7/9] drgn_dump_damon_status: dump damon_target->obsolete SeongJae Park
@ 2025-10-23 1:25 ` SeongJae Park
2025-10-23 1:25 ` [PATCH 9/9] selftests/damon/sysfs: add obsolete_target test SeongJae Park
8 siblings, 0 replies; 10+ messages in thread
From: SeongJae Park @ 2025-10-23 1:25 UTC (permalink / raw)
To: Andrew Morton
Cc: SeongJae Park, Bijan Tabatabai, Shuah Khan, damon, linux-kernel,
linux-kselftest, linux-mm
assert_ctx_committed() is not asserting monitoring targets commitment,
since all existing callers of the function assume no target changes.
Extend it for future usage.
Signed-off-by: SeongJae Park <sj@kernel.org>
---
tools/testing/selftests/damon/sysfs.py | 11 +++++++++++
1 file changed, 11 insertions(+)
diff --git a/tools/testing/selftests/damon/sysfs.py b/tools/testing/selftests/damon/sysfs.py
index 2666c6f0f1a5..fd8d3698326e 100755
--- a/tools/testing/selftests/damon/sysfs.py
+++ b/tools/testing/selftests/damon/sysfs.py
@@ -164,6 +164,16 @@ def assert_monitoring_attrs_committed(attrs, dump):
assert_true(dump['max_nr_regions'] == attrs.max_nr_regions,
'max_nr_regions', dump)
+def assert_monitoring_target_committed(target, dump):
+ # target.pid is the pid "number", while dump['pid'] is 'struct pid'
+ # pointer, and hence cannot be compared.
+ assert_true(dump['obsolete'] == target.obsolete, 'target obsolete', dump)
+
+def assert_monitoring_targets_committed(targets, dump):
+ assert_true(len(targets) == len(dump), 'len_targets', dump)
+ for idx, target in enumerate(targets):
+ assert_monitoring_target_committed(target, dump[idx])
+
def assert_ctx_committed(ctx, dump):
ops_val = {
'vaddr': 0,
@@ -172,6 +182,7 @@ def assert_ctx_committed(ctx, dump):
}
assert_true(dump['ops']['id'] == ops_val[ctx.ops], 'ops_id', dump)
assert_monitoring_attrs_committed(ctx.monitoring_attrs, dump['attrs'])
+ assert_monitoring_targets_committed(ctx.targets, dump['adaptive_targets'])
assert_schemes_committed(ctx.schemes, dump['schemes'])
def assert_ctxs_committed(ctxs, dump):
--
2.47.3
^ permalink raw reply related [flat|nested] 10+ messages in thread* [PATCH 9/9] selftests/damon/sysfs: add obsolete_target test
2025-10-23 1:25 [PATCH 0/9] mm/damon: support pin-point targets removal SeongJae Park
` (7 preceding siblings ...)
2025-10-23 1:25 ` [PATCH 8/9] sysfs.py: extend assert_ctx_committed() for monitoring targets SeongJae Park
@ 2025-10-23 1:25 ` SeongJae Park
8 siblings, 0 replies; 10+ messages in thread
From: SeongJae Park @ 2025-10-23 1:25 UTC (permalink / raw)
To: Andrew Morton
Cc: SeongJae Park, Bijan Tabatabai, Shuah Khan, damon, linux-kernel,
linux-kselftest, linux-mm
A new DAMON sysfs file for pin-point target removal, namely
obsolete_target, has been added. Add a test for the functionality. It
starts DAMON with three monitoring target processes, mark one in the
middle as obsolete, commit it, and confirm the internal DAMON status is
updated to remove the target in the middle.
Signed-off-by: SeongJae Park <sj@kernel.org>
---
tools/testing/selftests/damon/sysfs.py | 37 ++++++++++++++++++++++++++
1 file changed, 37 insertions(+)
diff --git a/tools/testing/selftests/damon/sysfs.py b/tools/testing/selftests/damon/sysfs.py
index fd8d3698326e..b34aea0a6775 100755
--- a/tools/testing/selftests/damon/sysfs.py
+++ b/tools/testing/selftests/damon/sysfs.py
@@ -279,5 +279,42 @@ def main():
kdamonds.stop()
+ # test obsolete_target.
+ proc1 = subprocess.Popen(['sh'], stdout=subprocess.PIPE,
+ stderr=subprocess.PIPE)
+ proc2 = subprocess.Popen(['sh'], stdout=subprocess.PIPE,
+ stderr=subprocess.PIPE)
+ proc3 = subprocess.Popen(['sh'], stdout=subprocess.PIPE,
+ stderr=subprocess.PIPE)
+ kdamonds = _damon_sysfs.Kdamonds(
+ [_damon_sysfs.Kdamond(
+ contexts=[_damon_sysfs.DamonCtx(
+ ops='vaddr',
+ targets=[
+ _damon_sysfs.DamonTarget(pid=proc1.pid),
+ _damon_sysfs.DamonTarget(pid=proc2.pid),
+ _damon_sysfs.DamonTarget(pid=proc3.pid),
+ ],
+ schemes=[_damon_sysfs.Damos()],
+ )])])
+ err = kdamonds.start()
+ if err is not None:
+ print('kdamond start failed: %s' % err)
+ exit(1)
+ kdamonds.kdamonds[0].contexts[0].targets[1].obsolete = True
+ kdamonds.kdamonds[0].commit()
+
+ status, err = dump_damon_status_dict(kdamonds.kdamonds[0].pid)
+ if err is not None:
+ print(err)
+ kdamonds.stop()
+ exit(1)
+
+ del kdamonds.kdamonds[0].contexts[0].targets[1]
+
+ assert_ctxs_committed(kdamonds.kdamonds[0].contexts, status['contexts'])
+
+ kdamonds.stop()
+
if __name__ == '__main__':
main()
--
2.47.3
^ permalink raw reply related [flat|nested] 10+ messages in thread