From patchwork Tue Mar 4 21:19:05 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: SeongJae Park X-Patchwork-Id: 14001423 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 85B1AC282D0 for ; Tue, 4 Mar 2025 21:19:21 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 1A25C6B0085; Tue, 4 Mar 2025 16:19:21 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 12BEB6B0088; Tue, 4 Mar 2025 16:19:21 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id EE6D46B0092; Tue, 4 Mar 2025 16:19:20 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0010.hostedemail.com [216.40.44.10]) by kanga.kvack.org (Postfix) with ESMTP id C5DF86B0085 for ; Tue, 4 Mar 2025 16:19:20 -0500 (EST) Received: from smtpin07.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay04.hostedemail.com (Postfix) with ESMTP id 78FC91A0601 for ; Tue, 4 Mar 2025 21:19:20 +0000 (UTC) X-FDA: 83185134480.07.C5E321A Received: from nyc.source.kernel.org (nyc.source.kernel.org [147.75.193.91]) by imf29.hostedemail.com (Postfix) with ESMTP id D97C6120003 for ; Tue, 4 Mar 2025 21:19:18 +0000 (UTC) Authentication-Results: imf29.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=dPOgLZev; spf=pass (imf29.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741123158; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=rlqU+kqW9ukYbDzlv4i2J5UucOp6MMEB0oVQStqLbnU=; b=a9FeoI9lY9KwmMoED7GQo/PFWnrBMkzM8Q1wvp2ptOeBL3On8BirQKRmkqv/zVCxnzIBU2 yCct/EWoQWyUaXv3fOt1iVz5QjSqg2IlcNYOdQnTHzmVt0FZPcKD+2tL2BooQkHTvJBXWd +c5Ld3/2OJlxjSTefNnlCTuvPtPYd8g= ARC-Authentication-Results: i=1; imf29.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=dPOgLZev; spf=pass (imf29.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741123158; a=rsa-sha256; cv=none; b=51jV5aPYBLit0uN8okYxGtAObFGlBWazOF+TXFoCQzr6jyaKp3ZTi2ARv6+i9moDIzXSGt GBxa2dP1MksdVaFehbB1zHnA4I09bOurQmbXOzccrCS0ArNJf3KOUaHA8A5UuHJYEhWD3i spBIPWOtO5s2jNcxC+i4d8iu9FQdclA= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by nyc.source.kernel.org (Postfix) with ESMTP id 7F217A45F87; Tue, 4 Mar 2025 21:13:47 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id C948EC4CEE5; Tue, 4 Mar 2025 21:19:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741123158; bh=1+GLBKsLzSxJFQ7DWFpnQ3RNIvFxJfA/ezMRoeI16Y8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=dPOgLZevkRvv7BLRFMCqBUuVRZGPlsN3CRS72TzgxGKYe0HfDe6lxR8n2UmyNc768 JGMTJ5QSmwvaJDLrkIK1Wo8y0357xd7Y+GaxxDa6dcrtti3tJcE3bO98fw57l4VpQU eMzvTQMcgCr3stTR9Lj3KufTiP3onmpvw4Ra9zpe7FsKOisvmvwVcoW/b3Z8KNXG3s Pu1yLZj6amxGpf/SryrRWQlM31f6MPN60U9DC+zNLLBhj0i4iCSEfHzJDuts7HqMDp X+/+NUomBDp5hzyCriU0l0T7KjDX6siT8E2FF2n3KIWwK0Ru5GI8OZrGn6sOsdV8Qf PkVpilH0sKigQ== From: SeongJae Park To: Andrew Morton Cc: SeongJae Park , damon@lists.linux.dev, kernel-team@meta.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 1/9] mm/damon/core: introduce damos->ops_filters Date: Tue, 4 Mar 2025 13:19:05 -0800 Message-Id: <20250304211913.53574-2-sj@kernel.org> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250304211913.53574-1-sj@kernel.org> References: <20250304211913.53574-1-sj@kernel.org> MIME-Version: 1.0 X-Rspam-User: X-Rspamd-Server: rspam10 X-Rspamd-Queue-Id: D97C6120003 X-Stat-Signature: monpcckbtiidifqekqcoggtr8eo7w1m4 X-HE-Tag: 1741123158-9979 X-HE-Meta: U2FsdGVkX1/6A4s2n+Q0GLJ8X+1XKVJjDqGrPN90CuvSWOorJndhDiFnxcLQcY/rRddeqasrSGQcEJ38XPBNNdNS7PHmXhJHeDw+aCME929HMPMlpS1vWWWDTYAtjM1+dXTkS9TA6/LtTgFVIEiX5pMmP9duyFrONznvHwCkGOaXbqKP/ELYmM4eo8yEo0MzI2DRk/bR2FHG7+c4QFwoWkXq6bZ/YloScUjZPS68sotba2V0mpzCUtVgkJ1XrVus04BNgeMJpNX2xofT1R7k11jLqL4QPgw0ALVnjOARCLW++930tTsZmK4+sbDA+8C7pxvvTWBIiekIBIaLy0dmR/KWd0vCgtdflziy2mnN+bSnzewMHGDpo7E23iKwhF8t0+owVSdSF5JUVRaoIFUGEyKAhidebFA30/LhgJilZILzLbrdgyxtPKu9NNc1KTUTZzpJiXapb4Tpymgd6e7H+JQvCtQdxLKPtRpBjQE0/3V2MQIqtLuB73TpiWBCSnkCwhjzpvpigH8mVa/vSvVMB5CECFeCD7n9Qzmekyf7v/DQEiJH3UYhMbbkLUrsaOL8zyx1a7eemYeoi57V39M+KOjp65x9dIszbO+KTomyF8aQQREMRa5grOpdWyu1da1BQoTD+XdGZemVp6pQnJUw34vLTdDWG4fq7I/bcv9AKQlvTNe7b6jSSa/OyBvbdsmnhNPRJzOxjPb6pU8mbaYSjBdsl7CQhXw0DhMxPWnm2EbYBswILtvX9ueG/WqArGuLMpU0+OaDfx02irpVqMAPLJ26XIhWXlVca28qUt76gtplg4zocXBYUbKCYolHXuMUfEWpsdP/LqhC3B/T1CjtOJ4q/nb+r5zTaomiW+ORAW4/BuxSnF7Czd0yTPOb/KXJA7uf1iqVELRBCcPCEilZGdcNwf+m+m6eXJPTYV+1yFJPxMBV1JkR06BiM83EhOljd1J+CYg8Zn2fXYCxCNq nOfFMHio EPDj0c/oMSaCUZAaZpuo+HgaCceFslZ8bvNx+rQOhDFrNJ7stdT7cYlk+ZbKp8Mwus44f5MmInldlJhieSo93i1YeyA6ivPNrN5FDCPfKzMcLrqvzVADy0ioQDWpPhrBF3dbPJUgc3BWMJ0vW3lA+4s/h1TR3Z0dwQzmjKxaj/Sjv15yMXEC9CVoUryy+ZCizKfQB3SHzA10u+TXGrlD7YRvffmQrUuB8VnYACr26eWxVdipmeFBkPZKInBML5ZHKFZ+vLrMYVoT4m78VjzmRy+f9Rg== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: DAMOS filters can be categorized into two groups depending on which layer they are handled, namely core layer and ops layer. The groups are important because the filtering behavior depends on evaluation sequence of filters, and core layer-handled filters are evaluated before operations layer-handled ones. The behavior is clearly documented, but the implementation is bit inefficient and complicated. All filters are maintained in a single list (damos->filters) in mix. Filters evaluation logics in core layer and operations layer iterates all the filters on the list, while skipping filters that should be not handled by the layer of the logic. It is inefficient. Making future extensions having differentiations for filters of different handling layers will also be complicated. Add a new list that will be used for having all operations layer-handled DAMOS filters to DAMOS scheme data structure. Also add the support of its initialization and basic traversal functions. Signed-off-by: SeongJae Park --- include/linux/damon.h | 8 ++++++++ mm/damon/core.c | 1 + 2 files changed, 9 insertions(+) diff --git a/include/linux/damon.h b/include/linux/damon.h index b3e2c793c1f4..7f76e2e99f37 100644 --- a/include/linux/damon.h +++ b/include/linux/damon.h @@ -448,6 +448,7 @@ struct damos_access_pattern { * @wmarks: Watermarks for automated (in)activation of this scheme. * @target_nid: Destination node if @action is "migrate_{hot,cold}". * @filters: Additional set of &struct damos_filter for &action. + * @ops_filters: ops layer handling &struct damos_filter objects list. * @last_applied: Last @action applied ops-managing entity. * @stat: Statistics of this scheme. * @list: List head for siblings. @@ -508,6 +509,7 @@ struct damos { int target_nid; }; struct list_head filters; + struct list_head ops_filters; void *last_applied; struct damos_stat stat; struct list_head list; @@ -858,6 +860,12 @@ static inline unsigned long damon_sz_region(struct damon_region *r) #define damos_for_each_filter_safe(f, next, scheme) \ list_for_each_entry_safe(f, next, &(scheme)->filters, list) +#define damos_for_each_ops_filter(f, scheme) \ + list_for_each_entry(f, &(scheme)->ops_filters, list) + +#define damos_for_each_ops_filter_safe(f, next, scheme) \ + list_for_each_entry_safe(f, next, &(scheme)->ops_filters, list) + #ifdef CONFIG_DAMON struct damon_region *damon_new_region(unsigned long start, unsigned long end); diff --git a/mm/damon/core.c b/mm/damon/core.c index 9d37d3664030..5415b7603d01 100644 --- a/mm/damon/core.c +++ b/mm/damon/core.c @@ -375,6 +375,7 @@ struct damos *damon_new_scheme(struct damos_access_pattern *pattern, scheme->next_apply_sis = 0; scheme->walk_completed = false; INIT_LIST_HEAD(&scheme->filters); + INIT_LIST_HEAD(&scheme->ops_filters); scheme->stat = (struct damos_stat){}; INIT_LIST_HEAD(&scheme->list); From patchwork Tue Mar 4 21:19:06 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: SeongJae Park X-Patchwork-Id: 14001424 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 0EF24C021B8 for ; Tue, 4 Mar 2025 21:19:24 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 0E2146B0088; Tue, 4 Mar 2025 16:19:22 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 03FD56B0093; Tue, 4 Mar 2025 16:19:21 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id DFE656B0095; Tue, 4 Mar 2025 16:19:21 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0013.hostedemail.com [216.40.44.13]) by kanga.kvack.org (Postfix) with ESMTP id B45036B0088 for ; Tue, 4 Mar 2025 16:19:21 -0500 (EST) Received: from smtpin14.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay06.hostedemail.com (Postfix) with ESMTP id 6E9ABAEA81 for ; Tue, 4 Mar 2025 21:19:21 +0000 (UTC) X-FDA: 83185134522.14.C9C6312 Received: from nyc.source.kernel.org (nyc.source.kernel.org [147.75.193.91]) by imf01.hostedemail.com (Postfix) with ESMTP id D9D0D4000F for ; Tue, 4 Mar 2025 21:19:19 +0000 (UTC) Authentication-Results: imf01.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=iCRgqwvI; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf01.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741123159; a=rsa-sha256; cv=none; b=Bej39kWZKabvUHvrWnQEbaTnRzDH/9ptzia5CyX9hGXjC6N1hdcg8kj6dulS66d09dIlQy WkwmzTpFRkzMtkEAKgqiKEqEy55l4SvSaRmpmBs6VuJix6wGcns8SK2X6e0iwX7edCuCPo jXtFddKwD17ycnT5xMldscUSfo+SLoQ= ARC-Authentication-Results: i=1; imf01.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=iCRgqwvI; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf01.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741123159; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=IeByixmRSb3y2v7/ptL/xsMh7ZQdYsERhAyiE3AugxY=; b=BTFHoapv8YU6A2HAiSXku2mRVdI8yXQKuBNqwFcLj1MQBfVKsBVRzI7PwLIj/u4fC6gYPa T/LI5laR5EXD3Ctr1jmmwktdUINY+zPQTWFxzA76loe/fH9Pn+9U9w2tC7EKHbCEvGKwT7 BLxQcRv3Ye3F5eysq3x0N6y21IDbah8= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by nyc.source.kernel.org (Postfix) with ESMTP id 70D02A45F86; Tue, 4 Mar 2025 21:13:48 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id E55E1C4CEE9; Tue, 4 Mar 2025 21:19:18 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741123159; bh=npc/D62/iA9M79tii02t66kR94TtHspqQy52dl64bMM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=iCRgqwvIepxKyJkApXpQpFtf9uNM7OzhQLJgmaj98xMr1qkhcgYsDa+nnCpkbHJiL J3wxit9ZLErX8nYSh8Wwjfvs4E+Z9S6eu63CgACgOSlaKeoYIopwExJN/2j8EKQP9v Ur3T/foL5tPNO8J6X5Q725XhMzg1/PBGUrQLeRkpf0VT8LVQCKG+6R648hFubunCOG SDXTaTCGm1Rg9CK8GFoM6PC8L6vXsQY8DKtLOrh88On4GYwkHfpObVbelT7w0REU6i N1XXUaEQ/FdPBpUY3GU1NOuYyKZ0XB+PXtROZKtWEQEhSEI1yG+oSI4Csceux57neB bqjkubU1JzYSg== From: SeongJae Park To: Andrew Morton Cc: SeongJae Park , damon@lists.linux.dev, kernel-team@meta.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 2/9] mm/damon/paddr: support ops_filters Date: Tue, 4 Mar 2025 13:19:06 -0800 Message-Id: <20250304211913.53574-3-sj@kernel.org> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250304211913.53574-1-sj@kernel.org> References: <20250304211913.53574-1-sj@kernel.org> MIME-Version: 1.0 X-Rspam-User: X-Rspamd-Server: rspam03 X-Rspamd-Queue-Id: D9D0D4000F X-Stat-Signature: bdrwmk3peyw5ooxzxp57mm57cmuqhec9 X-HE-Tag: 1741123159-817146 X-HE-Meta: U2FsdGVkX18N93Wn2nNYBmLCZhLNjw+HYuQZhDieOjiAJL8xZozlEouZQwN/FY8YB1hmJMyH1Ew/7MGmXkaoVlWoDQphA3JvCP1ifsuSMXl6ee3iHxMMcn9Z8DGZEe5QF7O5jQ8wHLZIE63Wr+5pIidkchEm1me5IUB9iScQJeCfyeAyK5KrUZGJcLbTOmE0ggPTvyQQfc3iBzQ293P3pQHDOW1v+va//CUA+4uV5WN83oxjCa+o/Wvz8XjFB/hfxYY+ORa0ZvMfjcMqDKpHEL+rfMwyVe2QJrqHAd6RCyewwoZisVTkzaGSNOwzEZXBDFwvrdwrStjX0wXdBONm2pa15sj2fHNJIyg8SXfaEiw0I/4RWulEPU3qea6D7qvLVZ95ZmVGFP203EvQADQQOsH+94e8XEcoNsKnMzvi57/YoI5LfEl/2Dz/o4W1t3QSMj+ma9M8L+kQXjnlHEDJ3ilEAfWRQrAvdlRrNtukpr51nRR3avUZ29LCXFBqu3iDx4Rld3rXzabzn4lgYyoslV1YiItoEv5Jm7EwIMsofgEB4YsfsWEg+iJjzDp/BmDtQWYAd47cIhBqBHVrJxEkoiQSdamjSMCIjY4q0/1OB/+v05aenBfLXWmQPIUq7bFFL1XaJAuozoEPbSpK084i6KLkneMZD1udHnm3eOjDgbhHcU5aotaigzkhZ//tRc68KrsCz8z763IlyHvza7gjc3h7McXsvHCamol4tsVMyyt0l2icW2qVXP26/eURgjbITe1E0Om5b2MRXOXtKbHeCRilq1s0ITyeOs+drAuzprwnAObE8JiJWARyIz0D67+s/2XQ5WQ6/b66yTzl5Bb4Q4HEr/BDltLGshyA1R0gzaakPiiWyw7ll0XvVSKqLe5h7Vza3ysIw+i+da+VWjlsxehujV/glO1gqL8aia5p6Zb+ipXTKZPqykYiISWjmBG0IpIOcyXLxDVMJyPx3qz +xvmuRi4 D4nFcC1iVLA1KHg0vATHxRsN0kpkyoXBE4JGW8Ww0N114uu4tDOfSzbz+OJA8rd8GGlOaOTtaGcvMdbgitESkkXZmPrjiFsoxwG6VnL0nfjMKPj4/wVFsVHaKdpIiN98oi69Gg+CYDAanpSGPqXtNu5XDUHNbgE/ymUtnzEhOuxDVDycOQOYz1ujF3snsuQ96g2FQ79g++Amzgx17LxQOKK7R59k5wuSDmgHkKSIvAm2BL/vFEvOr0zKw7RDkEQs36zZBbM7eXraW+Mk/5YEc4EYtUw== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000016, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: 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. Signed-off-by: SeongJae Park --- mm/damon/paddr.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/mm/damon/paddr.c b/mm/damon/paddr.c index d5db313ca717..2b1ea568a431 100644 --- a/mm/damon/paddr.c +++ b/mm/damon/paddr.c @@ -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; } From patchwork Tue Mar 4 21:19:07 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: SeongJae Park X-Patchwork-Id: 14001425 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 86D83C021B8 for ; Tue, 4 Mar 2025 21:19:26 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 463BF6B0093; Tue, 4 Mar 2025 16:19:23 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 39C806B0095; Tue, 4 Mar 2025 16:19:23 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 1F03E6B0096; Tue, 4 Mar 2025 16:19:23 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0017.hostedemail.com [216.40.44.17]) by kanga.kvack.org (Postfix) with ESMTP id EFCBA6B0093 for ; Tue, 4 Mar 2025 16:19:22 -0500 (EST) Received: from smtpin16.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay10.hostedemail.com (Postfix) with ESMTP id 9BF04C0634 for ; Tue, 4 Mar 2025 21:19:22 +0000 (UTC) X-FDA: 83185134564.16.0D4461C Received: from nyc.source.kernel.org (nyc.source.kernel.org [147.75.193.91]) by imf10.hostedemail.com (Postfix) with ESMTP id 0D2B9C0006 for ; Tue, 4 Mar 2025 21:19:20 +0000 (UTC) Authentication-Results: imf10.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=kqIpFa+R; spf=pass (imf10.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741123161; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=Roxbi+mH/NdwfOmAlTyUajM1Qj63tlolVmRshCUfFVw=; b=aqe/2HQ1I1J+zKq/iaIYBIZ/e5+cuQZE1v2u7bP3XN3T4uUEELo5Ij22H9AFNz+H7Kn47c nJsdFMgXsFMiVf/1C3hoWg9tJmZRy8X4BRbz9XnjYyL87m1ZZSIJ1pwar28gBnQXJURcO3 OuAkOnc6ZF93N2LOgDI/6l9QGoGWyqE= ARC-Authentication-Results: i=1; imf10.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=kqIpFa+R; spf=pass (imf10.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741123161; a=rsa-sha256; cv=none; b=AdCJBVZ8qJ6c9R8vCngSQuVqhemx/7h2CeFnlNnBYzfuAkn+SNQ3t2t19qEEIYYW98svB3 FZF2YBlw0VsfyPurkMDmPGyn48lhjG3DLmA2fbCpODWna6kGo1F2vudbwaN/CEJvogm01E GrHvLw9GmUEVAQ0ZVRAudn9pPVfLCfg= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by nyc.source.kernel.org (Postfix) with ESMTP id A50A9A45F92; Tue, 4 Mar 2025 21:13:49 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 20FFDC4CEE9; Tue, 4 Mar 2025 21:19:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741123160; bh=6FhMRhtfgS5z0o99EQbkeXHgbive43ppIa5gFAsIPKQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=kqIpFa+RIbg45l+WZVNN2pvsN+N5xKLHk5pBg7HNxx8Wvqj9os5jidvQxjr4C3W6Q ElW6wzf8gv1cRgPliHbzAOgnLGmcH22Vti65265Vg7KAv9gHbwljGws8BvO/VXgkZn H74aAIRPmZ7kB2KeuYKh/VnuA+a5bhiOVB4csn2fLiQy3U1RHvK3HAV2LTKZ0NJCAp sbd4TGUdFyvyRqtuzqIhLTamE5avcohCCPPHljPBBvs0G3gxuDtnfBgDzS1uGOOdcx hNpMjlC84+/rIkSjrxxDZFokHNm/r1dhCbW/h5aDQ9rtkKxMzQ+6XV4APWaA/qOA2N dRmILrEr8vJRg== From: SeongJae Park To: Andrew Morton Cc: SeongJae Park , damon@lists.linux.dev, kernel-team@meta.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 3/9] mm/damon/core: support committing ops_filters Date: Tue, 4 Mar 2025 13:19:07 -0800 Message-Id: <20250304211913.53574-4-sj@kernel.org> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250304211913.53574-1-sj@kernel.org> References: <20250304211913.53574-1-sj@kernel.org> MIME-Version: 1.0 X-Rspam-User: X-Stat-Signature: xaupdryzstspotncx73w7uatkh3jhq35 X-Rspamd-Queue-Id: 0D2B9C0006 X-Rspamd-Server: rspam07 X-HE-Tag: 1741123160-127684 X-HE-Meta: U2FsdGVkX19ITp/Hxx1skFYoIgrLWsPd0fksS/xDr0QxXlIHNPegI8ZwSh9vlLhdFdzRjhXvCDzK/lc85MOha/Yk8LVR8ZWcKoBkc+kaTqz/4UQwOKaDsa9lQEhgEqp1rd/9y7fPzJ4jxjW59k7F1db2Uamkp2L/6yXvGQehmRGlsgJkPnUAdNfSai+VZC1C7RklhRo474r6mpPkG/GVgvGceLkxMEiim+fK+fOiscg8ke7wtEbEK2FnCeaAE/m3hDDdeRoNmDltXh24c5ay0ezCZVtSfzq537rLmxJBB/6j37aekd8BAiwl9u/rcreKQOaK9/ODR20Ji1x76WhXIj/DOuuSnwSx2P/nb2sO+yS7FkdOP2DVm/BC4STofdsr2xczZvHuQKSfxcemqNwqJQZOGJVwXUfX4RDuqjE5ZCx0AFNYQqjwLkLv9/cXsds0D3oSYuunuiGfkyE9xsKOIuMGwUskKp4mwPFnJ7wfj32x6aujS66ATnaKHYeBZJXtHIgfaRQzhFK3WNH3fKUwhmCih/HWw9la8CgeWMPOh0+jwCPxu+w4XndyTuuvRG+RucSr+0wxwTEmtKVup0+ikO+GQNfTXw0cVZEBB2INXlD2S8RcsgjxJkCPWm4MbB/PLAM9cEuDXdaeiYbNdIaLTjF0+UBVGDLlFxqR8KuWu4hXEn0HRL4NOXRmIVRxMn3lnkMlQ6gvnOo/kfego7xpZ5rKyD7N7bzXYmb0bNo2Qqko6Bjz0LWt43w7vTyG2VEQqR85zRuGIP1mNxBDPblMj9V8/aeORXNsID4ZuspPnZ798HW+RFTSJ68CwVq/mAeOhLMoBm6CQfnz2Af1K2g38tng2lFMeWVxFVrR2WuTBShmGejRxcleL/XwqxVyootKtzUOTeZMU6z79SzVn8P4NAB3ocBVXcrBrn7BPK0iaEBJXin4u3HDZAkEeXOvtS6v/R7SNCsVyMUxTIG5iBR fqKorgGm szR1fy1IqzTuhDtHycfk51HlwHpid1hbrgxel30vpqGCwD1gkCnFMxL5KMgJxRvsxrM+EOQP9SgExVniMTt1+Aqu+HSrKAtABwz9a/gANDmTb5PjmnzBegYsmpxA8CUf0hcwxb+ckjinz3dvmXv/6a+vbho2BCgsvCtWp1NFXKMbRujzkRyuF+BNj9z58aCjopfjXnpPratyNUN53uYDLeRHF8szAQRJbU3mR3ufLRmXNhCrkHZT1h67HAOjXmP5wr9vOUvBZxOJClaAVOrHF86VYHg== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: DAMON kernel API callers should use damon_commit_ctx() to install DAMON parameters including DAMOS filters. But damos_commit_ops_filters(), which is called by damon_commit_ctx() for filters installing, is not handling damos->ops_filters. Hence, no DAMON kernel API caller can use damos->ops_filters. Do the committing of the ops_filters to make it usable. Signed-off-by: SeongJae Park --- mm/damon/core.c | 40 +++++++++++++++++++++++++++++++++++++++- 1 file changed, 39 insertions(+), 1 deletion(-) diff --git a/mm/damon/core.c b/mm/damon/core.c index 5415b7603d01..1daccccb5d67 100644 --- a/mm/damon/core.c +++ b/mm/damon/core.c @@ -820,7 +820,7 @@ static void damos_commit_filter( damos_commit_filter_arg(dst, src); } -static int damos_commit_filters(struct damos *dst, struct damos *src) +static int damos_commit_core_filters(struct damos *dst, struct damos *src) { struct damos_filter *dst_filter, *next, *src_filter, *new_filter; int i = 0, j = 0; @@ -848,6 +848,44 @@ static int damos_commit_filters(struct damos *dst, struct damos *src) return 0; } +static int damos_commit_ops_filters(struct damos *dst, struct damos *src) +{ + struct damos_filter *dst_filter, *next, *src_filter, *new_filter; + int i = 0, j = 0; + + damos_for_each_ops_filter_safe(dst_filter, next, dst) { + src_filter = damos_nth_filter(i++, src); + if (src_filter) + damos_commit_filter(dst_filter, src_filter); + else + damos_destroy_filter(dst_filter); + } + + damos_for_each_ops_filter_safe(src_filter, next, src) { + if (j++ < i) + continue; + + new_filter = damos_new_filter( + src_filter->type, src_filter->matching, + src_filter->allow); + if (!new_filter) + return -ENOMEM; + damos_commit_filter_arg(new_filter, src_filter); + damos_add_filter(dst, new_filter); + } + return 0; +} + +static int damos_commit_filters(struct damos *dst, struct damos *src) +{ + int err; + + err = damos_commit_core_filters(dst, src); + if (err) + return err; + return damos_commit_ops_filters(dst, src); +} + static struct damos *damon_nth_scheme(int n, struct damon_ctx *ctx) { struct damos *s; From patchwork Tue Mar 4 21:19:08 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: SeongJae Park X-Patchwork-Id: 14001426 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id CFC39C021B8 for ; Tue, 4 Mar 2025 21:19:28 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 636EA6B0095; Tue, 4 Mar 2025 16:19:24 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 5C1CD6B0096; Tue, 4 Mar 2025 16:19:24 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 3C3746B0098; Tue, 4 Mar 2025 16:19:24 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0011.hostedemail.com [216.40.44.11]) by kanga.kvack.org (Postfix) with ESMTP id 193E26B0095 for ; Tue, 4 Mar 2025 16:19:24 -0500 (EST) Received: from smtpin04.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay05.hostedemail.com (Postfix) with ESMTP id C2C0351584 for ; Tue, 4 Mar 2025 21:19:23 +0000 (UTC) X-FDA: 83185134606.04.455D53B Received: from nyc.source.kernel.org (nyc.source.kernel.org [147.75.193.91]) by imf06.hostedemail.com (Postfix) with ESMTP id 2B93318000B for ; Tue, 4 Mar 2025 21:19:22 +0000 (UTC) Authentication-Results: imf06.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=Iw3kdZOg; spf=pass (imf06.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741123162; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=AfHDfx2Mqpmxqe3TsI4kVOqKKeK+BkQ3AiEldiz6qLI=; b=55hJmtPIpn0yFfIYogHIMUtIwffgh77WGUW2SEON7E29m0D3iuDwFUJnFzt8nJ6BYnJz32 nRhKc7PtN6lQoi/hJFBbsviBe26C5NbbijTVHmr201YPPwKYOxfdWsHgPhRIISsU3dd4Ky Jo6pfwbuuArJOL9tq5a4Kwg76mav9Qk= ARC-Authentication-Results: i=1; imf06.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=Iw3kdZOg; spf=pass (imf06.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741123162; a=rsa-sha256; cv=none; b=qGkGDmuABCV7UQX5xmoMWy2004bp7FA1c9/OUcbjLb4D8lIkOnTq04ypNPiyvoaJ7ExZ10 6lc6TGq3+w3reOVrO39nqsbkD6H46Hf+ZMdsmMXXDoCyDOrNfS6TBa8RnUCw3kRHR17+sP JKjZimtd+ra48eyRY8Abny3xkVI2S2w= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by nyc.source.kernel.org (Postfix) with ESMTP id C3CEAA45FA6; Tue, 4 Mar 2025 21:13:50 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 43718C4CEEA; Tue, 4 Mar 2025 21:19:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741123161; bh=Fde/lmLSQSXQ1liXQlydq/8+gonOje/B4rUucWXnWA8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Iw3kdZOgSW/u/FLm6g6CMFJyQVZNC4ZhzRohI9+qPAEsY0NxlJyrAiZ7HGK1eEUgr x4Vk8tfB4zycpMiZPQ0Ww5OvmRiIRsop5SDN2uGnU4JSxklmMLOcyGHAIta55u3jtj 9u7ujb6HXYACqm7TwsTaJKYEnF+WxtwF6BOUXTGNls4j4iEZo3W+LnHtxSoYcYXjMy Wz34ShUXRd5QwdamGuRjIMf76gTHMtl58V5ITdvjNatxX26xonqU86up91zLT92NM9 27romVx/3IxV+kwLagVS6fpOD+eEtPP8gKwrhszRd7XvB7I7A0yu0WTMV7bLdRnbaf g4tjCZJQWp89g== From: SeongJae Park To: Andrew Morton Cc: SeongJae Park , damon@lists.linux.dev, kernel-team@meta.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 4/9] mm/damon/core: put ops-handled filters to damos->ops_filters Date: Tue, 4 Mar 2025 13:19:08 -0800 Message-Id: <20250304211913.53574-5-sj@kernel.org> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250304211913.53574-1-sj@kernel.org> References: <20250304211913.53574-1-sj@kernel.org> MIME-Version: 1.0 X-Stat-Signature: qbxxq1xo9mxgyoufofnbo7k1berbk5xs X-Rspamd-Server: rspam11 X-Rspamd-Queue-Id: 2B93318000B X-Rspam-User: X-HE-Tag: 1741123162-150675 X-HE-Meta: U2FsdGVkX1/jAKftvnAwII8f7jfDQ9dqg7r4KRUD8hpPUiyXt3Wktm1BuQsv2Wl9vi2OTgBrl/kUgVwwb6uDIlnyGGPPMZeUxiKmNqm/oz7w2hslnF3sAmtliO43AzJkzj84yLZE7owJywlC+D0e1bUPzBATt9Gs2zntchuaKhM8GYE0pzMr3Ll4wyHi6H8D/CMe6XqgI62cB8b+WtlvWhybyIMFpir0fCtEvJobG1qp40CEJWVM8YWX9uTnE6mStIwsDZHj0nn9GpZtU+Egngc7eYUvJamSRgQA/EPxuGZMi2QfEeP6JHzyv+l9iWAapHMbyPX+wbg+6Yg+wSzkV7gqOZOYLyjRIFSM05CIRIS+Gu4zRfQp2kUDNdFSsFHKtEHqFkCPy28iw38wpZAHYR/pN31yEtwpXprxFL0viJDs43IYPESmvCooXFZFSI1xJkbBn+rlqb98tT1AGH/hkHpccveTUzCh/XJDAn+RFSfZwFSJrH0v02dWRZaTs6pI2IXzpd/fXCp6DbiGhh85hffaSBSDxZbPLhjt1JS9XVEVyCn5aQN57S2ccbtP3J3qPPglqlpndV9e2ic2hgDVfgPg0phwkHlvriVIcn8QVjnJdn6zlQRH5icIpyc3SqwoBRz5LYpRh3mogEQfhzPsMMMmWZqIRJI3Fruv4JNRDZE0nxV/zLNrZCnau4hN1WxmIr4rKlZIQ0a4jS4jKfAlPku3XP9z9trqWEl2Q5tTv0PxH5enEx0VjYXiGmKz2z1N5vUefJOBxFy6Cpdz6AIIEwL6eS/cO3e69EUHhysDjd0pH3WEKi0ZF09bdFmECPLzyTM4j0Y4y7OCi8JdhCTVFWc/2pymr7Lnj2sUfKVpq0GqrOXLzagmyaw+crAZfw21LM5g2/32nk1xMiMS02YfvxKvpYhf8+OdwZRpJVe/ihGvKoPV3f+VAVkF3CbVj4K49ih6jlgHkmz10nPgW4u dkLoqihz jlHiRtoIIQ9zPuiJjqrxHh15dJqMyZFsB12cZb1eLvuVThR6xFM/omyQIRxTIZYdSvm3OfjtJzCZgD7xefxHqWgGxAR2IMC2HawPssh2prsyF2TZjVhXGlMF79dTMeqyeglAg/KS94st0t+5qsaxt8hfa0BWMORqoI0ESGdaWH/PMqcE+CCdSQnpylIzILSA+SV1/IbVN4PnrO4vkc+rdlEAmC0mpDeTKem8T0oXDH/9St46ePriG6HeOk9fstF0v8dZvH5sXsHg9SQYkPkqBNcJxOA== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000553, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: damos->ops_filters has introduced to be used for all operations layer handled filters. But DAMON kernel API callers can put any type of DAMOS filters to any of damos->filters and damos->ops_filters. DAMON user-space ABI users have no way to use ->ops_filters at all. Update damos_add_filter(), which should be used by API callers to install DAMOS filters, to add filters to ->filters and ->ops_filters depending on their handling layer. The change forces both API callers and ABI users to use proper lists since ABI users use the API internally. Signed-off-by: SeongJae Park --- mm/damon/core.c | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/mm/damon/core.c b/mm/damon/core.c index 1daccccb5d67..3fbc31d17239 100644 --- a/mm/damon/core.c +++ b/mm/damon/core.c @@ -281,9 +281,24 @@ struct damos_filter *damos_new_filter(enum damos_filter_type type, return filter; } +static bool damos_filter_for_ops(enum damos_filter_type type) +{ + switch (type) { + case DAMOS_FILTER_TYPE_ADDR: + case DAMOS_FILTER_TYPE_TARGET: + return false; + default: + break; + } + return true; +} + void damos_add_filter(struct damos *s, struct damos_filter *f) { - list_add_tail(&f->list, &s->filters); + if (damos_filter_for_ops(f->type)) + list_add_tail(&f->list, &s->ops_filters); + else + list_add_tail(&f->list, &s->filters); } static void damos_del_filter(struct damos_filter *f) From patchwork Tue Mar 4 21:19:09 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: SeongJae Park X-Patchwork-Id: 14001427 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 6C3A1C282D0 for ; Tue, 4 Mar 2025 21:19:31 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 2B4136B0098; Tue, 4 Mar 2025 16:19:26 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 264366B0099; Tue, 4 Mar 2025 16:19:26 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id EE7196B009A; Tue, 4 Mar 2025 16:19:25 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0016.hostedemail.com [216.40.44.16]) by kanga.kvack.org (Postfix) with ESMTP id CB3646B0098 for ; Tue, 4 Mar 2025 16:19:25 -0500 (EST) Received: from smtpin19.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay03.hostedemail.com (Postfix) with ESMTP id 7246BA3C0E for ; Tue, 4 Mar 2025 21:19:25 +0000 (UTC) X-FDA: 83185134690.19.135E80B Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by imf27.hostedemail.com (Postfix) with ESMTP id D551840008 for ; Tue, 4 Mar 2025 21:19:23 +0000 (UTC) Authentication-Results: imf27.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=Tp4w0ehV; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf27.hostedemail.com: domain of sj@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=sj@kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741123163; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=3iq1URAj6knBwOjeduALHZiu2oDCZ3MosMqfbPhysvY=; b=pNtxq/kftl0CTJY+efCw0wHftvHsiA41GgPlgLdJ/2UbqNQqW9lDqW647c9NhQ2eZv3l9d 2WxmVreEJrcTkwEIRx0IfgCpU3TwwY2D91SeGTELtPTy5kxNJpaEU9uihNvXfg1wz49PMC 6eLTl7b5CXld0k0JFLiNzEBMZc9xFd4= ARC-Authentication-Results: i=1; imf27.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=Tp4w0ehV; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf27.hostedemail.com: domain of sj@kernel.org designates 139.178.84.217 as permitted sender) smtp.mailfrom=sj@kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741123163; a=rsa-sha256; cv=none; b=Xj7ClDOBLQ/+0+lWckIIayupWnr27jiiJZkkidxg/h5nlD7POoIbYIXQXdGQ01+ibAYnHL Y63JrLREkqt+xLF5azNwqApOothtBL8/ufEN7KAITtYoscccIEPPc9EV206W+ud7NCQcJz c/+HOQj2RcKOsI/Fk5lx8rN5R7TKst8= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by dfw.source.kernel.org (Postfix) with ESMTP id F3CAC5C63F1; Tue, 4 Mar 2025 21:17:05 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 70108C4CEEE; Tue, 4 Mar 2025 21:19:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741123162; bh=aOvI5yHdfp5ge5+cmVoLx0OBIr3elAAL0hmqCGTPnsE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Tp4w0ehVwDNHiFXxn+urIRkFgiKetm8fQ7pasLsvTZn+huWTAPjUcV5hz1WhiyAZo NUhGb3SIWTnkVariAAGLwEyVR562FvrnREZf4I9P3MH29HbQmzwWimSivvIbcd/EVQ MgsvWbit9dDoNIhIJcGlFKZ6afBKXslekyNdGy56yYp3ipfW3bol54BJO4IUB+Qgdr D49+VRBHDBMX/nPqy2Lj9kd269zG0qDdCJZlWukC1f1FT5wN8VGz0fCWFc5+74213G N+K088o+AXVIibDxfa63vZzRLL5S9IkXZiWqtuHhi6b5DEEv1q7GqQxd5On+n7AWpj bkhX/rwxy7spA== From: SeongJae Park To: Andrew Morton Cc: SeongJae Park , damon@lists.linux.dev, kernel-team@meta.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 5/9] mm/damon/paddr: support only damos->ops_filters Date: Tue, 4 Mar 2025 13:19:09 -0800 Message-Id: <20250304211913.53574-6-sj@kernel.org> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250304211913.53574-1-sj@kernel.org> References: <20250304211913.53574-1-sj@kernel.org> MIME-Version: 1.0 X-Rspamd-Server: rspam04 X-Rspamd-Queue-Id: D551840008 X-Rspam-User: X-Stat-Signature: ughrs77ymkek75k9zn8oyci85ehu89h6 X-HE-Tag: 1741123163-606055 X-HE-Meta: U2FsdGVkX1+g+/SD4lC+mv0jdinRDIpqzfZW9uqcr7qUQn1SraKeRO9yLPx6ZB0MA627wUTGgQb8JkAaIV67i5zYzHLuoKuWJckkcdygu6810vq1qBelgDACkFKX0s3h6nnZHaNNyWXdKnSqhIdGIrOdGpuKycZHhBsyBMw/ZTpkL1xa5ld7RDIBDB4dUx8Ky1x3HVnM2oDdoEbfRPgmi12iATR1+7bOgrRhdZjolTyKzzhf6tZZqwyh6E4LZ/Pi5M0u1aPUEWGu17osRx5Q/mySdgne1BdPLHKs5CtvdOckdGYNQBaTX6Ay1cWmHLUApdzMHijCHs0/IeMXHua6a7QZUsC6GaYdikQFjs2BtD2RY62C+XBV64duofKuzRtjAytOeApJ+rmETkFBZCMtBn6g31om4RnDpnzjA2pJn0v1YqECNf6j6MqAf5FG6G19tNcGibe7NgTCDjly3bi4ZAfZlhfc8dT1FkSKIe8WivAhlMMo9iPndn8N8wujNf7zFc6mAnjbFMvgxQrS4bg5rQA5DRW3xqvaajK43He+3PzNesdYvc3W9fNJTaHYXPleUq9CT3bxq18hIINDbi7XXvVrqhhnA9EvKV1f5rZVUiprzMHXTZ88knCj8K3/+JvwsV/jdIT1e5W/bxo0RgHGAdjfu3wzNCWsCHaCz+0WVwwwuqsiupuj99gfDJUb8m0+OJkK5Jwl/Fa7JpmSyiXWv3vxN/cQGwdJVyFxYQl+qa4A0FriF/2BiWRl80ubs1RrKBsN8wmnEUU4mVcZqubw/hVO9fMiAeNX7B196g9r145rLdH+yYdGfGrsOiW67b5uTYGcCzmIczDcMp2sNyKoK5ArL4kufLud4p59kEbflxbaeHGbh18wMN8q41hm/WTZvYgghrkO936DpjKrr4YTJbp87VrNHNaxOvQu0nL4lxkZ7oB5ksLGf1vgPvXusylRls/Z2XU7SxZ0jbjGLtr d8UtIHSm T8gJk6DYU5l3rqIGUpp5GKHtpiZY+sxmz0UlZuPfU/B8Om6vURNDo/s5VU5Vz5dW397lDNE+dQiggS/ufVhwAyEs8xVnqL9zYJQcdBbarLrXAJf2lSmP9O0rcz7RlLWln7FL44Tk7VvyyCIJ19AG6CWk6EgUoJITno3dyl1AaNtuBaagx99mRdCm9ryk/UaWKU4bGwUnq1bK6dZNqkZpg9G4PdyYtYgOp9AJ1YBXuOwnfwT7oPeK/VKqWkAcGrQAD4mfP8FO+Hbm85AyXAoOiw/H/oQ== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: DAMON physical address space operation set implementation (paddr) started handling both damos->filters and damos->ops_filters to avoid breakage during the change for the ->ops_filters setup. Now the change is done, so paddr's support of ->filters is only a waste that can safely be dropped. Remove it. Signed-off-by: SeongJae Park --- mm/damon/paddr.c | 12 ------------ 1 file changed, 12 deletions(-) diff --git a/mm/damon/paddr.c b/mm/damon/paddr.c index 2b1ea568a431..dded659bb110 100644 --- a/mm/damon/paddr.c +++ b/mm/damon/paddr.c @@ -256,10 +256,6 @@ static bool damos_pa_filter_out(struct damos *scheme, struct folio *folio) if (scheme->core_filters_allowed) return false; - damos_for_each_filter(filter, scheme) { - 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; @@ -288,12 +284,6 @@ static unsigned long damon_pa_pageout(struct damon_region *r, struct damos *s, struct folio *folio; /* check access in page level again by default */ - damos_for_each_filter(filter, s) { - if (filter->type == DAMOS_FILTER_TYPE_YOUNG) { - install_young_filter = false; - break; - } - } damos_for_each_ops_filter(filter, s) { if (filter->type == DAMOS_FILTER_TYPE_YOUNG) { install_young_filter = false; @@ -546,8 +536,6 @@ static bool damon_pa_scheme_has_filter(struct damos *s) { struct damos_filter *f; - damos_for_each_filter(f, s) - return true; damos_for_each_ops_filter(f, s) return true; return false; From patchwork Tue Mar 4 21:19:10 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: SeongJae Park X-Patchwork-Id: 14001428 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 002F2C021B8 for ; Tue, 4 Mar 2025 21:19:33 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id A7E7A6B0099; Tue, 4 Mar 2025 16:19:26 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id A05E36B009A; Tue, 4 Mar 2025 16:19:26 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 8A6906B009B; Tue, 4 Mar 2025 16:19:26 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0017.hostedemail.com [216.40.44.17]) by kanga.kvack.org (Postfix) with ESMTP id 6536F6B0099 for ; Tue, 4 Mar 2025 16:19:26 -0500 (EST) Received: from smtpin07.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay07.hostedemail.com (Postfix) with ESMTP id 1D1FA16067E for ; Tue, 4 Mar 2025 21:19:26 +0000 (UTC) X-FDA: 83185134732.07.4B94C1B Received: from nyc.source.kernel.org (nyc.source.kernel.org [147.75.193.91]) by imf25.hostedemail.com (Postfix) with ESMTP id 88028A0009 for ; Tue, 4 Mar 2025 21:19:24 +0000 (UTC) Authentication-Results: imf25.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=Svab4fVh; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf25.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741123164; a=rsa-sha256; cv=none; b=jCJlcRQdk+2nf6VKqyFj3TtMlPLko4lZk/qlGugMSJ9ISfoVeCPF+F0Mc3cVHmorCmwFUD ouKcU38bwsgvCGzioCKtiv78BmbxxcMi4Z5+zRV4lb/CUGFjptJWxoqNcmJfgPwd7NO1kT LNJf1xXyvGTwbpk/fCSAZq4Wl1bx1z0= ARC-Authentication-Results: i=1; imf25.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=Svab4fVh; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf25.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741123164; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=IaJN+yoKa9k0iLp48HYbsxrTF5jhRhc6aB211JQNRmQ=; b=XFv7U14mnUgTyGWM5MSijCjPcWP9f/74jRqr/JCjoFbCQ0r04eewctRu1f5rAPE2XfFz06 0N/6C1fNSeU0bJ0UZGJi9HdZMcfAh3PqQnJ+4Qeb1d0/ncFyA96izkmvwHaj5OD1b5Pn+V Gq0FT9CLCHfm/1qitjQ/U54wxoYNrTM= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by nyc.source.kernel.org (Postfix) with ESMTP id 2DB57A45FAC; Tue, 4 Mar 2025 21:13:53 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id A0856C4CEE9; Tue, 4 Mar 2025 21:19:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741123163; bh=EAOvbQzL6b3K8TBvvaz/3YCTyNwJ67PJ+6i3fHUuYA8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Svab4fVhiOwVzBa67vyOMt5FwC01tvxULzewvGCpuajuPl9b7WMNEIV8xoBj70wOc vib6yUodrAqyupqCTR+6q7WYKRoEe5BiuRW94smu51GxUtm+YOclV1MmD2dPDNiwpE NyvZfq0ROunPGPvGOmozHi34nrq9bGRF6HjZ8AeQNZsr+eCroQnd1UPaJNM5ct8YtR FeMR2UgDRzOcpHfy2VR9yysG8vfMXFB9VTLktCgixYYF1l9bh415K9z7NU1UjF/4sM dHqNVW6I7SvkCa42jaxTMp+4WjexC8zt2/rdkJNFl/2y34j3XPG3eN8Kt74VSx1oiO mM4gtgPkcnoFw== From: SeongJae Park To: Andrew Morton Cc: SeongJae Park , damon@lists.linux.dev, kernel-team@meta.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 6/9] mm/damon: add default allow/reject behavior fields to struct damos Date: Tue, 4 Mar 2025 13:19:10 -0800 Message-Id: <20250304211913.53574-7-sj@kernel.org> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250304211913.53574-1-sj@kernel.org> References: <20250304211913.53574-1-sj@kernel.org> MIME-Version: 1.0 X-Rspamd-Queue-Id: 88028A0009 X-Stat-Signature: pf3fgh4hpk8ar1d16qfo9bb5cfajeegn X-Rspam-User: X-Rspamd-Server: rspam05 X-HE-Tag: 1741123164-255545 X-HE-Meta: U2FsdGVkX1+9RLWAs8QlvzpONoKDz+bUxb+N+Q3DqlEBk1pxi1wuCi4Qsg5uQY9rSPJXCvd8rrs72j5K2KrYxtaeiXosoE2dQc3HDMm/gsOGR0ncQySI/NPUfo+RuzfimPMMxa9FBfy4J+IrrPQYlgCUYOp/d4kG/Ju+O4SAuagSA/OnMLQ6w0os/QZOa19f4/zHupHp/BiPnB/XTO+RwzNQ54J1fiw4yOPliMlGjphlGdsTL4NWAJOC2IJtBNUfbycTjDViH/p1W6B68o5BLtgj1f7Xi4XXl5pVUro7WOjDM3PVnOyJjkQksv0aAjjHpo/Q3Nq4ke7X9B+0Qb8u65m/IeyHF3SrHUsG224AqrOq9+8pV1Bd8rESXg4pCu7HQ6/qxGOnl72VsDe1YrEqnp+WTOejkIszJ3y8a6mtfyleqANKJioq9QOd17YNSu4TAjnfakvqrDzyR5e9YYq6OxKMJ3Dq0gav7bfaXUqABSo5HQAD8ITXI2RUtcDLTXRCvitHVlFqgK5f2Y5g0irlL26k9leEdXobrleUVD/YvLiFo+QUAcdLUpO2vOqp3fCy40kFIUebRmewO73ULDlVuCe1ehIXgwgZIwty7gzqebCMkXxILdwgQ16FIn5zR5aNsGpa57mTi3kbIbkZHFXHkG+YLiFiR0pZlRng3l0ZXKuPBZY0y7rkR3Ub+4Q7vxgOBOOITIYmUcnpMQI69F2CBsy1fp5t9KYpeBkNgxtz79EDm74863pnoPqv7v7dYeEbk6lq5CjCTYi1cn95UhNA7EcVMLxTGA6XUkvU2sIWI671ObiIa0079kxe+KOib0fBHW2HhaAiz2qQ+YEqB2xdpaEX5iFcYcV3ZKFkyyy1wz6s/++d5wEKcOzbRszuKSI8w4vriZddL8zM1AV3bMELQ1QBHowE2PUkKwcSx71ih2C+SE8SBqT9jcLbZ6XZW+I2NsIgLnsMh4JyU3RVBSN +f6cxCJZ jYjp2h1B3d+H0lWGYruGQ6HOfalLG0lG0xgWeZMWv/1F3ScIBlQxqetqHJ/VuRurP49C8v+ttIJg7mGhVamYUD1HXySre0wbOpQ+yyzNIZnJxmzzUFV0xrt/9q3j/jOWAkITbZShYH99mOhG8AWfMtM5otrTjd7nq93yXORWK/gXdHde0Jm99NNkX2piAkRzidQigeMp5nAN+pVMAf/ssmoZA3IbPj+8MQTgAtYSzXMJ+DdQ= X-Bogosity: Ham, tests=bogofilter, spamicity=0.000034, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: Current default allow/reject behavior of filters handling stage has made before introduction of the allow behavior. For allow-filters usage, it is confusing and inefficient. It is more intuitive to decide the default filtering stage allow/reject behavior as opposite to the last filter's behavior. The decision should be made separately for core and operations layers' filtering stages, since last core layer-handled filter is not really a last filter if there are operations layer handling filters. Keeping separate decisions for the two categories can make the logic simpler. Add fields for storing the two decisions. Signed-off-by: SeongJae Park --- include/linux/damon.h | 3 +++ 1 file changed, 3 insertions(+) diff --git a/include/linux/damon.h b/include/linux/damon.h index 7f76e2e99f37..52559475dbe7 100644 --- a/include/linux/damon.h +++ b/include/linux/damon.h @@ -502,6 +502,9 @@ struct damos { * layer-handled filters. If true, operations layer allows it, too. */ bool core_filters_allowed; + /* whether to reject core/ops filters umatched regions */ + bool core_filters_default_reject; + bool ops_filters_default_reject; /* public: */ struct damos_quota quota; struct damos_watermarks wmarks; From patchwork Tue Mar 4 21:19:11 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: SeongJae Park X-Patchwork-Id: 14001429 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 814E6C282D3 for ; Tue, 4 Mar 2025 21:19:36 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 991F36B009B; Tue, 4 Mar 2025 16:19:28 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 91D786B009C; Tue, 4 Mar 2025 16:19:28 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 76D5D6B009D; Tue, 4 Mar 2025 16:19:28 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id 486086B009B for ; Tue, 4 Mar 2025 16:19:28 -0500 (EST) Received: from smtpin09.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay02.hostedemail.com (Postfix) with ESMTP id 67D39120659 for ; Tue, 4 Mar 2025 21:19:27 +0000 (UTC) X-FDA: 83185134774.09.9E8F077 Received: from nyc.source.kernel.org (nyc.source.kernel.org [147.75.193.91]) by imf22.hostedemail.com (Postfix) with ESMTP id CE151C0008 for ; Tue, 4 Mar 2025 21:19:25 +0000 (UTC) Authentication-Results: imf22.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=LrMKwWWt; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf22.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741123165; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=ylyB9J6hrsU051b7/cM5qneftJlzZ+SDbUBvnFqczoo=; b=GaZw/LLBNy4MJ1CYXeSk/brvV6JmGxzE+TvFcoBnYEJ0pWCEFbqydgE8aUxJ3N/r8kVAQB 8w8Wh5Sw02zFSlWrh0HpnpkSMu1CejsfWDqyQz/roBhd7TH8q3q/ZsfBJ9EP3gMWSUzfDp nNVlFzPEcjnziE21Id61h85WpWXv6KM= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741123165; a=rsa-sha256; cv=none; b=EP1gCIyE/PHmF6nBfj97SMYTf7Gg0jzJKMKN8yEuJYxRqKbTfq6WZ57O4MxHnvDQrLTJU0 Xr2v2v76mJ25+rvGF4xbGMKBB+qndzIaSiy3LTeYlBnYusln3xbb+JvZDP1DP3A0WeZj04 xbnB/vwW4h4ph94m5L2JhPx3kkD5GKQ= ARC-Authentication-Results: i=1; imf22.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=LrMKwWWt; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf22.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by nyc.source.kernel.org (Postfix) with ESMTP id 5B6F0A45FAE; Tue, 4 Mar 2025 21:13:54 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id B9E89C4CEE5; Tue, 4 Mar 2025 21:19:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741123164; bh=JHR8X09g7RbF+z7f4pVptzblJHocAhQ0MhsGQMkHws4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LrMKwWWtHJlk8IRwUXYWPpsrLjun2KZA81/oqEUwWUUFCof6U744AYZB9SGWuivag 376YD7Tlak5+1Q7fwe46b96rtbc2VvxWQmyoiLR32HL4TFFCDWryQF5AIKv2VuA+pM XKu60rm8ooVyLivi4UUZ4POoBTrrq5GieMUbIYHwPo+Z9r3hdhvw1o6rUNVuvHa09D FLMvuZ/roJSe7NvrO6lz49C0cIjtTIpy7pC21p4gRSnCFVe4/U9aU6Ot+pOLNEehae 44lsSYbTonQDfKJu5fj7ytc4/e3H5qhRmK1DxRSLKfBwdVsHRCCQNBJsp85Y/ruJDY HMtdyIgNxgltw== From: SeongJae Park To: Andrew Morton Cc: SeongJae Park , damon@lists.linux.dev, kernel-team@meta.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 7/9] mm/damon/core: set damos_filter default allowance behavior based on installed filters Date: Tue, 4 Mar 2025 13:19:11 -0800 Message-Id: <20250304211913.53574-8-sj@kernel.org> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250304211913.53574-1-sj@kernel.org> References: <20250304211913.53574-1-sj@kernel.org> MIME-Version: 1.0 X-Rspam-User: X-Rspamd-Server: rspam12 X-Rspamd-Queue-Id: CE151C0008 X-Stat-Signature: wsaicgerx4chu5zrypyzdxfoqucm5ktn X-HE-Tag: 1741123165-479725 X-HE-Meta: U2FsdGVkX1+VV6IhAqztVsvQNZw6pl7Qt6RLZ1SVfjri2tUTuf/bgz4aY0NBbEBnISRBMUXNynrtjgB4b6VQISFf5fR/QtT1RbPYv67Qd+/ESJ4IP4sFOxV9Tro5lwndfneo7JoTvQMeSlwTP9tuerlTbNcELWckW2g5X9HdNEaKAdY/BMQL/LdUKZ6AHSQQ7XZpcZiWZ4L7cX7m/lzajvAJIfNRKLs1wXjXBtCPA4b5WiUilH+6DCxrHMWP7rA6+PgzLu7qi1w2LEN8FGgVvmk6pj18Ihft43hkvCxNQqnMtZRhvZDEfPsOklMGwZ6oHEsSXcrU8wuWSSD08wtw5qKlSLuwNEQK5mQYs34j8XpaVlkppLjbUaNOwh1vTMcVvXB1x8EU8i6POG4nPKPt3dkJ79AsJ0Pc8wikGr+YwexJPPNyUMVK3hkr7G4Fuik5ZE7mCGx55+kwlvGQHmGyIOdP7wrT4kGKW6FiMq+9k0IytLmjWnNZn5v+NaDTaWZ1LFEsANeMM7j6HVoKdjESBKTPGT/CBzXxCDtAKFhYmzoNl1JqOTG//qKIGhWHFW4UIRt+4VnsBwk/dtMwlJ3KkOeZTh+p+SGSouxVL3/PK9XUjr/B3wpR7xgVpFZ7cG6sr5RKf0vxLHHUd8JZxNfNfCpnXgG5R9plxXwEf1K89zD/+I1+uM5OabkQojTAyUdQYjKmGQLQ+25en0/rSkN6d+DAYS3HghCzZee79TJlWsotPF7uAAvNL3Q5CUfxJqg2bBLCjrbu4Ovh9ODqMF9O8GHDbB0ymaqJMY4uUcR/UlgPaTyIo8jUO88YEyNipanqEM5fzYwn5vuPb24HAPivAuqJtt37wM6/sS/ZRIONYC5yohLrhHU052GlSaZhCRdwgHaM0yYEUo9gefILWa1QK9+Z/0a/e+YSUkjStae59cqJrvJf9nfGpiaJrVYM/4JxUtvhXzGGLZEjG1kPMxx yjeTibeN GqDwk4BtJaeiBpPcbfDPwQQFWtZN/1Kk88PtNc8I9Gv9DeG4IDahU4KFE3Ga+diwcY6M/7l2mnuhsUtdlrZiNhU4bpuyXbsGiS0t/MivuLA1YVFJdhifHN0V2gRq2QQ8rhoOF5zBLradOQ/t9y3w4QTAWghfafQJVV3nlVZSBc2TYA9PwoW7ACwiQMTVqAezrd3C6eqewQpezC1MgYyCwvMljK1cdpIg8rdeKSEm4aijnvcLKW0pc4bEcKg7ogF6VmnJaG+M/onRKkYPlSgbQOQsjWQ== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: Decide whether to allow or reject by default on core and opertions layer handled filters evaluation stages. It is decided as the opposite of the last installed filter's behavior. If there is no filter at all, allow by default. If there is any operations layer handled filters, core layer's filtering stage sets allowing as the default behavior regardless of the last filter of core layer-handling ones, since the last filter of core layer handled filters in the case is not really the last filter of the entire filtering stage. Also, make the core layer's DAMOS filters handling stage uses the newly set behavior field. Signed-off-by: SeongJae Park --- mm/damon/core.c | 34 ++++++++++++++++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/mm/damon/core.c b/mm/damon/core.c index 3fbc31d17239..194550e033b1 100644 --- a/mm/damon/core.c +++ b/mm/damon/core.c @@ -891,6 +891,32 @@ static int damos_commit_ops_filters(struct damos *dst, struct damos *src) return 0; } +/** + * damos_filters_default_reject() - decide whether to reject memory that didn't + * match with any given filter. + * @filters: Given DAMOS filters of a group. + */ +static bool damos_filters_default_reject(struct list_head *filters) +{ + struct damos_filter *last_filter; + + if (list_empty(filters)) + return false; + last_filter = list_last_entry(filters, struct damos_filter, list); + return last_filter->allow; +} + +static void damos_set_filters_default_reject(struct damos *s) +{ + if (!list_empty(&s->ops_filters)) + s->core_filters_default_reject = false; + else + s->core_filters_default_reject = + damos_filters_default_reject(&s->filters); + s->ops_filters_default_reject = + damos_filters_default_reject(&s->ops_filters); +} + static int damos_commit_filters(struct damos *dst, struct damos *src) { int err; @@ -898,7 +924,11 @@ static int damos_commit_filters(struct damos *dst, struct damos *src) err = damos_commit_core_filters(dst, src); if (err) return err; - return damos_commit_ops_filters(dst, src); + err = damos_commit_ops_filters(dst, src); + if (err) + return err; + damos_set_filters_default_reject(dst); + return 0; } static struct damos *damon_nth_scheme(int n, struct damon_ctx *ctx) @@ -1580,7 +1610,7 @@ static bool damos_filter_out(struct damon_ctx *ctx, struct damon_target *t, return !filter->allow; } } - return false; + return s->core_filters_default_reject; } /* From patchwork Tue Mar 4 21:19:12 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: SeongJae Park X-Patchwork-Id: 14001430 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id AE806C021B8 for ; Tue, 4 Mar 2025 21:19:38 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id F3B4E6B009C; Tue, 4 Mar 2025 16:19:28 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id E99CF6B009D; Tue, 4 Mar 2025 16:19:28 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id D12516B009E; Tue, 4 Mar 2025 16:19:28 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id 962376B009D for ; Tue, 4 Mar 2025 16:19:28 -0500 (EST) Received: from smtpin09.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay05.hostedemail.com (Postfix) with ESMTP id 58B1D5159A for ; Tue, 4 Mar 2025 21:19:28 +0000 (UTC) X-FDA: 83185134816.09.B500617 Received: from nyc.source.kernel.org (nyc.source.kernel.org [147.75.193.91]) by imf15.hostedemail.com (Postfix) with ESMTP id CDDCAA000A for ; Tue, 4 Mar 2025 21:19:26 +0000 (UTC) Authentication-Results: imf15.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=M6UHmq9j; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf15.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741123166; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=Y7WbBVK6yT1hDW8SfKHEXAKRcKj2B/GJk1V/Jo19aIA=; b=jnS/Vqn8arZHUSwNnMTK85/Y4sbZJS1tSTLfHf5cfCM1SCBfjmswpL1JJqwk7xfuhtGf/o BXrNoGckJ8Fy57G7P4Xunr0+uhviexiAAig8/sWyXb0RcydWuVupnBPpepw+7n02GJjSUZ jzv3Qp0yVGKBp1iBES+rSzGLFyvNAxs= ARC-Authentication-Results: i=1; imf15.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=M6UHmq9j; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf15.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741123166; a=rsa-sha256; cv=none; b=P2hGiZuWV5XLNgjrQUT++CSJ7+Wh3MAvk9OFa/W0LiELYfrupfsoekoX3Lwd9WJdJrRISQ /j9SBJoINTJgqodIGDiz3Fsl0ehs0qY+Z02m8EsCqvnHYhxU9hQFJeiX36MM4LIcqTg/pi 0At/7X7rPRs7VCjzvSXGPOsXCq+ZUVk= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by nyc.source.kernel.org (Postfix) with ESMTP id 6B39FA45FAF; Tue, 4 Mar 2025 21:13:55 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id DCB93C4CEED; Tue, 4 Mar 2025 21:19:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741123166; bh=ZliShDrZ0L46pvsTW9GzGZb0sxInjXIUsFCHMS3ng74=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=M6UHmq9j1mkN0E/jbDoKlPvDDEXN/HEofEzXOoAFv0R1wVXpPeAhVFQJJaUGEd92Y jQ1s619HlVIVL8SyV04x2TWXiNMexUhRdUYdtPTaOVD2qGOdcZrhCEgjdHE2ByQ7Md DRVjaE9NdYdxM3bqI5sD2SPg0cDGH8C8Wc30mrp5pISWr9OFgd2YVZeXp6yDIwh8Tt BjGI9s/MfnA2tJF8PuQutJmOjRwrHQjugfSr1VVxLI0KAzSxYzMu6WJoGS4FVOXjbT Rywfe/pxqGFCmot7EwubXP2V6pTtKe64V+1xGioybpTKR999XhhpOHiYk7c2ZjbAnZ 2aVtS7qsiY9fQ== From: SeongJae Park To: Andrew Morton Cc: SeongJae Park , damon@lists.linux.dev, kernel-team@meta.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 8/9] mm/damon/paddr: respect ops_filters_default_reject Date: Tue, 4 Mar 2025 13:19:12 -0800 Message-Id: <20250304211913.53574-9-sj@kernel.org> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250304211913.53574-1-sj@kernel.org> References: <20250304211913.53574-1-sj@kernel.org> MIME-Version: 1.0 X-Rspamd-Server: rspam04 X-Rspamd-Queue-Id: CDDCAA000A X-Rspam-User: X-Stat-Signature: mpdd49az5f6ooz6tigkfzs89whyz5ixe X-HE-Tag: 1741123166-561374 X-HE-Meta: U2FsdGVkX18NgzfNQZv6ep93Kks7XayLjGgtlGyMhtVjF1e/iyO30qjmNrpy1KhiEsvie4YZG0xay2vTTVggPBM18offb0H5He8prD843LbdhsqyzOUU/sd5Yl+mZqu5RU+L/+BTsZENkWzbHgSwQR6oiIp/nYea9CFjGP+1LZP+kvWUkYTZ8RnJM1OOt5GEO+VtgTt0yulxoWXQsfSpqQAuNcMAohvN7tYCYlP1/6B/cJPwV+8kYRAL5fTuK+iIFVffZdjuInFrTnV0p9F9eXh8vgpBWKBhHCfUWqEqz8I2ljAm6aQ7Q2MlzApvjGE36RJiVqxqmOmupCC5jL81pvBMwTCnhRIazx9pu9mGkyQDRkviqL1tmQJd1/ue8pYMDABUGTJOLgjbFN8gLvF927NHJgxEDPp9V7+9KgumnywNPpPOGZXFRnsgrMKLndIx0XOUdCi5WXgmJK6P8wlMIKDUDvOO5JQtoCwq09aT6JLxhHo+bomHFdvFy57fxxLDEVXF4ZEljpEo07FwZtPa4Xu9oiZWEw0WVdHqHOWEJIq+yBE/OMJK7xoVsGifxavVwjnIRxm2yqvjWe7Jej7x2mzkGWj3nEUJitP4M8LsLbOOlcAelrG/GuIBuob8OG19EsNbeamM/dnn2vx85MxVb9Iyn5EclS8Oqwo5dQ46PMX90EPdgY/faPPJS0qChqiZbde4lwSBDy103IngaT3b2uBn/RyxhQ1soyTbTWDC1icYWIYrYM9eaX0wD1fsJc+xVQUvL7v29KkF4ptjXNm2DIkF6c4RZ7g4ZHAGaqjc/tGoCE27WDurrQNQ/FOzSp+wojapxQerB1m5OMmnbu1uQnS3FjkCdFZN/It4MJjmb6ZX+ieTONlKnqwZWer9L74JH6RPCHO+GCsuCaT0kgKLZxMXGZsdsQR5scwmFIjIX5ANIrwfDaNZierDWhX3sUtuK8XOmCMyeH5uzRSd+i6 6wSi5oUn S2e+jSd95Dlp4Ov0bmee13w2aGrsg8NJ20IEZP+mwZXWo6+rGjVzmMYCysaqoYDb6rN0ujM2cBuS42FjBOBE70z2z/crwaTeFuYzNcLwp8ZrVyA/CRJzChpYXkPOQmH6VMom/igdMwucRFKD0FyN6F4I6lsxwrN6Xxli/QrGTYCgIdjCXzieAD6qPLNbo05Z/9M7FO+cvPoB2QQ01hUW0m3AP/laGpCmXKncJ8H8TBkDSffU/RIvvXfoSoS2hzzyoTD1NQMMx47HEt28UxULql5Fs7w== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000001, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: Use damos->ops_filters_default_reject, which is set based on the installed filters' behaviors, from physical address space DAMON operations set. Signed-off-by: SeongJae Park --- mm/damon/paddr.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mm/damon/paddr.c b/mm/damon/paddr.c index dded659bb110..fba8b3c8ba30 100644 --- a/mm/damon/paddr.c +++ b/mm/damon/paddr.c @@ -260,7 +260,7 @@ static bool damos_pa_filter_out(struct damos *scheme, struct folio *folio) if (damos_pa_filter_match(filter, folio)) return !filter->allow; } - return false; + return scheme->ops_filters_default_reject; } static bool damon_pa_invalid_damos_folio(struct folio *folio, struct damos *s) From patchwork Tue Mar 4 21:19:13 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: SeongJae Park X-Patchwork-Id: 14001431 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 43075C282D3 for ; Tue, 4 Mar 2025 21:19:41 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 6387A6B009E; Tue, 4 Mar 2025 16:19:30 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 5C3076B009F; Tue, 4 Mar 2025 16:19:30 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 412396B00A0; Tue, 4 Mar 2025 16:19:30 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0014.hostedemail.com [216.40.44.14]) by kanga.kvack.org (Postfix) with ESMTP id 1ECEB6B009E for ; Tue, 4 Mar 2025 16:19:30 -0500 (EST) Received: from smtpin22.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay02.hostedemail.com (Postfix) with ESMTP id D1A7D12065B for ; Tue, 4 Mar 2025 21:19:29 +0000 (UTC) X-FDA: 83185134858.22.51ABA0A Received: from nyc.source.kernel.org (nyc.source.kernel.org [147.75.193.91]) by imf24.hostedemail.com (Postfix) with ESMTP id 05BBB18000E for ; Tue, 4 Mar 2025 21:19:27 +0000 (UTC) Authentication-Results: imf24.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=H+yFtLDF; spf=pass (imf24.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741123168; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=eqxFwr1YF/5aKyOTrxEZTybI/ra9eSf1gDz823CD7H8=; b=SeYCO1Tmq2C4mOoSz7DOyvcN5u9an8mSplBz1MI4BStJE8iucVYaR6oETjYDa9Gu2FD2/A 673q/qcMq78I9ZwmQ4OsOD/H06x7YU47EkzqBMurq9Es+iAJcGty670+2s0wtA2OmwQLU5 5lXYIXniDW5P0a+tDFesehOPmsbp9os= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741123168; a=rsa-sha256; cv=none; b=QYp0m8Ko61HWkEV3ayyMjtTv036NqpSOTKQmCnUVGWknR78sj9WHMlUPcKNrvDt00ewfCo wuIl5kgUs6lOH1AHx8qdq4E+92Az1m4/XI2cfcdFtVZQpEkaDQOAUanw/lMdL6pCxAuzix QtNtrL5cP+MwU/uz2w2tAGdlgiCqHdE= ARC-Authentication-Results: i=1; imf24.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=H+yFtLDF; spf=pass (imf24.hostedemail.com: domain of sj@kernel.org designates 147.75.193.91 as permitted sender) smtp.mailfrom=sj@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by nyc.source.kernel.org (Postfix) with ESMTP id 92CF6A45FA9; Tue, 4 Mar 2025 21:13:56 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 1049CC4CEE5; Tue, 4 Mar 2025 21:19:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1741123167; bh=MvYdk6+CJs1x3c6be1UzpWng25V7d78Qpub9AKz7s0w=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=H+yFtLDFGNtuTNbyJUs+cxgvACAguJ1tXWM+lVJ7fZHcH3tKreNyIYL/74ILQnPBF LlTEEqtW0LpjlYbcTMRDaiB0S8R5VwCl0QAmj4+m4Z/cMKj7SnTTIZH0u0dGbq15km XK8ubi0/sZefriDo97HjeujAKsKrZA4rtUA6leE6Z7jQFr81uQtBYPxTRh9QM6VEcw DhPEPbOV8b4U43JYDC4igFQ6atTlB4hhQLvgcCwUjdYDOoZC7ifnG4fpihSm5GpHwY YejZz9hEeZTh1c0n966bcFw8g722XNw6Lg6sL9DBfHXMS2xhiBKamFd/HXqSdbxpZn +/ver5JBcmoZQ== From: SeongJae Park To: Andrew Morton Cc: SeongJae Park , Jonathan Corbet , damon@lists.linux.dev, kernel-team@meta.com, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: [PATCH 9/9] Docs/mm/damon/design: update for changed filter-default behavior Date: Tue, 4 Mar 2025 13:19:13 -0800 Message-Id: <20250304211913.53574-10-sj@kernel.org> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250304211913.53574-1-sj@kernel.org> References: <20250304211913.53574-1-sj@kernel.org> MIME-Version: 1.0 X-Rspamd-Server: rspam02 X-Stat-Signature: irrkpg4twnepoqcz67rbbkd6mnus5h8b X-Rspamd-Queue-Id: 05BBB18000E X-Rspam-User: X-HE-Tag: 1741123167-660497 X-HE-Meta: U2FsdGVkX18errwJKzFRf0pQwDBgqfQk8za4AWtdVWqsmdQ++8Gs0CO4uLGNKGm9l5yQ/iywqf0T0HVI9UntLXxaf01Bkim0teg4nrbbKLVZ2PoT7K3XIazkzjeBSmA6zW0G9ZQaHsmmSW25qA4SgZlo3kfIpUZhYj0Ket51ZzCD+09owss/c3e6VDfGGJkUkhi6j4vEl48+zT5nXWt93RaZziXAqVlCXs6AZIwqa+bU7TKpNq5L9340CErv6yIWd2H2cb5wGrgLQKGY2VypA12/1uA2ww8q9wwjjLHL79KiopYpNtykILm5WoU3GP452Kd0sbbVnSZOrG50eWYXsJFOatJxAbRBP2fUkXwQGwLe7io1J5oF/3stivIOT9jOSAMRE1xoNVnRt857en5Il1uvh9dncWX4bvfdecMb1fKY7O/a2JYjqzzxirApMstaHu7YQlmXZGWFI09o0gAPy+lMY3zi6OkcHs8O9dr4TMMYi9n4Ns+Tq/swhv3KNQmwcocepm8aN2wkrTP23X4g/O1Zy6/XYvDY5K0+cipUk9yH6+BhOP9TIK36aYOG01zQWZo6VHazO2BXlvDaXZu31Iql63lziXXGgeqzD+D2Al2RRiHfMGQg5ZbujNuwcEET5ao6/UQDdchSievsgAeAoApOR4RAT+FqQKC+gvxLx3S7qi2wINlGXCMIwETa5tp7zVN/XdOVoma+eZlnvCMWW2j8+tZNtTfWrqHGc/29uPEYQWVnHrW8cpKMBs+cAjaExDomr9LKqaaLB/MskMuRRivn7npzg6nwvSwNXvPtiavSw97W39fA+Bf9sc6GmJiXoDE3TeJBW9LeKGlA2ri9qc8BtrDU6ny7/9NB+VGJTa9+2auA9fh/azqxewnflqKRhTbIyl3ML+OE6nhmVdz7eSVQ6RyvWA2V8D3FWPYHGeSym4kXm+hpstZ1UOn0cgk0fS8zFKE5F+rYal6QJeK vaN89WdR y8c72YFhetjkP7MXf0NUf6VskLWE9V4fKFCSr2ILwoNpsb+P5WGbgsWre8gyB67XMrYT/MVLUvki6rAm/zEOQB7hglWDBrfWn4Do8geir8nWUR5vzcCS8TRkLMWpAQ87269wkkdMsEsLGsmFeASC640QMNim0ECNO2dMc3UDUE7AGFuqprm6WKNXGlKLc6E6idz8rEakZLy7ZTiQeh1B87HgBR8DaeoLTFXUKbgjpg8IAaMc= X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: Update the design documentation for changed DAMOS filters default allowance behaviors. Signed-off-by: SeongJae Park --- Documentation/mm/damon/design.rst | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/Documentation/mm/damon/design.rst b/Documentation/mm/damon/design.rst index 26c9ab10daf7..0cf678d98b1b 100644 --- a/Documentation/mm/damon/design.rst +++ b/Documentation/mm/damon/design.rst @@ -631,9 +631,10 @@ When multiple filters are installed, the group of filters that handled by the core layer are evaluated first. After that, the group of filters that handled by the operations layer are evaluated. Filters in each of the groups are evaluated in the installed order. If a part of memory is matched to one of the -filter, next filters are ignored. If the memory passes through the filters +filter, next filters are ignored. If the part passes through the filters evaluation stage because it is not matched to any of the filters, applying the -scheme's action to it is allowed, same to the behavior when no filter exists. +scheme's action to it depends on the last filter's allowance type. If the last +filter was for allowing, the part of memory will be rejected, and vice versa. For example, let's assume 1) a filter for allowing anonymous pages and 2) another filter for rejecting young pages are installed in the order. If a page @@ -645,11 +646,6 @@ second reject-filter blocks it. If the page is neither anonymous nor young, the page will pass through the filters evaluation stage since there is no matching filter, and the action will be applied to the page. -Note that the action can equally be applied to memory that either explicitly -filter-allowed or filters evaluation stage passed. It means that installing -allow-filters at the end of the list makes no practical change but only -filters-checking overhead. - Below ``type`` of filters are currently supported. - Core layer handled