From: Fedor Pchelkin Date: Mon, 6 Mar 2023 21:26:50 +0000 (+0300) Subject: nfc: change order inside nfc_se_io error path X-Git-Tag: v6.1.21~315 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=4d72cdd639094d10a53be20ce6b5cf730842e6ac;p=platform%2Fkernel%2Flinux-starfive.git nfc: change order inside nfc_se_io error path commit 7d834b4d1ab66c48e8c0810fdeadaabb80fa2c81 upstream. cb_context should be freed on the error path in nfc_se_io as stated by commit 25ff6f8a5a3b ("nfc: fix memory leak of se_io context in nfc_genl_se_io"). Make the error path in nfc_se_io unwind everything in reverse order, i.e. free the cb_context after unlocking the device. Suggested-by: Krzysztof Kozlowski Signed-off-by: Fedor Pchelkin Reviewed-by: Krzysztof Kozlowski Link: https://lore.kernel.org/r/20230306212650.230322-1-pchelkin@ispras.ru Signed-off-by: Jakub Kicinski Signed-off-by: Greg Kroah-Hartman --- diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c index 348bf56..b9264e7 100644 --- a/net/nfc/netlink.c +++ b/net/nfc/netlink.c @@ -1446,8 +1446,8 @@ static int nfc_se_io(struct nfc_dev *dev, u32 se_idx, return rc; error: - kfree(cb_context); device_unlock(&dev->dev); + kfree(cb_context); return rc; }