Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp1399140ybp; Thu, 17 Oct 2019 12:12:26 -0700 (PDT) X-Google-Smtp-Source: APXvYqzAvJj0BioP4vfG/4S+soCUYWyXYkVGNATLMWdGRwrv5uI45r28BZS4mAP43UU3WrZrUqP/ X-Received: by 2002:a17:906:6b88:: with SMTP id l8mr5066151ejr.26.1571339546825; Thu, 17 Oct 2019 12:12:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571339546; cv=none; d=google.com; s=arc-20160816; b=nASrbzEkJFV4rzJdWl5hRtRt7YSTUxTnjXDN7WivlbE+SwAj5X7x1VuteOSeLIrAXb QeOnU2aEzTN6xsXIJ6hTFzWnf1e4JC9YN6y7KTro4yMcpW+8hjyxfg8xjF/6m2XjjxUa IwD4n/xI0Cz/SNb7WKL9LouUiFoa+n1h8hO0dxIAyPdnbotyQcsZQrgdAYreDSdPRnEF DsAB9SiBAtYv/qIkvO936nInoA5fG11sON0s5vxfl3vq1tnlK8ABzEIudd5xuOW/4bXG xWuAiumLSaJXoGUWOx5q+0iJeSD4AF1geOHzfSnGseOWYXYwws134nJ8PmL2C39U3nem x5ng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=YAnKDvbFFksXsU3lYIgjAlKgTXD153LJAIM/gvNYcJk=; b=Hb9juB3B5iI7VYbp4NlINOstowAmey0f6Cw9q/6V0Xav4ZdhkftRd1jUzfW95RVvuq PIen6g1f1E5SpTa947qoecIyBSWtvsf+jfDdGtfNqRt2b4LTWS/AqVwP9gyUnynn0+Dy 2nENemi/ctNQfOJn1FhOpAQmMO+yCYCQbG9k63qFKr6WQoj8DOj/ftJrV8DcPrjnvk8G 71GB8PqOt0PbCmmH3G11yT/bzB7Vgp62TuW75UPKhuaci8tunCbIumvJTrzYgkteUDRv lYGSBk6NOeEgVq958Hf9w2tyKb+PxaAyUFGNQHqZNLf2rSQGz9zi6HqO6q7QEVG5BYxI biAg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=vLDzr2f3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d1si1963352ejh.281.2019.10.17.12.12.03; Thu, 17 Oct 2019 12:12:26 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=vLDzr2f3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2393121AbfJPWNe (ORCPT + 99 others); Wed, 16 Oct 2019 18:13:34 -0400 Received: from mail.kernel.org ([198.145.29.99]:46922 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2395367AbfJPVzv (ORCPT ); Wed, 16 Oct 2019 17:55:51 -0400 Received: from localhost (unknown [192.55.54.58]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 83F5721925; Wed, 16 Oct 2019 21:55:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1571262950; bh=crHSjvYMY9d/dYMyzSZHnf5e6SCkxwWPOlxaPZTBiYQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=vLDzr2f3XxrVF4Wl8ZE8Ydkyk27aqrahQvqdwONMh8pVFtxLd9XTJOCmacX95ahLY F8IWj8hyzcxlE8r3bJKbULfT70JObZRoXCNXb0NxjqEcLndHVyyUb6g4Gr/2tK3kn/ 06K4JH0s75/gPPVyi6OEedaDQLyNqhbqO1WDMVYQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Johan Hovold Subject: [PATCH 4.14 20/65] USB: usblp: fix runtime PM after driver unbind Date: Wed, 16 Oct 2019 14:50:34 -0700 Message-Id: <20191016214815.264366153@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191016214756.457746573@linuxfoundation.org> References: <20191016214756.457746573@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Johan Hovold commit 9a31535859bfd8d1c3ed391f5e9247cd87bb7909 upstream. Since commit c2b71462d294 ("USB: core: Fix bug caused by duplicate interface PM usage counter") USB drivers must always balance their runtime PM gets and puts, including when the driver has already been unbound from the interface. Leaving the interface with a positive PM usage counter would prevent a later bound driver from suspending the device. Fixes: c2b71462d294 ("USB: core: Fix bug caused by duplicate interface PM usage counter") Cc: stable Signed-off-by: Johan Hovold Link: https://lore.kernel.org/r/20191001084908.2003-3-johan@kernel.org Signed-off-by: Greg Kroah-Hartman --- drivers/usb/class/usblp.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) --- a/drivers/usb/class/usblp.c +++ b/drivers/usb/class/usblp.c @@ -474,10 +474,12 @@ static int usblp_release(struct inode *i mutex_lock(&usblp_mutex); usblp->used = 0; - if (usblp->present) { + if (usblp->present) usblp_unlink_urbs(usblp); - usb_autopm_put_interface(usblp->intf); - } else /* finish cleanup from disconnect */ + + usb_autopm_put_interface(usblp->intf); + + if (!usblp->present) /* finish cleanup from disconnect */ usblp_cleanup(usblp); mutex_unlock(&usblp_mutex); return 0;