Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3563358pxb; Mon, 24 Jan 2022 12:17:56 -0800 (PST) X-Google-Smtp-Source: ABdhPJxqo9ETo6VkTUcZtojDQi03dUJmJkrpnq4XLUdN3y4SiPQq1IyqYUC2GeimU/HExUAi2YRQ X-Received: by 2002:a63:5965:: with SMTP id j37mr1204168pgm.292.1643055476707; Mon, 24 Jan 2022 12:17:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643055476; cv=none; d=google.com; s=arc-20160816; b=zMd+3853GIq96jbvX69d2JtP9oAwHef49782VZZr6zx1q2DI81l4CqnRCrqSe2/sDx eFw8dxCgT7rImJAuAGB6dST3kTXPB6DateVHNDBw3+pOnZG0tZBVL62o0meybzyJUcFX mJey4sGNU1NPhVhF2CT1sRXbfNBhaQ9+2eSbs99d5lH0UkslWHyESe11RaI7lctwVg4p 8cTIcZ8LxBXEqB+SWdTzPVfTJrlBEg/FZIr0h5miSMx5ih2mHfSMGTqEz0fPeTqq6qgB bRBmjIu2bErZMd+fV1raP5IrrOJMUJ4qonF6jhA3JsWMKPCdB1MqRFz6ZgAvB1/axnOY 2gPw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=WbheEbcZK5CQrtJkmlRLYwYQ2eLD8HfKROD6XskwqE0=; b=eKDcrInoRB3WIfueiYBLNJ37A4DlOwfZDqytrLcPfqwL9sslOiUbq9Zt+iFZXSOHSw WKfx4G/BCjAVhlo0EU35554n/q0aPGcwe6VJgKKnAEOklevcnClvDGHekZ/70t1kaDKu DcfJEAisYjnLYm1t6HeA1Ekab8Kk99P185Mc1I3fXqtAPtL8d+FqnMpER1/XMDuzVuVa 1jN+H9mvwXWS9Q4NZ8IhyfT65L9VY04qNOVUs+gCB1cIlACwfmpDEiQR9kG2T0X7vjz1 cS3sCzRNc3nAizA2CCus+qTylRmcxrkAH3wauqQBrFEkfLhbQcz3Ead+Ze6ImeBmjl6u i9RQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=G50zDGmh; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v13si3981458pfc.372.2022.01.24.12.17.42; Mon, 24 Jan 2022 12:17:56 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=G50zDGmh; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1348915AbiAXTTy (ORCPT + 99 others); Mon, 24 Jan 2022 14:19:54 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47520 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343987AbiAXTLP (ORCPT ); Mon, 24 Jan 2022 14:11:15 -0500 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5820FC06136A; Mon, 24 Jan 2022 11:03:12 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id EC55F60B9E; Mon, 24 Jan 2022 19:03:11 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id C820BC340E5; Mon, 24 Jan 2022 19:03:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643050991; bh=4GURJXnZwalX9bgyNci/dmzlQqB3PFZtssTykR3PTh0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=G50zDGmhFzUfr4H8aZlzKcRv5CvSgGoza8bNo2Jo+nDdFYZ8g95MXUAuohdMg9bS1 utGG1/WysZyA8K2cj3X6B1UEg9ayAceX4C64iaPrvxnUGa1rYlGw7J6opgMono/LkE HFN8RuseY0GNuE9yqHsmg8Jsa8EO37RZko1sQDdM= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jonathan McDowell , Alan Stern Subject: [PATCH 4.14 002/186] USB: core: Fix bug in resuming hubs handling of wakeup requests Date: Mon, 24 Jan 2022 19:41:17 +0100 Message-Id: <20220124183937.186147505@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124183937.101330125@linuxfoundation.org> References: <20220124183937.101330125@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Alan Stern commit 0f663729bb4afc92a9986b66131ebd5b8a9254d1 upstream. Bugzilla #213839 reports a 7-port hub that doesn't work properly when devices are plugged into some of the ports; the kernel goes into an unending disconnect/reinitialize loop as shown in the bug report. This "7-port hub" comprises two four-port hubs with one plugged into the other; the failures occur when a device is plugged into one of the downstream hub's ports. (These hubs have other problems too. For example, they bill themselves as USB-2.0 compliant but they only run at full speed.) It turns out that the failures are caused by bugs in both the kernel and the hub. The hub's bug is that it reports a different bmAttributes value in its configuration descriptor following a remote wakeup (0xe0 before, 0xc0 after -- the wakeup-support bit has changed). The kernel's bug is inside the hub driver's resume handler. When hub_activate() sees that one of the hub's downstream ports got a wakeup request from a child device, it notes this fact by setting the corresponding bit in the hub->change_bits variable. But this variable is meant for connection changes, not wakeup events; setting it causes the driver to believe the downstream port has been disconnected and then connected again (in addition to having received a wakeup request). Because of this, the hub driver then tries to check whether the device currently plugged into the downstream port is the same as the device that had been attached there before. Normally this check succeeds and wakeup handling continues with no harm done (which is why the bug remained undetected until now). But with these dodgy hubs, the check fails because the config descriptor has changed. This causes the hub driver to reinitialize the child device, leading to the disconnect/reinitialize loop described in the bug report. The proper way to note reception of a downstream wakeup request is to set a bit in the hub->event_bits variable instead of hub->change_bits. That way the hub driver will realize that something has happened to the port but will not think the port and child device have been disconnected. This patch makes that change. Cc: Tested-by: Jonathan McDowell Signed-off-by: Alan Stern Link: https://lore.kernel.org/r/YdCw7nSfWYPKWQoD@rowland.harvard.edu Signed-off-by: Greg Kroah-Hartman --- drivers/usb/core/hub.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- a/drivers/usb/core/hub.c +++ b/drivers/usb/core/hub.c @@ -1192,7 +1192,7 @@ static void hub_activate(struct usb_hub */ if (portchange || (hub_is_superspeed(hub->hdev) && port_resumed)) - set_bit(port1, hub->change_bits); + set_bit(port1, hub->event_bits); } else if (udev->persist_enabled) { #ifdef CONFIG_PM