Received: by 2002:a05:7412:bb8d:b0:d7:7d3a:4fe2 with SMTP id js13csp680697rdb; Tue, 15 Aug 2023 08:49:48 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFDAG/dlfq8GcI3yfIJoiemDEWm+DVHCNDjNpVOK7hrT1mIfroqax1pPkE9vmKyyLXsEf8Y X-Received: by 2002:a17:902:c40a:b0:1bd:ba57:5a8f with SMTP id k10-20020a170902c40a00b001bdba575a8fmr13843278plk.13.1692114588465; Tue, 15 Aug 2023 08:49:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1692114588; cv=none; d=google.com; s=arc-20160816; b=aB4qMb8KpdDnXKSvJxzdIF2JqQQtGcLZ8e28S2i4oULcv2ZStw+CC/Cmd6mcVlNgDT A8rHfsRr6J1eKAQiLeDKWBrtTBZhEAdmBAe+TBotWyv04Y3qp/wL4gU3UuBALi8wgucU fi5nEGt3ALcuzzcmz9ZnFjdpmUQSermgjCZFy/qBopc/nHtqUlSovoFUVJlFH9ln9qW1 sqQT7GkgllNQCQ521dLYrfGJ+g79XkNSwIouFo508K48Jhr4f9j3NsuVT5tFQikOXn0r D9+pfCi7z6tsdAgR/HguGJ7XVTMBwaIURzgU7+uWREgRNFhw2mvKLMgC9X3JB3QL0WA+ yVMQ== 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 :mime-version:user-agent:date:message-id:from:cc:references:to :subject; bh=jgeVxoycWNpVN8Ubi3CJ6g3MpjLi4nY2hOIwxG5KtN0=; fh=GSREk/ToT6IOmgy3I8Wvl7p8CiU+QzT43WYbyOgh3LY=; b=qldwYf2VLg1od3tGwXiE23D3Us7Ny6xBELGopMrMmy4kj6Qm/ctw/5qTy3FFg0Z++k nsOFUR4eWbbVu0TB5Ptk/+0jF541gjMpUawa4N9C+AhlcVO96g8k7DaqXKGSeF9B8JmG IO0LhfdIM9g11qReA+FcVhiyZyBKFkI5dHp3ZVM4/yPEnV7VJtWEqJbZT4jxzMbSm3ML 1n5IB/Xm/YLMznYJBQtY+X1InJSE6e/6KamBTu8dPkgMb1zpgUOBkFXs02sUd5F8/CfT U3nM8GmIb1QCry8LzdjpLSZRvk4vZmfv3AV7Ftk6y8Y9IlWIVJPtueg6JXp7I27wpmi0 KFEQ== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id n17-20020a170903111100b001b89fd6bec4si10164649plh.144.2023.08.15.08.49.35; Tue, 15 Aug 2023 08:49:48 -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; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236718AbjHOLim (ORCPT + 99 others); Tue, 15 Aug 2023 07:38:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52510 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236702AbjHOLiV (ORCPT ); Tue, 15 Aug 2023 07:38:21 -0400 Received: from szxga03-in.huawei.com (szxga03-in.huawei.com [45.249.212.189]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E5717E7C for ; Tue, 15 Aug 2023 04:38:19 -0700 (PDT) Received: from dggpeml500002.china.huawei.com (unknown [172.30.72.56]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4RQ8MY1jGzzFqdC; Tue, 15 Aug 2023 19:35:21 +0800 (CST) Received: from [10.67.103.44] (10.67.103.44) by dggpeml500002.china.huawei.com (7.185.36.158) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.31; Tue, 15 Aug 2023 19:38:17 +0800 Subject: Re: [PATCH 2/2] coresight: core: Fix multiple free TRBE platform data resource To: Suzuki K Poulose , , , , , James Clark References: <20230814093813.19152-1-hejunhao3@huawei.com> <20230814093813.19152-3-hejunhao3@huawei.com> <2b69bd4e-5ef4-16c7-f908-7c70187e12b6@arm.com> CC: , , , , , From: hejunhao Message-ID: <68f16bb1-53ed-b8b9-812e-6d3be40a5bde@huawei.com> Date: Tue, 15 Aug 2023 19:38:17 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:45.0) Gecko/20100101 Thunderbird/45.7.1 MIME-Version: 1.0 In-Reply-To: <2b69bd4e-5ef4-16c7-f908-7c70187e12b6@arm.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.67.103.44] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To dggpeml500002.china.huawei.com (7.185.36.158) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-2.9 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_PASS 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 Hi, Suzuki On 2023/8/15 6:47, Suzuki K Poulose wrote: > + James Clark > > On 14/08/2023 10:38, Junhao He wrote: >> Current the TRBE driver supports matching TRBE platform device through >> id_table. The ACPI created a dummy TRBE platform device inside >> drivers/perf/arm_pmu_acpi.c. So the TRBE platform driver will probe only >> once and allocate just one TRBE platform data resource. >> >> If the system supports the TRBE feature, Each CPU in the systems can >> have at least one TRBE present, and the coresight_unregister gets called >> multiple times, once for each of them. >> Therefore, when unregister TRBE coresight devices, the TRBE platform >> data >> resource will multiple free in function coresight_unregister. >> >> root@localhost:# insmod coresight-trbe.ko >> root@localhost:# rmmod coresight-trbe.ko >> [ 423.455932] ------------[ cut here ]------------ >> [ 423.461987] WARNING: CPU: 1 PID: 0 at drivers/base/devres.c:1064 >> devm_kfree+0x88/0x98 >> [ 423.483821] CPU: 1 PID: 0 Comm: swapper/1 Tainted: G >> O 6.5.0-rc4+ #1 >> [ 423.505842] pstate: 614000c9 (nZCv daIF +PAN -UAO -TCO +DIT -SSBS >> BTYPE=--) >> ... >> [ 423.601301] Call trace: >> [ 423.604202] devm_kfree+0x88/0x98 >> [ 423.608369] coresight_release_platform_data+0xb8/0xe0 [coresight] >> [ 423.616589] coresight_unregister+0x120/0x170 [coresight] >> [ 423.623533] arm_trbe_remove_coresight_cpu+0x70/0xa0 [coresight_trbe] >> [ 423.631082] __flush_smp_call_function_queue+0x1e4/0x4e0 >> [ 423.637471] generic_smp_call_function_single_interrupt+0x1c/0x30 >> [ 423.644796] ipi_handler+0x90/0x278 >> [ 423.648992] handle_percpu_devid_irq+0x90/0x250 >> [ 423.654636] generic_handle_domain_irq+0x34/0x58 >> [ 423.659786] gic_handle_irq+0x12c/0x270 >> [ 423.664039] call_on_irq_stack+0x24/0x30 >> [ 423.668452] do_interrupt_handler+0x88/0x98 >> [ 423.673027] el1_interrupt+0x48/0xe8 >> [ 423.677413] el1h_64_irq_handler+0x18/0x28 >> [ 423.681781] el1h_64_irq+0x78/0x80 >> [ 423.685550] default_idle_call+0x5c/0x180 >> [ 423.689855] do_idle+0x25c/0x2c0 >> [ 423.694196] cpu_startup_entry+0x2c/0x40 >> [ 423.698373] secondary_start_kernel+0x144/0x188 >> [ 423.703920] __secondary_switched+0xb8/0xc0 >> [ 423.708972] ---[ end trace 0000000000000000 ]--- >> [ 423.729209] ------------[ cut here ]------------ >> ... >> [ 423.735217] WARNING: CPU: 2 PID: 40 at drivers/base/devres.c:1064 >> devm_kfree+0x88/0x98 >> ... >> [ 424.012385] WARNING: CPU: 3 PID: 0 at drivers/base/devres.c:1064 >> devm_kfree+0x88/0x98 >> ... >> >> This patch does the following: >> 1.TRBE coresight devices do not need regular connections information, We >> can free connections resource when the nr_conns is valid. >> 2.And we can ignore the free platform data resource, it will be >> automatically free in platform_driver_unregister(). > > Do we need a Fixes tag here ? Yes, I will do that. >> >> Signed-off-by: Junhao He >> --- >> drivers/hwtracing/coresight/coresight-core.c | 7 ++++--- >> 1 file changed, 4 insertions(+), 3 deletions(-) >> >> diff --git a/drivers/hwtracing/coresight/coresight-core.c >> b/drivers/hwtracing/coresight/coresight-core.c >> index 118fcf27854d..c6f7889d1b4d 100644 >> --- a/drivers/hwtracing/coresight/coresight-core.c >> +++ b/drivers/hwtracing/coresight/coresight-core.c >> @@ -1555,9 +1555,10 @@ void coresight_release_platform_data(struct >> coresight_device *csdev, >> conns[i]->dest_fwnode = NULL; >> devm_kfree(dev, conns[i]); >> } >> - devm_kfree(dev, pdata->out_conns); >> - devm_kfree(dev, pdata->in_conns); >> - devm_kfree(dev, pdata); >> + if (pdata->nr_outconns) >> + devm_kfree(dev, pdata->out_conns); >> + if (pdata->nr_inconns) >> + devm_kfree(dev, pdata->in_conns); > > These allocations are made on the parent device and that > may never get unregistered (e.g., AMBA device, platform device, > stay forever, even when the "coresight" modules are unloaded). > Thus the memory will be left unused, literally leaking. > This specific devm_kfree() was added to fix that. May be we should fix > this in the TRBE driver to use separate pdata for the TRBE device > instances. > > Suzuki If we fix this with minimal changes, I think it is possible to add a check and not free pdata if it is TRBE? if (csdev->subtype.sink_subtype != CORESIGHT_DEV_SUBTYPE_SINK_PERCPU_SYSMEM) devm_kfree(dev, pdata); Then free pdata in the end of arm_trbe_remove_coresight(). > >> if (csdev) >> coresight_remove_conns_sysfs_group(csdev); >> } > > > . >