Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp721360yba; Thu, 16 May 2019 07:57:33 -0700 (PDT) X-Google-Smtp-Source: APXvYqxt9ldqpljp+cAy0TGybPiaaLHGd2hngzKFslA1yrgM2vtkE8PGcMi1AiUydqQuRovR/tby X-Received: by 2002:a17:902:e683:: with SMTP id cn3mr28130017plb.86.1558018653785; Thu, 16 May 2019 07:57:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558018653; cv=none; d=google.com; s=arc-20160816; b=jlqAGBEYwS9AJ6xCsMDJ9+ObZErvM1A1xyEnJu8cMKDhZqDJDelcTBdQ5V4FUb+dac g6j1P8kqlUS8sCVnbdMVrUZvDbe1dZWqYwCzcJhH+xgRV4c/BuJcxoxQwotbLa4twQsi ecuevMtDrmK8/HjdnhjzOEwN5QAx/oSaJp+5t3tUBxuwrmxjSt9jbCZNkTymRDVmZcLY UjG2LNGdPpZ3MDj/1hrdrwgG4Xw9noXfK3IvoN6dRqSfOLTtuNr9gkVb02XbtprTyK7L JvAr0A8CgEMILV8T/lf3+iZyuyy8ZUSbxXy6pQau2uxKR/hKadjilWmaOKK1ZDftWA+T 8msw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:in-reply-to :subject:cc:to:from:date; bh=WH4nLU4z71vBVVwdAJ6q80tfwglrpKvR18gPLxwONAQ=; b=M93Z3CqMZMXwrARxL8oVsL9oFWya0mkO0ZVvVr6kucMoDp8u0K3OVQ2rlYqoh3bLIo SzqGG8CXAn83Z3ksV//zacQECAc95ZsApM3agodWGZwe3FIAAs5Klfcbz3roPazJpMFX C99UldvutBKkci8jyOYJmJV5L+kBcMNIrzD2yBjVPI1CRPecFZk9FPBQz3jA4TWT7qqP Gd3cu+acB1l+vX9CFOH7vb13Erms7yHjmYdQt/4iiX5RjWrY+nw0jvuhwB4vM65oaJvX Ij909R9HgfDl/x1W7cBQ7pnJJbZKuEa4Pgl9LX3LJi7rQ0+5BxxcTNA8eC2HffUUSgTD NyKA== ARC-Authentication-Results: i=1; mx.google.com; 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 h34si5158893pld.42.2019.05.16.07.57.18; Thu, 16 May 2019 07:57:33 -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; 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 S1727539AbfEPO4H (ORCPT + 99 others); Thu, 16 May 2019 10:56:07 -0400 Received: from iolanthe.rowland.org ([192.131.102.54]:40114 "HELO iolanthe.rowland.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1727464AbfEPO4E (ORCPT ); Thu, 16 May 2019 10:56:04 -0400 Received: (qmail 2248 invoked by uid 2102); 16 May 2019 10:56:02 -0400 Received: from localhost (sendmail-bs@127.0.0.1) by localhost with SMTP; 16 May 2019 10:56:02 -0400 Date: Thu, 16 May 2019 10:56:02 -0400 (EDT) From: Alan Stern X-X-Sender: stern@iolanthe.rowland.org To: Jim Lin cc: gregkh@linuxfoundation.org, , , , , , , , , Subject: Re: [PATCH v10 1/2] usb: xhci : Add devaddr in struct usb_device In-Reply-To: <1558017657-13835-2-git-send-email-jilin@nvidia.com> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 16 May 2019, Jim Lin wrote: > The Clear_TT_Buffer request sent to the hub includes the address of > the LS/FS child device in wValue field. usb_hub_clear_tt_buffer() > uses udev->devnum to set the address wValue. This won't work for > devices connected to xHC. > > For other host controllers udev->devnum is the same as the address of > the usb device, chosen and set by usb core. With xHC the controller > hardware assigns the address, and won't be the same as devnum. > > Here we add devaddr in "struct usb_device" for > usb_hub_clear_tt_buffer() to use. > > Signed-off-by: Jim Lin > --- Aside from the "xhci:" part of the Subject line (it's not really appropriate because this is a modification of the USB core more than of the xhci-hcd driver), Acked-by: Alan Stern > v2: xhci_clear_tt_buffer_complete: add static, shorter indentation > , remove its claiming in xhci.h > v3: Add description for clearing_tt (xhci.h) > v4: Remove clearing_tt flag because hub_tt_work has hub->tt.lock > to protect for Clear_TT_Buffer to be run serially. > Remove xhci_clear_tt_buffer_complete as it's not necessary. > Same reason as the above. > Extend usb_hub_clear_tt_buffer parameter > v5: Not extending usb_hub_clear_tt_buffer parameter > Add description. > v6: Remove unused parameter slot_id from xhci_clear_hub_tt_buffer > v7: Add devaddr field in "struct usb_device" > v8: split as two patches, change type from int to u8 for devaddr. > v9: Use pahole to find place to put devaddr in struct usb_device. > Remove space between type cast and variable. > hub.c changed from v8 > clear->devinfo |= (u16) (udev->devaddr << 4); > to > clear->devinfo |= ((u16)udev->devaddr) << 4; > to solve a problem if devaddr is larger than 16. > v10 Initialize devaddr in xhci_setup_device() > Move devaddr to be below "u8 level" > > drivers/usb/core/hub.c | 4 +++- > drivers/usb/host/xhci.c | 1 + > include/linux/usb.h | 2 ++ > 3 files changed, 6 insertions(+), 1 deletion(-) > > diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c > index 15a2934dc29d..0d4b289be103 100644 > --- a/drivers/usb/core/hub.c > +++ b/drivers/usb/core/hub.c > @@ -873,7 +873,7 @@ int usb_hub_clear_tt_buffer(struct urb *urb) > /* info that CLEAR_TT_BUFFER needs */ > clear->tt = tt->multi ? udev->ttport : 1; > clear->devinfo = usb_pipeendpoint (pipe); > - clear->devinfo |= udev->devnum << 4; > + clear->devinfo |= ((u16)udev->devaddr) << 4; > clear->devinfo |= usb_pipecontrol(pipe) > ? (USB_ENDPOINT_XFER_CONTROL << 11) > : (USB_ENDPOINT_XFER_BULK << 11); > @@ -2125,6 +2125,8 @@ static void update_devnum(struct usb_device *udev, int devnum) > /* The address for a WUSB device is managed by wusbcore. */ > if (!udev->wusb) > udev->devnum = devnum; > + if (!udev->devaddr) > + udev->devaddr = (u8)devnum; > } > > static void hub_free_dev(struct usb_device *udev) > diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c > index 7fa58c99f126..68b393e5a453 100644 > --- a/drivers/usb/host/xhci.c > +++ b/drivers/usb/host/xhci.c > @@ -4096,6 +4096,7 @@ static int xhci_setup_device(struct usb_hcd *hcd, struct usb_device *udev, > /* Zero the input context control for later use */ > ctrl_ctx->add_flags = 0; > ctrl_ctx->drop_flags = 0; > + udev->devaddr = (u8)(le32_to_cpu(slot_ctx->dev_state) & DEV_ADDR_MASK); > > xhci_dbg_trace(xhci, trace_xhci_dbg_address, > "Internal device address = %d", > diff --git a/include/linux/usb.h b/include/linux/usb.h > index 4229eb74bd2c..af68e31118f8 100644 > --- a/include/linux/usb.h > +++ b/include/linux/usb.h > @@ -580,6 +580,7 @@ struct usb3_lpm_parameters { > * @bus_mA: Current available from the bus > * @portnum: parent port number (origin 1) > * @level: number of USB hub ancestors > + * @devaddr: device address, XHCI: assigned by HW, others: same as devnum > * @can_submit: URBs may be submitted > * @persist_enabled: USB_PERSIST enabled for this device > * @have_langid: whether string_langid is valid > @@ -663,6 +664,7 @@ struct usb_device { > unsigned short bus_mA; > u8 portnum; > u8 level; > + u8 devaddr; > > unsigned can_submit:1; > unsigned persist_enabled:1; >