Received: by 2002:a05:7412:31a9:b0:e2:908c:2ebd with SMTP id et41csp6002088rdb; Mon, 18 Sep 2023 00:19:49 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFmmyFx/GHrCFoZwOhxUxfmXusVsNkT2Yn36JHud5wUhC7Ugau4S88U4cA0RFkg6hjpYDoz X-Received: by 2002:a67:f446:0:b0:44d:95d4:9fa1 with SMTP id r6-20020a67f446000000b0044d95d49fa1mr6065552vsn.17.1695021589168; Mon, 18 Sep 2023 00:19:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695021589; cv=none; d=google.com; s=arc-20160816; b=G+IFQnqLStX8tjRpq9BUe2wFpz1vNoVnNtH368K/ZhQiZLRvBEoWTNuFka6SrhnSZa c3dyMmznAZjRZw1uGWtDYgjD4rMsOYvpm+T1uNKlcffyfPVMf+ktPdv9qNYsZ9Iwww1Z a2SLS+aZLhKpOLKNTbGGqflmkAniNmNXETsuW3Zynl1tBt13AxCsQ9M/HGLFMBbkFE1X 6JLsy4CjX26r5NyaI5TDW0XgYARm9UDKnaQ5duy+Hg7AubY4RIM3NnuuSqG8UcAKsnTD O7H6PLtAWBjZimkhh30Vhzk6U6kbEFTN7Gt3aril1Aj3MCP94eU4Qee3S/RfsoZAZsN6 Lv+g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=RaVv7/p3dVdB2RaMs8fdeJ/iURSJ7ehP5ULdLlSzb9k=; fh=bX0E1kE6BV3nAVlM6Xy9JfIm1hblvvPM+raCPrBMmi8=; b=dZ3V3Txf4bP4j05KCouC2bCqFLtfPYOs1G2Rc9/7BU0IfeVRSfrN1wM1QYUDGz6Elt /I6qIzPcDD7K17sa4KqtqlTtk/HGRpk+ASIgXbzpGHiN82ZDsYl5Ch8RS0p76VRSUN0Q +ZcqAbmqlbJmYiXm+9DGXNq4PwkVJv6GsVVHz1wSBIrOJUI6smTXJjgy/dyLrrEqxCNr oPTYpgefQE19QsllqOaK41nRkaKhFkwaxiKHpj/Vhc9anLSmbnc0SMPwSMZ6wYjwRZPI qFSrpVAC6T66yKKmY3omguethUxXLL5ckz7N6G2le06wlqQHF2Cy6t33eZmRuVyMa28u IHjw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from fry.vger.email (fry.vger.email. [23.128.96.38]) by mx.google.com with ESMTPS id 6-20020a630a06000000b00573fc592e9dsi7659093pgk.848.2023.09.18.00.19.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Sep 2023 00:19:49 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) client-ip=23.128.96.38; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id 3CC3D808BD37; Mon, 18 Sep 2023 00:15:20 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232238AbjIRHOi (ORCPT + 99 others); Mon, 18 Sep 2023 03:14:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56258 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238179AbjIRHOO (ORCPT ); Mon, 18 Sep 2023 03:14:14 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4AB7B1A5; Mon, 18 Sep 2023 00:13:11 -0700 (PDT) Received: from kwepemi500008.china.huawei.com (unknown [172.30.72.53]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4Rpwrz18XpzNndR; Mon, 18 Sep 2023 15:09:23 +0800 (CST) Received: from [10.67.109.254] (10.67.109.254) by kwepemi500008.china.huawei.com (7.221.188.139) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.31; Mon, 18 Sep 2023 15:13:08 +0800 Message-ID: Date: Mon, 18 Sep 2023 15:13:07 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.2.0 Subject: Re: [PATCH RESEND 1/2] mm/damon/core-test: Fix memory leak in damon_new_region() Content-Language: en-US To: SeongJae Park CC: , , , , , , , References: <20230918053320.61408-1-sj@kernel.org> From: Ruan Jinjie In-Reply-To: <20230918053320.61408-1-sj@kernel.org> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [10.67.109.254] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To kwepemi500008.china.huawei.com (7.221.188.139) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-2.2 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Mon, 18 Sep 2023 00:15:20 -0700 (PDT) On 2023/9/18 13:33, SeongJae Park wrote: > Hi Jinjie, > > > Thank you for this patchset! > > On Mon, 18 Sep 2023 13:10:43 +0800 Jinjie Ruan wrote: > >> The damon_region which is allocated by kmem_cache_alloc() in >> damon_new_region() in damon_test_regions() and >> damon_test_update_monitoring_result() are not freed and it causes below >> memory leak. So use damon_free_region() to free it. >> >> unreferenced object 0xffff2b49c3edc000 (size 56): >> comm "kunit_try_catch", pid 338, jiffies 4294895280 (age 557.084s) >> hex dump (first 32 bytes): >> 01 00 00 00 00 00 00 00 02 00 00 00 00 00 00 00 ................ >> 00 00 00 00 00 00 00 00 00 00 00 00 49 2b ff ff ............I+.. >> backtrace: >> [<0000000088e71769>] slab_post_alloc_hook+0xb8/0x368 >> [<00000000b528f67c>] kmem_cache_alloc+0x168/0x284 >> [<000000008603f022>] damon_new_region+0x28/0x54 >> [<00000000a3b8c64e>] damon_test_regions+0x38/0x270 >> [<00000000559c4801>] kunit_try_run_case+0x50/0xac >> [<000000003932ed49>] kunit_generic_run_threadfn_adapter+0x20/0x2c >> [<000000003c3e9211>] kthread+0x124/0x130 >> [<0000000028f85bdd>] ret_from_fork+0x10/0x20 >> unreferenced object 0xffff2b49c5b20000 (size 56): >> comm "kunit_try_catch", pid 354, jiffies 4294895304 (age 556.988s) >> hex dump (first 32 bytes): >> 03 00 00 00 00 00 00 00 07 00 00 00 00 00 00 00 ................ >> 00 00 00 00 00 00 00 00 96 00 00 00 49 2b ff ff ............I+.. >> backtrace: >> [<0000000088e71769>] slab_post_alloc_hook+0xb8/0x368 >> [<00000000b528f67c>] kmem_cache_alloc+0x168/0x284 >> [<000000008603f022>] damon_new_region+0x28/0x54 >> [<00000000ca019f80>] damon_test_update_monitoring_result+0x18/0x34 >> [<00000000559c4801>] kunit_try_run_case+0x50/0xac >> [<000000003932ed49>] kunit_generic_run_threadfn_adapter+0x20/0x2c >> [<000000003c3e9211>] kthread+0x124/0x130 >> [<0000000028f85bdd>] ret_from_fork+0x10/0x20 > > Nice finding! Could you please share just a brief more detail about above cool > output, e.g., just the name of the tool you used, so that others can learn it > from your awesome commit message? > >> >> Fixes: 17ccae8bb5c9 ("mm/damon: add kunit tests") >> Fixes: f4c978b6594b ("mm/damon/core-test: add a test for damon_update_monitoring_results()") >> Signed-off-by: Jinjie Ruan >> --- >> mm/damon/core-test.h | 3 +++ >> 1 file changed, 3 insertions(+) >> >> diff --git a/mm/damon/core-test.h b/mm/damon/core-test.h >> index 6cc8b245586d..255f8c925c00 100644 >> --- a/mm/damon/core-test.h >> +++ b/mm/damon/core-test.h >> @@ -34,6 +34,7 @@ static void damon_test_regions(struct kunit *test) >> KUNIT_EXPECT_EQ(test, 0u, damon_nr_regions(t)); >> >> damon_free_target(t); >> + damon_free_region(r); > > There is damon_destroy_region() function, which simply calls damon_del_region() > and damon_free_region(). Unless there is needs to access the region before > removing from the region, doing memory return together via the function is > recommended. > > And this test code calls damon_del_region() just beofre above > KUNIT_EXPECT_EQ(). Hence, I think replacing the damon_del_region() call with > damon_destroy_region() rather than calling damon_free_region() may be simpler > and shorter. Could you please do so? Sure. Thank you very much! > >> } >> >> static unsigned int nr_damon_targets(struct damon_ctx *ctx) >> @@ -316,6 +317,8 @@ static void damon_test_update_monitoring_result(struct kunit *test) >> damon_update_monitoring_result(r, &old_attrs, &new_attrs); >> KUNIT_EXPECT_EQ(test, r->nr_accesses, 150); >> KUNIT_EXPECT_EQ(test, r->age, 20); >> + >> + damon_free_region(r); > > This looks nice. Thank you for fixing this! > >> } >> >> static void damon_test_set_attrs(struct kunit *test) >> -- >> 2.34.1 >> > > Thanks, > SJ