From: Takashi Iwai Date: Wed, 14 Jul 2021 17:00:21 +0000 (+0200) Subject: r8152: Fix potential PM refcount imbalance X-Git-Tag: v4.19.202~13 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=9b091d54444c6b6512903ce6758b841b1699c5bf;p=users%2Fdwmw2%2Flinux.git r8152: Fix potential PM refcount imbalance [ Upstream commit 9c23aa51477a37f8b56c3c40192248db0663c196 ] rtl8152_close() takes the refcount via usb_autopm_get_interface() but it doesn't release when RTL8152_UNPLUG test hits. This may lead to the imbalance of PM refcount. This patch addresses it. Link: https://bugzilla.suse.com/show_bug.cgi?id=1186194 Signed-off-by: Takashi Iwai Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- diff --git a/drivers/net/usb/r8152.c b/drivers/net/usb/r8152.c index 726fb5561a0fb..4764e4f54cefe 100644 --- a/drivers/net/usb/r8152.c +++ b/drivers/net/usb/r8152.c @@ -3960,9 +3960,10 @@ static int rtl8152_close(struct net_device *netdev) tp->rtl_ops.down(tp); mutex_unlock(&tp->control); + } + if (!res) usb_autopm_put_interface(tp->intf); - } free_all_mem(tp);