]> git.baikalelectronics.ru Git - kernel.git/commitdiff
ptp_qoriq: fix memory leak in probe()
authorSongJingyi <u201912584@hust.edu.cn>
Fri, 24 Mar 2023 03:14:06 +0000 (11:14 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 5 Apr 2023 09:16:43 +0000 (11:16 +0200)
[ Upstream commit f33642224e38d7e0d59336e10e7b4e370b1c4506 ]

Smatch complains that:
drivers/ptp/ptp_qoriq.c ptp_qoriq_probe()
warn: 'base' from ioremap() not released.

Fix this by revising the parameter from 'ptp_qoriq->base' to 'base'.
This is only a bug if ptp_qoriq_init() returns on the
first -ENODEV error path.
For other error paths ptp_qoriq->base and base are the same.
And this change makes the code more readable.

Fixes: 456bb3f9cc32 ("ptp_qoriq: fix NULL access if ptp dt node missing")
Signed-off-by: SongJingyi <u201912584@hust.edu.cn>
Reviewed-by: Dan Carpenter <error27@gmail.com>
Reviewed-by: Dongliang Mu <dzm91@hust.edu.cn>
Link: https://lore.kernel.org/r/20230324031406.1895159-1-u201912584@hust.edu.cn
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/ptp/ptp_qoriq.c

index a577218d1ab716fc9367e5e4a02289268a7f8ec7..ca211feadb383238bb8eba3cc44dd37c79bd45c0 100644 (file)
@@ -604,7 +604,7 @@ static int ptp_qoriq_probe(struct platform_device *dev)
        return 0;
 
 no_clock:
-       iounmap(ptp_qoriq->base);
+       iounmap(base);
 no_ioremap:
        release_resource(ptp_qoriq->rsrc);
 no_resource: