Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp154090pxv; Wed, 21 Jul 2021 18:28:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxDbaxP4ICbL29Xz4jzZMoF22CEkHVIjZFGIK6bw6GRJAcVHuRCWRr6Jt8Z2sZXRU4I2pBV X-Received: by 2002:a05:6e02:16c7:: with SMTP id 7mr10318305ilx.269.1626917326236; Wed, 21 Jul 2021 18:28:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626917326; cv=none; d=google.com; s=arc-20160816; b=hACgWDmVXIN8YpQA1YKNpWb5FwazfGlfiU3IyKLDGIVB8XEKeV3zB5+kyxrc0wLFI+ fWspcvK63sm7ezAVXnr5yKqHgspVmgT6/ahwTARjyh0s4G/IFQpyqHy52lgDHgxWF8WI pbTtZYHnHYKltAxBTVexGFGEm7SzqbKesHLjtmggbsjIlDe1IFGN534MAeNVQtOAmEVM Bp2VfkfyrxM+LOnfmo3wHuoGAifDjc+FZYLMh9iOyLC9JUqn+vM5KwWY6W7bya5QkslO zljXVG8MZCSQr6P2SS7E8DleWnbWPpOg+vdll3NQHFQiYsy94Ccx/S5XezWkIj3Gdu4D uoxQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :to:subject:dkim-signature; bh=ZEFkgmUTVjeuYsx4VvotXiwOxlNKuQXZvTuRHJTeDJo=; b=DlWZZ6WiO/wq7ptKabrxKx+eCTMKdI0WrW8DxIMkHqvZk6eAnJa79bGS8jJA9GlKIG +RJArxownN2eWOueARTBYcSa58s+H8LZea6ZLxJnFvkdBFcCqVbJMIfNvQIYxXpWfaQ3 rDpBV8KpHtglbCuxc5oBUfQGzlVWGBikCEwM04FkBi+umMIR/1Q8/3UA/1gECSDnMt7y 2ZXUlBwNYI4L2tOY0n4mYHS0U5tc/qDP/8bFDWss4hyQ++6c8sloMU3A47n53jkeNW8n hPcQG5QNeYnchABXRo7k4MJowmuGbaYm5jKn3qInuk0jDmDcWYMeHDUJtIqufKNpXJBk hopw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=google header.b=G735zQvf; 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 x19si26970639ioa.74.2021.07.21.18.28.32; Wed, 21 Jul 2021 18:28:46 -0700 (PDT) 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=google header.b=G735zQvf; 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 S230045AbhGVAp3 (ORCPT + 99 others); Wed, 21 Jul 2021 20:45:29 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37516 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229621AbhGVAp2 (ORCPT ); Wed, 21 Jul 2021 20:45:28 -0400 Received: from mail-io1-xd31.google.com (mail-io1-xd31.google.com [IPv6:2607:f8b0:4864:20::d31]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7AF73C061575 for ; Wed, 21 Jul 2021 18:26:04 -0700 (PDT) Received: by mail-io1-xd31.google.com with SMTP id x10so4528810ion.9 for ; Wed, 21 Jul 2021 18:26:04 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linuxfoundation.org; s=google; h=subject:to:references:from:message-id:date:user-agent:mime-version :in-reply-to:content-language:content-transfer-encoding; bh=ZEFkgmUTVjeuYsx4VvotXiwOxlNKuQXZvTuRHJTeDJo=; b=G735zQvfkBzRI8EIQJf0oY4XgRqua1+SjwAdBzPqM69liydweNYz398t4cwwpUCYV7 C0lbr2ip/Dux7th/wkG5pcygQhkZ46KM4DvXIE+sFKQhQ2KlObewqc347nMQjytE4Jkg P+/hUOqK2QFA8qLI4A4/U8L5SVLm+2omLPkGc= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=ZEFkgmUTVjeuYsx4VvotXiwOxlNKuQXZvTuRHJTeDJo=; b=C2A2W1OQGHCLN419zNnagpi1W9SiH0Hu/pGTJ71S9Pl51hQ3/+ou98GsT2NmeFhNaZ uH8C/y8zsr20CS3Bzn7uYH4Nga0r5GckSusQKbFxCUX+1nMz/RHLLG8U+YzSXpgdHAz+ VCLINiEwQTHNgxdltEm3WGETUrKSVI/4VdOmWXd/AHx3SaCaActgGCEbxs1t6aEoLbup yuC2StWnL/60qrYOu1wgT8sg8RFZubiTXPrAz8Qw7R/2tQhf/ne7hFu5KgxnMO1S0dw0 3ySjmryfK5bkzzwuj3KYRr9WEooHzsEtRrDRwobC7CnlNaGtUitajGHRVD+Ms6v8NuwV 8y/w== X-Gm-Message-State: AOAM533xo2qjBfdnnO45HTQcDJBiIuvUj1BxzAotD1gv/U8HdZ8QxpQp aAS87K4U43ufxd6/MT1DkFH6jA== X-Received: by 2002:a02:6946:: with SMTP id e67mr33251483jac.4.1626917163888; Wed, 21 Jul 2021 18:26:03 -0700 (PDT) Received: from [192.168.1.112] (c-24-9-64-241.hsd1.co.comcast.net. [24.9.64.241]) by smtp.gmail.com with ESMTPSA id a10sm16118824ioo.9.2021.07.21.18.26.03 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 21 Jul 2021 18:26:03 -0700 (PDT) Subject: Re: [PATCH v2] vhci_hcd: USB port can get stuck in the disabled state To: Michael Broadfoot , valentina.manea.m@gmail.com, shuah@kernel.org, gregkh@linuxfoundation.org, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, Shuah Khan References: <20210721235526.10588-1-msbroadf@gmail.com> From: Shuah Khan Message-ID: <7b02cb66-d672-ae95-01ea-c6015725e1ac@linuxfoundation.org> Date: Wed, 21 Jul 2021 19:26:02 -0600 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: <20210721235526.10588-1-msbroadf@gmail.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 7/21/21 5:55 PM, Michael Broadfoot wrote: > When a remote usb device is attached to the local Virtual USB > Host Controller Root Hub port, the bound device driver may send a > port reset command. For example to initialize firmware (eg. btusb does this). > This port reset command can be sent at any time, however the VHCI hcd > root hub is only expecting reset to occur before the device receives > SET_ADDRESS. The USB port should always be enabled after a reset > (because the port is virtual and there is no possibility of hardware errors) > > > > Signed-off-by: Michael Broadfoot > --- > drivers/usb/usbip/vhci_hcd.c | 13 ++++--------- > 1 file changed, 4 insertions(+), 9 deletions(-) > > diff --git a/drivers/usb/usbip/vhci_hcd.c b/drivers/usb/usbip/vhci_hcd.c > index 4ba6bcdaa8e9..d3cda1b2c15a 100644 > --- a/drivers/usb/usbip/vhci_hcd.c > +++ b/drivers/usb/usbip/vhci_hcd.c > @@ -455,15 +455,10 @@ static int vhci_hub_control(struct usb_hcd *hcd, u16 typeReq, u16 wValue, > vhci_hcd->port_status[rhport] &= ~(1 << USB_PORT_FEAT_RESET); > vhci_hcd->re_timeout = 0; > > - if (vhci_hcd->vdev[rhport].ud.status == > - VDEV_ST_NOTASSIGNED) { > - usbip_dbg_vhci_rh( > - " enable rhport %d (status %u)\n", > - rhport, > - vhci_hcd->vdev[rhport].ud.status); > - vhci_hcd->port_status[rhport] |= > - USB_PORT_STAT_ENABLE; > - } VDEV_ST_NOTASSIGNED status indicates that the vdev is in use without address assigned - in other words port is initializing. This is part of the attach request handling when user requests to attach to a remote device. attach_store() will change the status to VDEV_ST_NOTASSIGNED and then initiate port_connect sequence. We don't want to touch the vdev when it is in other states. > + usbip_dbg_vhci_rh(" enable rhport %d (status %u)\n", > + rhport, > + vhci_hcd->vdev[rhport].ud.status); > + vhci_hcd->port_status[rhport] |= USB_PORT_STAT_ENABLE; > > if (hcd->speed < HCD_USB3) { > switch (vhci_hcd->vdev[rhport].speed) { > How did you find this problem? Does the port get into stuck state while attaching to a remote usbip device on the host? thanks, -- Shuah