Received: by 2002:a05:6358:bb9e:b0:b9:5105:a5b4 with SMTP id df30csp4573290rwb; Tue, 6 Sep 2022 09:18:53 -0700 (PDT) X-Google-Smtp-Source: AA6agR7oASJcJNXVpCFQBOwDFDvzNUx3UcOX9QRWv+WzZSNp7QhwvE016cL+L7m40Jzsc38GhzIf X-Received: by 2002:a63:475d:0:b0:430:120:18d0 with SMTP id w29-20020a63475d000000b00430012018d0mr28782460pgk.563.1662481133683; Tue, 06 Sep 2022 09:18:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662481133; cv=none; d=google.com; s=arc-20160816; b=sM8LOrsxAD8mioeTy23AUKunttZV4bvj261+fga19eZWjG23bjMBjtuqKU53RFhCSv vFefv9yfZLvgkye0jVkwLqu2sM8GAm/2mZe9+XLSlV6AWJwRnKJF46ORf9UbWMZEkKnM A+lg/YYpQMPn6E9UNiH0Yjimxuuvaj3x7z66tLfydlNqZPjipLhovbCCqopQkSvk6QJu dXApoLqbKsyb9nBE/l2YaqHUQmgiVYjbYxFt+qCgjXF5c/N2hcuCrcMdySrPPj1pJK6H BfMREcK1E3CAbGVYI1nj7kRfOXgjFtBLeculbzz7LplQ44ZGj/ZzwdjrdmJLEz96icFa Ud8w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from :dkim-signature; bh=1NDwLaBCs5nhmRz61i3eAQ3IF542diGapeEzK/fCX5o=; b=qsL72RqOzq2RW+CYMz9mqggrB/QkjpKWHjH9qQqQdhY+xVCOHriMgCx0V4/Xd9dSzx YSKiZ6dVBopNrTFwDPfOmtSTpvANuiFsxDvGzfKIXM0TDYuVR6zwkCxbGagJgGIXPE7e DWEjxU3CFU40gQ+DF13QkekW3wivLh2RFC5MricrgFQeuXGZVTM/fk6yo4Rwm/pp68Qu 52WWGLnMKR7Q2NLgxPiOQTbwMUzOojk7gCnAR/LXHVUpUh5fFnr1K5Xd4YgkjKAQ7gAd wvPHGQ9bjBwDo889lktp6uU4ZdK4wFjIrkSZMIn1IRqR7nuYs+r+40+Z/lAjDPjEb5tL INYw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=Zo5lCexy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nn16-20020a17090b38d000b001f2757da25asi14008763pjb.91.2022.09.06.09.18.41; Tue, 06 Sep 2022 09:18:53 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=Zo5lCexy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233696AbiIFQAt (ORCPT + 99 others); Tue, 6 Sep 2022 12:00:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40288 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233660AbiIFQAR (ORCPT ); Tue, 6 Sep 2022 12:00:17 -0400 Received: from mail-pj1-x102a.google.com (mail-pj1-x102a.google.com [IPv6:2607:f8b0:4864:20::102a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 67E723AB00 for ; Tue, 6 Sep 2022 08:19:55 -0700 (PDT) Received: by mail-pj1-x102a.google.com with SMTP id q3so11635217pjg.3 for ; Tue, 06 Sep 2022 08:19:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=message-id:date:subject:cc:to:from:from:to:cc:subject:date; bh=1NDwLaBCs5nhmRz61i3eAQ3IF542diGapeEzK/fCX5o=; b=Zo5lCexyWBldwLJNn337E+X4XjLh3CKtHzTEdaQ/ECk+dhSOKS4DnmcGXPxy+tuk+U DUV5mZGpHmWJrRWFmITH9tJPsFe1PisCnZYzDJPqP0axutpJSiQFSLw/4EbTQLO1dE1Y ZfGil5qcOfMj5r12bh+MaLOVAENX22LwVqJbfiy8lNzM7eK8mU+c+KLNV/DP0QAXsk0V 5eobciFlxZL6g0+VRCohy0KR6AZLqVuB0KtCkAnw2bo6svNgZuDD4BlwJC3aCzLdc5id Tr8R3j3r6k3AcZ/1Ex0sSQ94QMEp9vGtRd4+ITU5wwMa0YVVivbd1CotjXtDyWyLYiAo +ejw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date; bh=1NDwLaBCs5nhmRz61i3eAQ3IF542diGapeEzK/fCX5o=; b=0u26rSejzI7Ol27iPnDZoUc9bWqPDIVNikUT8hahox9FGOn2tad3SpCdrI65G07JDD tFJhFJ41iJXrRvJEEHcba/34TCL5QDmKnRkLIDPaBG4gf6PccvoPXY1XwhauqCU0fDXT U1t4fuoOQ0i8V1DYn21bRF6eviLQHS+9t6qzGv5vEo5K5NxEUrjxpLCPKhJ5rvN4jGNL Q6NVBEjihFLYgLijjYnU+QF31eAxYLx03wTd6nW9+v5P/R6VGxsX8vCO2AhOLZWPB0gT kokys0z7hcLIseEvoaf7FfS0DAJ0e7D39eeQQGAzNZJMgjdxwD0BXfq6nMrSeS7WErwF 29rA== X-Gm-Message-State: ACgBeo3YGY3My9aNkV25BSeOfgKa+E/mIKsF+WEEMVNz724HRZkHJC/l PwjKwNziE29GCisDFuEpOQ== X-Received: by 2002:a17:90b:1d0a:b0:1ff:35a3:c594 with SMTP id on10-20020a17090b1d0a00b001ff35a3c594mr24869790pjb.14.1662477595386; Tue, 06 Sep 2022 08:19:55 -0700 (PDT) Received: from localhost.localdomain ([43.132.141.9]) by smtp.gmail.com with ESMTPSA id x4-20020a170902a38400b0016dc26c7d30sm1095554pla.164.2022.09.06.08.19.53 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Tue, 06 Sep 2022 08:19:54 -0700 (PDT) From: xiakaixu1987@gmail.com X-Google-Original-From: kaixuxia@tencent.com To: sj@kernel.org, akpm@linux-foundation.org Cc: damon@lists.linux.dev, linux-mm@kvack.org, linux-kernel@vger.kernel.org, Kaixu Xia Subject: [PATCH] mm/damon/core: iterate the regions list from current point in damon_set_regions() Date: Tue, 6 Sep 2022 23:18:47 +0800 Message-Id: <1662477527-13003-1-git-send-email-kaixuxia@tencent.com> X-Mailer: git-send-email 1.8.3.1 X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_ENVFROM_END_DIGIT, FREEMAIL_FROM,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Kaixu Xia We iterate the whole regions list every time to get the first/last regions intersecting with the specific range in damon_set_regions(), in order to add new region or resize existing regions to fit in the specific range. Actually, it is unnecessary to iterate the new added regions and the front regions that have been checked. Just iterate the regions list from the current point using list_for_each_entry_from() every time to improve performance. The kunit tests passed: [PASSED] damon_test_apply_three_regions1 [PASSED] damon_test_apply_three_regions2 [PASSED] damon_test_apply_three_regions3 [PASSED] damon_test_apply_three_regions4 Signed-off-by: Kaixu Xia --- include/linux/damon.h | 8 ++++++++ mm/damon/core.c | 3 ++- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/include/linux/damon.h b/include/linux/damon.h index 7b1f4a488230..d54acec048d6 100644 --- a/include/linux/damon.h +++ b/include/linux/damon.h @@ -463,9 +463,17 @@ static inline struct damon_region *damon_last_region(struct damon_target *t) return list_last_entry(&t->regions_list, struct damon_region, list); } +static inline struct damon_region *damon_first_region(struct damon_target *t) +{ + return list_first_entry(&t->regions_list, struct damon_region, list); +} + #define damon_for_each_region(r, t) \ list_for_each_entry(r, &t->regions_list, list) +#define damon_for_each_region_from(r, t) \ + list_for_each_entry_from(r, &t->regions_list, list) + #define damon_for_each_region_safe(r, next, t) \ list_for_each_entry_safe(r, next, &t->regions_list, list) diff --git a/mm/damon/core.c b/mm/damon/core.c index 7d25dc582fe3..702e1b7e975b 100644 --- a/mm/damon/core.c +++ b/mm/damon/core.c @@ -195,6 +195,7 @@ int damon_set_regions(struct damon_target *t, struct damon_addr_range *ranges, damon_destroy_region(r, t); } + r = damon_first_region(t); /* Add new regions or resize existing regions to fit in the ranges */ for (i = 0; i < nr_ranges; i++) { struct damon_region *first = NULL, *last, *newr; @@ -202,7 +203,7 @@ int damon_set_regions(struct damon_target *t, struct damon_addr_range *ranges, range = &ranges[i]; /* Get the first/last regions intersecting with the range */ - damon_for_each_region(r, t) { + damon_for_each_region_from(r, t) { if (damon_intersect(r, range)) { if (!first) first = r; -- 2.27.0