Received: by 2002:a05:7412:31a9:b0:e2:908c:2ebd with SMTP id et41csp6109158rdb; Mon, 18 Sep 2023 04:44:22 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEZKzzwdCLSprswHF9jGD1Yfp1YNYi228cCSAIWe8KjzuH5ukoGntx/SaaT4BcZn5QsfHbM X-Received: by 2002:a05:6a21:18e:b0:13a:12c2:359e with SMTP id le14-20020a056a21018e00b0013a12c2359emr9839160pzb.2.1695037462590; Mon, 18 Sep 2023 04:44:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695037462; cv=none; d=google.com; s=arc-20160816; b=K+fEPSe/0x3+wNogvpOAKom6uWuEMRNSN/BdwvbJNSiFVFHTI0a8Yx92JNBrhtBoDW yiI2naj/4MMQIXmsd9SYmo64LNRxYMs+ofB0/KpDe75VVzLwJ94hZR5172paXhS6GTMX X7v5iHC1mEzcImiLGiZjLWBvZ97qeGRuDySfx0zXlCV8r5EOqLu7hKkcfbp11594aPym skkBFcxxgZhMIUldJl5z+KaNyVc0iNFxBmP8zhylsbrkcuhEwsGcBo1O5ayNsABgHDbj SKX+HcXBY+1RuNvwo0FARwPQDtGtt3GI6G/0Of4XMBg2Rr9Ai1CuyzKgYrmHhqaLkkUR wzWw== 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=5FWUD3A+WASfPmfnXpg6Os6+zYl9lBZEVwuMD/Ogihs=; fh=bX0E1kE6BV3nAVlM6Xy9JfIm1hblvvPM+raCPrBMmi8=; b=Ul+h1lV+HtcXwToYsNAIhGhfXH1ZYuTmejKQKf372VM6DDy6zTpW01CNidHwXn+xML OqU8+BhMQXC6CVzx2wMWFQ3VoDwW9MV2HeFquEvX3tC/5yzD9X8MZZvlLyMvdDbqJGOn W8zoQI++oFiHozmredK8ZZanRjZwi64b+0ULhq2WA5LV9bEJU+I7QdkQ38OGHkUyhzdw 44Ik2UCt4XJrPR91EGTSZiWI7Ctj2lfcW3Ks+lo5KCrrFk3yYHNuabD9oosw+7gBaMTG yDJbY8sGXGB7dbPkcPVN7990C6D0GMpttCG+gCw/jfakQn96CnjgbMP8Sz7DB1kEilxi Xqzw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 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 lipwig.vger.email (lipwig.vger.email. [2620:137:e000::3:3]) by mx.google.com with ESMTPS id b29-20020a63931d000000b005774d2f4abasi7799438pge.876.2023.09.18.04.44.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Sep 2023 04:44:22 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) client-ip=2620:137:e000::3:3; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 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 lipwig.vger.email (Postfix) with ESMTP id 13A238037959; Mon, 18 Sep 2023 04:36:15 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239489AbjIRLfX (ORCPT + 99 others); Mon, 18 Sep 2023 07:35:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33076 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241800AbjIRLfU (ORCPT ); Mon, 18 Sep 2023 07:35:20 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 044DC11C; Mon, 18 Sep 2023 04:33:49 -0700 (PDT) Received: from kwepemi500008.china.huawei.com (unknown [172.30.72.54]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4Rq2dj1WCLzNncT; Mon, 18 Sep 2023 19:30:01 +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 19:33:46 +0800 Message-ID: Date: Mon, 18 Sep 2023 19:33:45 +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 v2 1/2] mm/damon/core-test: Fix memory leak in damon_new_region() Content-Language: en-US To: SeongJae Park CC: , , , , , , , References: <20230918110009.78365-1-sj@kernel.org> From: Ruan Jinjie In-Reply-To: <20230918110009.78365-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 lipwig.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 (lipwig.vger.email [0.0.0.0]); Mon, 18 Sep 2023 04:36:15 -0700 (PDT) On 2023/9/18 19:00, SeongJae Park wrote: > Hi Jinjie, > > On Mon, 18 Sep 2023 15:47:58 +0800 Jinjie Ruan wrote: > >> When CONFIG_DAMON_KUNIT_TEST=y and making CONFIG_DEBUG_KMEMLEAK=y >> and CONFIG_DEBUG_KMEMLEAK_AUTO_SCAN=y, the below memory leak is detected. >> >> 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. So use >> damon_free_region() to free it. > > Nit. This patch is not directly adding use of damon_free_region() but replaces > damon_del_region() call with damon_destroy_region(), so that it calls both > damon_del_region() and damon_free_region(). > > I think this part might better to be re-written? OK. Thank you! > >> After applying this patch, the following >> memory leak is never detected. >> >> 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 >> >> 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 > > Other than the above trivial nit, > > Reviewed-by: SeongJae Park > >> --- >> v2: >> - Replace the damon_del_region() with damon_destroy_region() rather than >> calling damon_free_region(). >> - Update the commit message. > > And thank you for making the changes. > > > Thanks, > SJ > >> --- >> mm/damon/core-test.h | 4 +++- >> 1 file changed, 3 insertions(+), 1 deletion(-) >> >> diff --git a/mm/damon/core-test.h b/mm/damon/core-test.h >> index 79f1f12e0dd5..3959be35b901 100644 >> --- a/mm/damon/core-test.h >> +++ b/mm/damon/core-test.h >> @@ -30,7 +30,7 @@ static void damon_test_regions(struct kunit *test) >> damon_add_region(r, t); >> KUNIT_EXPECT_EQ(test, 1u, damon_nr_regions(t)); >> >> - damon_del_region(r, t); >> + damon_destroy_region(r, t); >> KUNIT_EXPECT_EQ(test, 0u, damon_nr_regions(t)); >> >> damon_free_target(t); >> @@ -321,6 +321,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); >> } >> >> static void damon_test_set_attrs(struct kunit *test) >> -- >> 2.34.1 >> >>