Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp460318ybh; Tue, 10 Mar 2020 02:03:45 -0700 (PDT) X-Google-Smtp-Source: ADFU+vvTgQ6Ar2I2lgo7NCsHpcEtkcPNh3FpX7PD506MMdmIOOw4CN2U+kifO5H4QM84gn9rIeRx X-Received: by 2002:a9d:18f:: with SMTP id e15mr13406198ote.42.1583831025112; Tue, 10 Mar 2020 02:03:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1583831025; cv=none; d=google.com; s=arc-20160816; b=LE5wVeGlxVQxyjPubOeqtJ4QGeIdpFHkySl+l5dI4skILpBQooSe6xZR5RPM+xjJC4 2uBeCaRghoDKuiO6lUane4qqcKNPYpVtZzbke5AAP0BAmQOOyGvjv61uu9DnB4ewb2iU kYQXWGSQJPLLV8RG1tyvqFQAhDoHXvN5mu0GnBgE0j93t8UU/o/oR4C39eVItH1Xyam3 1qRhMfbMKSjdPCMTxIMhkS2FFa3hZruqfbhZa6XSuPDxLZfXH0zfZfXsMHDn8dVpsIHK 6QwvpIqhl5Jp5kPLX6/l1hPeK1XKFalNEQLAx3iDOlJTH1t339mNvoYVWSgazaPdc480 jXXQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :organization:references:in-reply-to:message-id:subject:cc:to:from :date; bh=F8GondhFVTzO0lUpjWfsYL9H645LnbIBCOaT3ImdJ+4=; b=q3gm22skgy3nHcQJ/73m1wROMweREheIa/3UYgZ9/8cdCdAR1DS4dp30+24lmeCEKX /OgVmcvx29VKcQUq+/fY4gEs0aSQGlxGtVMxFm4edBI/9C8Dt7qKd0dSsATr9hGy4Udh khLdIZxi732uV9BRi+R6p3ui7VrM4T+col55Q6DI5DE0DokgqwH7H99PzHDhD1/fmGNn MPVmjVCkKyrxXCAGU+d+JocPnyPilCHKmJEXw1dcReHO+IEJqW12XWEWKIM3oEiRN6r8 8EWnw2GMiommNpXXGs741AtYz0VrYzeKoBHrxrVZFmKTGwg9X4FyVR1k6aWA15WVxJIz O3FA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l4si7396989otj.173.2020.03.10.02.03.09; Tue, 10 Mar 2020 02:03:45 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726697AbgCJJBd (ORCPT + 99 others); Tue, 10 Mar 2020 05:01:33 -0400 Received: from lhrrgout.huawei.com ([185.176.76.210]:2534 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726389AbgCJJBd (ORCPT ); Tue, 10 Mar 2020 05:01:33 -0400 Received: from lhreml705-cah.china.huawei.com (unknown [172.18.7.106]) by Forcepoint Email with ESMTP id 1AB38615AD1B600B7010; Tue, 10 Mar 2020 09:01:32 +0000 (GMT) Received: from lhreml710-chm.china.huawei.com (10.201.108.61) by lhreml705-cah.china.huawei.com (10.201.108.46) with Microsoft SMTP Server (TLS) id 14.3.408.0; Tue, 10 Mar 2020 09:01:18 +0000 Received: from localhost (10.202.226.57) by lhreml710-chm.china.huawei.com (10.201.108.61) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5; Tue, 10 Mar 2020 09:01:18 +0000 Date: Tue, 10 Mar 2020 09:01:16 +0000 From: Jonathan Cameron To: SeongJae Park CC: , SeongJae Park , , , , , , , , , , , , , , , , , , , , , , , , , , , , , Subject: Re: [PATCH v6 05/14] mm/damon: Implement callbacks Message-ID: <20200310090116.0000723f@Huawei.com> In-Reply-To: <20200224123047.32506-6-sjpark@amazon.com> References: <20200224123047.32506-1-sjpark@amazon.com> <20200224123047.32506-6-sjpark@amazon.com> Organization: Huawei Technologies Research and Development (UK) Ltd. X-Mailer: Claws Mail 3.17.4 (GTK+ 2.24.32; i686-w64-mingw32) MIME-Version: 1.0 Content-Type: text/plain; charset="US-ASCII" Content-Transfer-Encoding: 7bit X-Originating-IP: [10.202.226.57] X-ClientProxiedBy: lhreml715-chm.china.huawei.com (10.201.108.66) To lhreml710-chm.china.huawei.com (10.201.108.61) X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 24 Feb 2020 13:30:38 +0100 SeongJae Park wrote: > From: SeongJae Park > > This commit implements callbacks for DAMON. Using this, DAMON users can > install their callbacks for each step of the access monitoring so that > they can do something interesting with the monitored access pattrns patterns > online. For example, callbacks can report the monitored patterns to > users or do some access pattern based memory management such as > proactive reclamations or access pattern based THP promotions/demotions > decision makings. > > Signed-off-by: SeongJae Park > --- > mm/damon.c | 8 ++++++++ > 1 file changed, 8 insertions(+) > > diff --git a/mm/damon.c b/mm/damon.c > index 6a17408e83c2..554720778e8a 100644 > --- a/mm/damon.c > +++ b/mm/damon.c > @@ -83,6 +83,10 @@ struct damon_ctx { > struct rnd_state rndseed; > > struct list_head tasks_list; /* 'damon_task' objects */ > + > + /* callbacks */ > + void (*sample_cb)(struct damon_ctx *context); > + void (*aggregate_cb)(struct damon_ctx *context); > }; > > /* Get a random number in [l, r) */ > @@ -814,9 +818,13 @@ static int kdamond_fn(void *data) > } > mmput(mm); > } > + if (ctx->sample_cb) > + ctx->sample_cb(ctx); > > if (kdamond_aggregate_interval_passed(ctx)) { > kdamond_merge_regions(ctx, max_nr_accesses / 10); > + if (ctx->aggregate_cb) > + ctx->aggregate_cb(ctx); > kdamond_flush_aggregated(ctx); > kdamond_split_regions(ctx); > }