yam: fix a memory leak in yam_siocdevprivate()
authorHangyu Hua <hbh25y@gmail.com>
Mon, 24 Jan 2022 03:29:54 +0000 (11:29 +0800)
committerSalvatore Bonaccorso <carnil@debian.org>
Mon, 28 Feb 2022 11:23:03 +0000 (11:23 +0000)
Origin: https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable.git/commit?id=729e54636b3ebefb77796702a5b1f1ed5586895e
Bug-Debian-Security: https://security-tracker.debian.org/tracker/CVE-2022-24959

[ Upstream commit 29eb31542787e1019208a2e1047bb7c76c069536 ]

ym needs to be free when ym->cmd != SIOCYAMSMCS.

Fixes: 0781168e23a2 ("yam: fix a missing-check bug")
Signed-off-by: Hangyu Hua <hbh25y@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Gbp-Pq: Topic bugfix/all
Gbp-Pq: Name yam-fix-a-memory-leak-in-yam_siocdevprivate.patch

drivers/net/hamradio/yam.c

index b05798b5f5e2aed0e00c3d27bd22dea77a34c242..1d1f802e5e3ebb9ad94f70bd7e488b64c69bbd97 100644 (file)
@@ -948,9 +948,7 @@ static int yam_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
                                 sizeof(struct yamdrv_ioctl_mcs));
                if (IS_ERR(ym))
                        return PTR_ERR(ym);
-               if (ym->cmd != SIOCYAMSMCS)
-                       return -EINVAL;
-               if (ym->bitrate > YAM_MAXBITRATE) {
+               if (ym->cmd != SIOCYAMSMCS || ym->bitrate > YAM_MAXBITRATE) {
                        kfree(ym);
                        return -EINVAL;
                }