]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
mm/damon/paddr: support ops_filters
authorSeongJae Park <sj@kernel.org>
Tue, 4 Mar 2025 21:19:06 +0000 (13:19 -0800)
committerAndrew Morton <akpm@linux-foundation.org>
Mon, 17 Mar 2025 07:05:38 +0000 (00:05 -0700)
DAMON keeps all DAMOS filters in damos->filters.  Upcoming changes will
make it to use damos->ops_filters for all operations layer handled DAMOS
filters, though.  DAMON physical address space operations set
implementation (paddr) is not ready for the changes, since it handles only
damos->filters.  To avoid any breakage during the upcoming changes, make
paddr to handle both lists.  After the change is made, ->filters support
on paddr can be safely removed.

Link: https://lkml.kernel.org/r/20250304211913.53574-3-sj@kernel.org
Signed-off-by: SeongJae Park <sj@kernel.org>
Cc: Jonathan Corbet <corbet@lwn.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
mm/damon/paddr.c

index d5db313ca717f5a6987734c50efd807e67b6937b..2b1ea568a4311c43d61aba29d3cc7445bf3ca540 100644 (file)
@@ -260,6 +260,10 @@ static bool damos_pa_filter_out(struct damos *scheme, struct folio *folio)
                if (damos_pa_filter_match(filter, folio))
                        return !filter->allow;
        }
+       damos_for_each_ops_filter(filter, scheme) {
+               if (damos_pa_filter_match(filter, folio))
+                       return !filter->allow;
+       }
        return false;
 }
 
@@ -290,6 +294,12 @@ static unsigned long damon_pa_pageout(struct damon_region *r, struct damos *s,
                        break;
                }
        }
+       damos_for_each_ops_filter(filter, s) {
+               if (filter->type == DAMOS_FILTER_TYPE_YOUNG) {
+                       install_young_filter = false;
+                       break;
+               }
+       }
        if (install_young_filter) {
                filter = damos_new_filter(
                                DAMOS_FILTER_TYPE_YOUNG, true, false);
@@ -538,6 +548,8 @@ static bool damon_pa_scheme_has_filter(struct damos *s)
 
        damos_for_each_filter(f, s)
                return true;
+       damos_for_each_ops_filter(f, s)
+               return true;
        return false;
 }