[PATCH] coresight: tmc: sg: Do not leak sg_table
Anshuman Khandual
anshuman.khandual at arm.com
Wed Jul 3 20:59:26 PDT 2024
On 7/2/24 18:58, Suzuki K Poulose wrote:
> Running perf with cs_etm on Juno triggers the following kmemleak warning !
>
> :~# cat /sys/kernel/debug/kmemleak
> unreferenced object 0xffffff8806b6d720 (size 96):
> comm "perf", pid 562, jiffies 4297810960
> hex dump (first 32 bytes):
> 38 d8 13 07 88 ff ff ff 00 d0 9e 85 c0 ff ff ff 8...............
> 00 10 00 88 c0 ff ff ff 00 f0 ff f7 ff 00 00 00 ................
> backtrace (crc 1dbf6e00):
> [<ffffffc08107381c>] kmemleak_alloc+0xbc/0xd8
> [<ffffffc0802f9798>] kmalloc_trace_noprof+0x220/0x2e8
> [<ffffffc07bb71948>] tmc_alloc_sg_table+0x48/0x208 [coresight_tmc]
> [<ffffffc07bb71cbc>] tmc_etr_alloc_sg_buf+0xac/0x240 [coresight_tmc]
> [<ffffffc07bb72538>] tmc_alloc_etr_buf.constprop.0+0x1f0/0x260 [coresight_tmc]
> [<ffffffc07bb7280c>] alloc_etr_buf.constprop.0.isra.0+0x74/0xa8 [coresight_tmc]
> [<ffffffc07bb72950>] tmc_alloc_etr_buffer+0x110/0x260 [coresight_tmc]
> [<ffffffc07bb38afc>] etm_setup_aux+0x204/0x3b0 [coresight]
> [<ffffffc08025837c>] rb_alloc_aux+0x20c/0x318
> [<ffffffc08024dd84>] perf_mmap+0x2e4/0x7a0
> [<ffffffc0802cceb0>] mmap_region+0x3b0/0xa08
> [<ffffffc0802cd8a8>] do_mmap+0x3a0/0x500
> [<ffffffc080295328>] vm_mmap_pgoff+0x100/0x1d0
> [<ffffffc0802cadf8>] ksys_mmap_pgoff+0xb8/0x110
> [<ffffffc080020688>] __arm64_sys_mmap+0x38/0x58
> [<ffffffc080028fc0>] invoke_syscall.constprop.0+0x58/0x100
>
> This due to the fact that we do not free the "sg_table" itself while
> freeing up the SG table and data pages. Fix this by freeing the sg_table
> in tmc_free_sg_table().
>
> Fixes: 99443ea19e8b ("coresight: Add generic TMC sg table framework")
> Cc: Mike Leach <mike.leach at linaro.org>
> Cc: James Clark <james.clark at arm.com>
> Signed-off-by: Suzuki K Poulose <suzuki.poulose at arm.com>
LGTM
Reviewed-by: Anshuman Khandual <anshuman.khandual at arm.com>
> ---
> drivers/hwtracing/coresight/coresight-tmc-etr.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/hwtracing/coresight/coresight-tmc-etr.c b/drivers/hwtracing/coresight/coresight-tmc-etr.c
> index e75428fa1592..610ad51cda65 100644
> --- a/drivers/hwtracing/coresight/coresight-tmc-etr.c
> +++ b/drivers/hwtracing/coresight/coresight-tmc-etr.c
> @@ -261,6 +261,7 @@ void tmc_free_sg_table(struct tmc_sg_table *sg_table)
> {
> tmc_free_table_pages(sg_table);
> tmc_free_data_pages(sg_table);
> + kfree(sg_table);
> }
> EXPORT_SYMBOL_GPL(tmc_free_sg_table);
>
> @@ -342,7 +343,6 @@ struct tmc_sg_table *tmc_alloc_sg_table(struct device *dev,
> rc = tmc_alloc_table_pages(sg_table);
> if (rc) {
> tmc_free_sg_table(sg_table);
> - kfree(sg_table);
> return ERR_PTR(rc);
> }
>
More information about the linux-arm-kernel
mailing list