All of lore.kernel.org
 help / color / mirror / Atom feed
* [RFC] Question about reset order for xhci controller and pci
@ 2019-04-26  3:07 Tangnianyao (ICT)
  2019-04-29  2:33 ` Tangnianyao (ICT)
  0 siblings, 1 reply; 5+ messages in thread
From: Tangnianyao (ICT) @ 2019-04-26  3:07 UTC (permalink / raw)
  To: mathias.nyman, gregkh, linux-usb, linux-kernel, tangnianyao

Hi,all

I've meet a problem about reset xhci and it may be caused by the
reset order of pci and xhci.
Using xhci-pci, when users send reset command in os(centos or red-hat os),
it would first reset PCI device by pci_reset_function. During this
process, it would disable BME(Bus Master Enable) and set BME=0, and
then enable it and set BME=1.
And then it comes to xhci reset process. First, it would send an
endpoint stop command in xhci_urb_dequeue. However, this stop ep command
fails to finish. The reason is that BME is set to 0 in former process and
xhci RUN/STOP changes to 0, and when BME is set to 1 again, RUN/STOP doesn't
recover to 1.
I've checked BME behavior in xhci spec, it shows that "If the BME bit is set to 0
when xHC is running, the xHC may treat this as a Host Controller Error, asserting
HCE(1) and immediately halt(R/S=0 and HCH=1). Recovery from this state will
require an HCRST." It seems that the stop ep command failure is reasonable.
Maybe I've missed something and please let me know.

linux version:5.0.0-rc3

Thanks,
Nianyao Tang


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2019-04-30 14:17 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-04-26  3:07 [RFC] Question about reset order for xhci controller and pci Tangnianyao (ICT)
2019-04-29  2:33 ` Tangnianyao (ICT)
2019-04-29 14:06   ` Alan Stern
2019-04-30  6:41     ` Tangnianyao (ICT)
2019-04-30 14:17       ` Alan Stern

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.