From mboxrd@z Thu Jan 1 00:00:00 1970 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 A60E2C0218D for ; Wed, 29 Jan 2025 16:44:38 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 124F8280018; Wed, 29 Jan 2025 11:44:38 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 0D5DD280011; Wed, 29 Jan 2025 11:44:38 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id EB7C4280018; Wed, 29 Jan 2025 11:44:37 -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 CC6F5280011 for ; Wed, 29 Jan 2025 11:44:37 -0500 (EST) Received: from smtpin24.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay02.hostedemail.com (Postfix) with ESMTP id 83BD8120F33 for ; Wed, 29 Jan 2025 16:44:37 +0000 (UTC) X-FDA: 83061062994.24.59BD6D6 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by imf11.hostedemail.com (Postfix) with ESMTP id F1BAB40010 for ; Wed, 29 Jan 2025 16:44:34 +0000 (UTC) Authentication-Results: imf11.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=JorrZU1A; spf=pass (imf11.hostedemail.com: domain of david@redhat.com designates 170.10.133.124 as permitted sender) smtp.mailfrom=david@redhat.com; dmarc=pass (policy=none) header.from=redhat.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1738169075; 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-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=n2Gu/Qndi7yO7ZvaM1m+DLy9qwHQqccsR3SY/PKWVEo=; b=RxHRUy9dmpdjL352t9KLoY2MCt+gB4RdueSLzuVngYV2KnLoezwVsg7NVzW8okBaPQDSij g1grCQZMvxkVh8WQavWJ6/BCYjBmse4ytH+QnYp26So+5Ua/9u5IgKIUCuHjXCm6PwHIIU imoiwtWCHWPwCiHu95QE/E74ezttXII= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1738169075; a=rsa-sha256; cv=none; b=h3Ywl381b7D2UG88pa7RV84BJCeHwyVXqzM057aUA9s5vHiNyORW0rRJniYNv0VhawDJC7 VfgyMBiLEoaxMa5fvujpJkEkXN9xn0FNbQTcGpJFNjPgrOVZbDye1vQanW611bGQPASnUV eQTHcaZAd939nW9kQYN76UlwdvvvdXM= ARC-Authentication-Results: i=1; imf11.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=JorrZU1A; spf=pass (imf11.hostedemail.com: domain of david@redhat.com designates 170.10.133.124 as permitted sender) smtp.mailfrom=david@redhat.com; dmarc=pass (policy=none) header.from=redhat.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1738169074; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:autocrypt:autocrypt; bh=n2Gu/Qndi7yO7ZvaM1m+DLy9qwHQqccsR3SY/PKWVEo=; b=JorrZU1AyXPjI0TuY0DQ1DSMkNjwx2+SpF9npVtnOLE9oIVFKZf9h/Xp7MOxiOBa7h94nW WlHrdLrXRnWU3wKpon21wan1iIhNYitw9ZOsJEbmS/1OMKV0cMan1c7gNTvv/L/adPHKO/ CqK7PbDjbfB/N3I/meOnO5F1NqAF5f4= Received: from mail-wr1-f71.google.com (mail-wr1-f71.google.com [209.85.221.71]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-582-JJ26qqeJOAy1Js16ez8fAQ-1; Wed, 29 Jan 2025 11:44:33 -0500 X-MC-Unique: JJ26qqeJOAy1Js16ez8fAQ-1 X-Mimecast-MFC-AGG-ID: JJ26qqeJOAy1Js16ez8fAQ Received: by mail-wr1-f71.google.com with SMTP id ffacd0b85a97d-38639b4f19cso4711082f8f.0 for ; Wed, 29 Jan 2025 08:44:32 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1738169072; x=1738773872; h=content-transfer-encoding:in-reply-to:organization:autocrypt :content-language:from:references:cc:to:subject:user-agent :mime-version:date:message-id:x-gm-message-state:from:to:cc:subject :date:message-id:reply-to; bh=n2Gu/Qndi7yO7ZvaM1m+DLy9qwHQqccsR3SY/PKWVEo=; b=d0e4H37iZWFkypgFLmT1zFXpmaRHnowqm1/WlzuuYO/Dxj4Bpv/KEVwf0JDd5anr/7 Nhxy+DwZQW+5vfobz8SHGVWmCfoRdLcH2JoB1CBQKhwTjufVi6CsrczglEwiCar7GTQ6 KF5Oxm+2xyUVI6QMVdsd/VWrdO8jNZOGB9efYKpRdXjIaF4iNfn5cNX3TNC6IwRvg217 YILmUc2LEumAE7iaXTo5Ys9Jh3eZj+EH9JXSpJ8Nxx+A+jqxTKLGbAPfmNA+9uTJNNZa Eu3Ht+fbt0gWSAzGCfypkswlGtCroD8Re4dBQmo/PvFDVser2JdkD+3CtMrDMcQJjJwk e0lw== X-Forwarded-Encrypted: i=1; AJvYcCUGwvJYU5E1RsnY//JHx04HpYSPMSX/KtZVQy3iUBha5Pv+hGJyY74IXOzxGz/gdLQ7h1pQhY4dIg==@kvack.org X-Gm-Message-State: AOJu0YwR9HgZ+Askal6lJPDONLTDt8/G7HCcG0isoQo/Zv/ij5/o+bt4 F0aHlEn5nChe6WLeiFaxRibALlMCQBTxZ24qlc8jKj1SQLQlljNdsJAg8MYiBLTkoy9t9fDQoBd TTMhARzTvMuaD7UGul2q4MvxtTItE1aFHoVhJWuIQvAbZwDky X-Gm-Gg: ASbGnct2PH+sOZe/4Ti7dyzATRK018J1RJ1lDavznKtH3q0JdTiraZSjlVw9FmgFtDt +54JVY3ZHTp+NaG/zm7n1Rl+WquXOlsRCu7laI/Pav6wIEauDzQ69HWOedY5S7/+p6U2Vcky3UN xV9+xKZXS3kqyvuDJXbZbW4N7B3IFls30FiUyjPnNt7Fw2WjIa+DbVvrg7SRiLl8gzzYixhVhOC nk1O8VSedrk7m9wE4FA03J0AuluN9nOgWlTRm2xChIoi39Vmbf2MDFjYhQd/teJI6wv4BcklOqS 2bjAuf+wo1BY/RklWIlpeGTCMBmEXK/mVh4G9Et9KQE+4bCt05zU5r8hT7kdZegkFZDVTWTZPcd hgqeIjRBviVzMiHcLjlvH1mEFJsu7EvxG X-Received: by 2002:a5d:47cd:0:b0:385:e88a:7037 with SMTP id ffacd0b85a97d-38c51939740mr3757649f8f.6.1738169071672; Wed, 29 Jan 2025 08:44:31 -0800 (PST) X-Google-Smtp-Source: AGHT+IFQ/HByK/JSFhUNIQvMI8OQ7ivI9bcSi2qkGn2ioLNG8d6ynmmuXYyQBCxcKRDb1NWjGC37Zw== X-Received: by 2002:a5d:47cd:0:b0:385:e88a:7037 with SMTP id ffacd0b85a97d-38c51939740mr3757626f8f.6.1738169071305; Wed, 29 Jan 2025 08:44:31 -0800 (PST) Received: from ?IPV6:2003:cb:c705:3b00:64b8:6719:5794:bf13? (p200300cbc7053b0064b867195794bf13.dip0.t-ipconnect.de. [2003:cb:c705:3b00:64b8:6719:5794:bf13]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-438dcc2e384sm29647105e9.19.2025.01.29.08.44.29 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 29 Jan 2025 08:44:30 -0800 (PST) Message-ID: <2d0eeca2-7875-415b-b20f-cebebce70f50@redhat.com> Date: Wed, 29 Jan 2025 17:44:28 +0100 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH] damon: add feature to monitor only writes To: SeongJae Park , Pedro Demarchi Gomes Cc: damon@lists.linux.dev, linux-kernel@vger.kernel.org, linux-mm@kvack.org References: <20250129055237.38547-1-sj@kernel.org> From: David Hildenbrand Autocrypt: addr=david@redhat.com; keydata= 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 WNyWQQ== Organization: Red Hat In-Reply-To: <20250129055237.38547-1-sj@kernel.org> X-Mimecast-Spam-Score: 0 X-Mimecast-MFC-PROC-ID: eYSZC6wXd2wB3A6AKUHj228vgzepYM3LcXMHjiTiJf4_1738169072 X-Mimecast-Originator: redhat.com Content-Language: en-US Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Stat-Signature: fkupr4af4ktt9cg8y7a8pjznyk9oy5jt X-Rspam-User: X-Rspamd-Queue-Id: F1BAB40010 X-Rspamd-Server: rspam03 X-HE-Tag: 1738169074-763210 X-HE-Meta: U2FsdGVkX1+ktMhp2PXE2xXrnYohQnjcZDgpGWwajkICk9U2a+DhB3naQ220vAlqoWXe9rVMiBF6M4KnhRg46mejsVf0JckTDnaXo9gncZPWWEW/0Csgv0dfjVmfzH0iHTrE9nyRVHlRZZtT0ogkuRyAh3pYjJWwsL46V4DvLtoOVGildGX0PlfLmZNj8Ns68TxZtGDrI83UN3fMMm0cVnAU8vIsovE+d6YNqutCPh9BAzw9fsVBo8qOmCO7tVm8/GwHR4qtBI0RMWsjKGuKkIPq7uwZwuJS9FuIiX5lqf07pYKRk2fLR3MoCsTmPv6eGyTz1pfXVYBGMEzZbFrnDCQYiA2YyYLPxWW1fA1w9F5F5DBhsKZBU4p4LHFetp2LAusZ9FbLPqeFn0+c5E6deHdFSz0ByNaZXqVZXzJbVk9wsfHSu7+VaiFIr0RbT4s/B2+H0qKJnz/RjHfkiVTsoMu2pMszm3yL510dS/IovlrFdVucDB+W/35PZfbC8q7bQpS1IuvRh1hUi9oWUO66sNKrVady9TO8uaAm2X0WqPBFdPKUciHr8jQrbchScF1p2UjtNqxMws2N5ZX1m96JvOqHXHNIdEXiOJMb0ejZidE9kBdrL1QHFy4L8AS7y7WAQoIE8l0YivH0jExD6y0klZYXIxa0+px3m73U5IiMO0wm/4kbDVrLQzx6CgRhWcu9SThQIsyZZyZPBwDNr4jkedpyhHPYGMa4jRND9D1D17WOQVKGNssDQGT7WIlr2Zk6E5YrFcwUtgY1bZreW26G3Dr6wV4lJBGA0L0swMk8ttIAUqbj2fktCi3wq4jvaWofILbi1cRznzjVIIFJoKi3ZtYcusxQcbbVZHSxilyot114t6Mzm9yOufQV8smGzBHIoaPDjyz7HtOwt2n5ScNcswDlp7ywaP3SwXFqRuULb16KtjWpLHB7hXn9HSq1TPUB8zihd/5weNzoy8J3ENn ytLJ5mHF ZugJdqZ4mPAGqfhhZMkKBrISiHCHOncoib/09GNyjWOxAU2rXsP0+9ednl+dsOsTahfX9kHeWPqETk7JvFn1eu70Bc4ZYMAqzG4ezA77lQ/xYqA+034ID1NO/5z5Uv/YMuIWz0XyChMp03w/laxqx5mOGPDLbuZ5nw8NBborL0wAsTllWm75AIpZ0ErwgWJUnqmvYBeiYYarZxXlgnaSWIvIQ21CG3CIhLa0JSp7p7Mq9BJ99YN0c13C2ba4EHAQRwrYNmFd2BBg916GUvDeEJit4FdONL4i316kl60rvDil0EUPjfQF+zmD6RQ6c5zLFNv/6MRw0FtvtRlqm1sKPfOl7CSZxQV51fnfmI/DAGwuhEeDjgovf/1zZvboToXpyNJ5A2i8zHWx4VKyhzQEy29YN8LOx3pmayonxbs1qqjtBslYKP6bbrQ608LTOByFM2ejHJQg8nGrn6c5o8J6HU9PJ3A== 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: On 29.01.25 06:52, SeongJae Park wrote: > + linux-mm@ and David > > Hi Pedro, > > On Wed, 29 Jan 2025 01:40:41 -0300 Pedro Demarchi Gomes wrote: > >> Add damon operation DAMON_OPS_VADDR_WRITES to monitor only writes. > > Thank you for this patch! I think this is a successor of the patch[1] that you > posted before. Thank you very much for continuing this work. > > Nonetheless, could you please add more description about this patch including > changes you made from the previous version? I'm especially curious if the > concern[2] that David raised to the previous version is solved. The CoW concern is resolved upstream now. You can convert pte_write(pte) -> !ptw_write(pte) without risking weird interactions with DMA etc. > Motivation of > this patch including expected usage (I remeber that you mentioned using this > feature to find KSM-candidate memory regions, but I'm curious if you found more > potential usages) and test/evaluation results if available. > > Adding comments below to things that stand out to my eyes on a glance. > > [1] https://lore.kernel.org/lkml/20220203131237.298090-1-pedrodemargomes@gmail.com/ > [2] https://lore.kernel.org/dcb5d9c7-ae5c-e0c5-adee-37f5b92281e0@redhat.com > >> >> Signed-off-by: Pedro Demarchi Gomes >> --- >> include/linux/damon.h | 5 +- >> mm/damon/Makefile | 2 +- >> mm/damon/ops-common.c | 80 +++++ >> mm/damon/ops-common.h | 3 + >> mm/damon/sysfs.c | 1 + >> mm/damon/vaddr-writes.c | 735 ++++++++++++++++++++++++++++++++++++++++ >> 6 files changed, 824 insertions(+), 2 deletions(-) >> create mode 100644 mm/damon/vaddr-writes.c >> >> diff --git a/include/linux/damon.h b/include/linux/damon.h >> index af525252b853..9a6027faa7a6 100644 >> --- a/include/linux/damon.h >> +++ b/include/linux/damon.h >> @@ -485,6 +485,7 @@ struct damos { >> * enum damon_ops_id - Identifier for each monitoring operations implementation >> * >> * @DAMON_OPS_VADDR: Monitoring operations for virtual address spaces >> + * @DAMON_OPS_VADDR_WRITES: Monitoring only write operations for virtual address spaces >> * @DAMON_OPS_FVADDR: Monitoring operations for only fixed ranges of virtual >> * address spaces >> * @DAMON_OPS_PADDR: Monitoring operations for the physical address space >> @@ -492,6 +493,7 @@ struct damos { >> */ >> enum damon_ops_id { >> DAMON_OPS_VADDR, >> + DAMON_OPS_VADDR_WRITES, >> DAMON_OPS_FVADDR, >> DAMON_OPS_PADDR, >> NR_DAMON_OPS, >> @@ -846,7 +848,8 @@ int damon_select_ops(struct damon_ctx *ctx, enum damon_ops_id id); >> >> static inline bool damon_target_has_pid(const struct damon_ctx *ctx) >> { >> - return ctx->ops.id == DAMON_OPS_VADDR || ctx->ops.id == DAMON_OPS_FVADDR; >> + return ctx->ops.id == DAMON_OPS_VADDR || ctx->ops.id == DAMON_OPS_VADDR_WRITES >> + || ctx->ops.id == DAMON_OPS_FVADDR; >> } >> >> static inline unsigned int damon_max_nr_accesses(const struct damon_attrs *attrs) >> diff --git a/mm/damon/Makefile b/mm/damon/Makefile >> index 8b49012ba8c3..c3c8dce0b34a 100644 >> --- a/mm/damon/Makefile >> +++ b/mm/damon/Makefile >> @@ -1,7 +1,7 @@ >> # SPDX-License-Identifier: GPL-2.0 >> >> obj-y := core.o >> -obj-$(CONFIG_DAMON_VADDR) += ops-common.o vaddr.o >> +obj-$(CONFIG_DAMON_VADDR) += ops-common.o vaddr.o vaddr-writes.o >> obj-$(CONFIG_DAMON_PADDR) += ops-common.o paddr.o >> obj-$(CONFIG_DAMON_SYSFS) += sysfs-common.o sysfs-schemes.o sysfs.o >> obj-$(CONFIG_DAMON_RECLAIM) += modules-common.o reclaim.o >> diff --git a/mm/damon/ops-common.c b/mm/damon/ops-common.c >> index d25d99cb5f2b..4a3cad303a60 100644 >> --- a/mm/damon/ops-common.c >> +++ b/mm/damon/ops-common.c >> @@ -9,6 +9,8 @@ >> #include >> #include >> #include >> +#include >> +#include >> >> #include "ops-common.h" >> >> @@ -67,6 +69,84 @@ void damon_pmdp_mkold(pmd_t *pmd, struct vm_area_struct *vma, unsigned long addr >> #endif /* CONFIG_TRANSPARENT_HUGEPAGE */ >> } >> >> +static inline bool pte_is_pinned(struct vm_area_struct *vma, unsigned long addr, pte_t pte) >> +{ >> + struct folio *folio; >> + >> + if (!pte_write(pte)) >> + return false; >> + if (!is_cow_mapping(vma->vm_flags)) >> + return false; >> + if (likely(!test_bit(MMF_HAS_PINNED, &vma->vm_mm->flags))) >> + return false; >> + folio = vm_normal_folio(vma, addr, pte); >> + if (!folio) >> + return false; >> + return folio_maybe_dma_pinned(folio); >> +} >> + >> +static inline void clear_soft_dirty_pmd(struct vm_area_struct *vma, >> + unsigned long addr, pmd_t *pmdp) >> +{ >> + pmd_t old, pmd = *pmdp; >> + >> + if (pmd_present(pmd)) { >> + /* See comment in change_huge_pmd() */ >> + old = pmdp_invalidate(vma, addr, pmdp); >> + if (pmd_dirty(old)) >> + pmd = pmd_mkdirty(pmd); >> + if (pmd_young(old)) >> + pmd = pmd_mkyoung(pmd); >> + >> + pmd = pmd_wrprotect(pmd); >> + pmd = pmd_clear_soft_dirty(pmd); >> + >> + set_pmd_at(vma->vm_mm, addr, pmdp, pmd); >> + } else if (is_migration_entry(pmd_to_swp_entry(pmd))) { >> + pmd = pmd_swp_clear_soft_dirty(pmd); >> + set_pmd_at(vma->vm_mm, addr, pmdp, pmd); >> + } >> +} >> + >> +static inline void clear_soft_dirty(struct vm_area_struct *vma, >> + unsigned long addr, pte_t *pte) >> +{ >> + /* >> + * The soft-dirty tracker uses #PF-s to catch writes >> + * to pages, so write-protect the pte as well. See the >> + * Documentation/admin-guide/mm/soft-dirty.rst for full description >> + * of how soft-dirty works. >> + */ >> + pte_t ptent = *pte; >> + >> + if (pte_present(ptent)) { >> + pte_t old_pte; >> + >> + if (pte_is_pinned(vma, addr, ptent)) >> + return; >> + old_pte = ptep_modify_prot_start(vma, addr, pte); >> + ptent = pte_wrprotect(old_pte); >> + ptent = pte_clear_soft_dirty(ptent); >> + ptep_modify_prot_commit(vma, addr, pte, old_pte, ptent); >> + } else if (is_swap_pte(ptent)) { >> + ptent = pte_swp_clear_soft_dirty(ptent); >> + set_pte_at(vma->vm_mm, addr, pte, ptent); >> + } >> +} > > Seems you're copying code from task_mmu.c to here. Can you explain why you do > so instead of making those be able to use from other files and reuse? +1 This code should not be copied in that way. I am not sure, though, if the interaction between both interfaces is actually desirable, and if the interaction with VM_SOFTDIRTY is properly taken care of here. soft-dirty is not something that I am particularly exited to see getting used more and in different context. -- Cheers, David / dhildenb