From: Alan Stern <stern@rowland.harvard.edu> To: Sudip Mukherjee <sudipm.mukherjee@gmail.com> Cc: Mathias Nyman <mathias.nyman@linux.intel.com>, Andy Shevchenko <andriy.shevchenko@linux.intel.com>, Andy Shevchenko <andy.shevchenko@gmail.com>, Mathias Nyman <mathias.nyman@intel.com>, linux-usb@vger.kernel.org, lukaszx.szulc@intel.com, Christoph Hellwig <hch@lst.de>, Marek Szyprowski <m.szyprowski@samsung.com>, iommu@lists.linux-foundation.org Subject: usb HC busted? Date: Tue, 17 Jul 2018 10:28:14 -0400 (EDT) [thread overview] Message-ID: <Pine.LNX.4.44L0.1807171022001.1689-100000@iolanthe.rowland.org> (raw) On Tue, 17 Jul 2018, Sudip Mukherjee wrote: > I did some more debugging. Tested with a KASAN enabled kernel and that > shows the problem. The report is attached. > > To my understanding: > > btusb_work() is calling usb_set_interface() with alternate = 0. which > again calls usb_hcd_alloc_bandwidth() and that frees the rings by > xhci_free_endpoint_ring(). That doesn't sound like the right thing to do. The rings shouldn't be freed until xhci_endpoint_disable() is called. On the other hand, there doesn't appear to be any xhci_endpoint_disable() routine, although a comment refers to it. Maybe this is the real problem? Alan Stern > But then usb_set_interface() continues and > calls usb_disable_interface() -> usb_hcd_flush_endpoint()->unlink1()-> > xhci_urb_dequeue() which at the end gives the command to stop endpoint. > > In all the cycles I have tested I see that only in the fail case > handle_cmd_completion() gets called, but in the cycles where the error > is not there handle_cmd_completion() is not called with that command. > > I am not sure what is happening, and you are the best person to understand > what is happening. :) > > But for now (untill you are back from holiday and suggest a proper solution), > I made a hacky patch (attached) which is working and I donot get any > corruption after that. Both KASAN and slub debug are also happy. > > So, now waiting for you to analyze what is going on and suggest a proper > fix. > > Thanks in advance. > > -- > Regards > Sudip > --- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
WARNING: multiple messages have this Message-ID (diff)
From: Alan Stern <stern-nwvwT67g6+6dFdvTe/nMLpVzexx5G7lz@public.gmane.org> To: Sudip Mukherjee <sudipm.mukherjee-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> Cc: Mathias Nyman <mathias.nyman-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>, Mathias Nyman <mathias.nyman-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>, linux-usb-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, iommu-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org, Christoph Hellwig <hch-jcswGhMUV9g@public.gmane.org>, Andy Shevchenko <andy.shevchenko-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>, Andy Shevchenko <andriy.shevchenko-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>, lukaszx.szulc-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org Subject: Re: usb HC busted? Date: Tue, 17 Jul 2018 10:28:14 -0400 (EDT) [thread overview] Message-ID: <Pine.LNX.4.44L0.1807171022001.1689-100000@iolanthe.rowland.org> (raw) In-Reply-To: <20180717114104.irgdb5rmg2qxclgp@debian> On Tue, 17 Jul 2018, Sudip Mukherjee wrote: > I did some more debugging. Tested with a KASAN enabled kernel and that > shows the problem. The report is attached. > > To my understanding: > > btusb_work() is calling usb_set_interface() with alternate = 0. which > again calls usb_hcd_alloc_bandwidth() and that frees the rings by > xhci_free_endpoint_ring(). That doesn't sound like the right thing to do. The rings shouldn't be freed until xhci_endpoint_disable() is called. On the other hand, there doesn't appear to be any xhci_endpoint_disable() routine, although a comment refers to it. Maybe this is the real problem? Alan Stern > But then usb_set_interface() continues and > calls usb_disable_interface() -> usb_hcd_flush_endpoint()->unlink1()-> > xhci_urb_dequeue() which at the end gives the command to stop endpoint. > > In all the cycles I have tested I see that only in the fail case > handle_cmd_completion() gets called, but in the cycles where the error > is not there handle_cmd_completion() is not called with that command. > > I am not sure what is happening, and you are the best person to understand > what is happening. :) > > But for now (untill you are back from holiday and suggest a proper solution), > I made a hacky patch (attached) which is working and I donot get any > corruption after that. Both KASAN and slub debug are also happy. > > So, now waiting for you to analyze what is going on and suggest a proper > fix. > > Thanks in advance. > > -- > Regards > Sudip >
next reply other threads:[~2018-07-17 14:28 UTC|newest] Thread overview: 75+ messages / expand[flat|nested] mbox.gz Atom feed top 2018-07-17 14:28 Alan Stern [this message] 2018-07-17 14:28 ` usb HC busted? Alan Stern -- strict thread matches above, loose matches on Subject: below -- 2018-07-21 10:55 Sudip Mukherjee 2018-07-21 10:55 ` Sudip Mukherjee 2018-07-20 14:09 Alan Stern 2018-07-20 14:09 ` Alan Stern 2018-07-20 12:54 Sudip Mukherjee 2018-07-20 12:54 ` Sudip Mukherjee 2018-07-20 11:46 Mathias Nyman 2018-07-20 11:46 ` Mathias Nyman 2018-07-20 11:10 Mathias Nyman 2018-07-20 11:10 ` Mathias Nyman 2018-07-19 17:32 Sudip Mukherjee 2018-07-19 17:32 ` Sudip Mukherjee 2018-07-19 15:42 Mathias Nyman 2018-07-19 15:42 ` Mathias Nyman 2018-07-19 14:57 Alan Stern 2018-07-19 14:57 ` Alan Stern 2018-07-19 11:34 Sudip Mukherjee 2018-07-19 11:34 ` Sudip Mukherjee 2018-07-19 10:59 Mathias Nyman 2018-07-19 10:59 ` Mathias Nyman 2018-07-17 17:01 Sudip Mukherjee 2018-07-17 17:01 ` Sudip Mukherjee 2018-07-17 15:59 Sudip Mukherjee 2018-07-17 15:59 ` Sudip Mukherjee 2018-07-17 15:52 Greg Kroah-Hartman 2018-07-17 15:52 ` Greg KH 2018-07-17 15:10 Sudip Mukherjee 2018-07-17 15:10 ` Sudip Mukherjee 2018-07-17 15:08 Alan Stern 2018-07-17 15:08 ` Alan Stern 2018-07-17 14:49 Sudip Mukherjee 2018-07-17 14:49 ` Sudip Mukherjee 2018-07-17 14:40 Sudip Mukherjee 2018-07-17 14:40 ` Sudip Mukherjee 2018-07-17 14:31 Alan Stern 2018-07-17 14:31 ` Alan Stern 2018-07-17 13:53 Greg Kroah-Hartman 2018-07-17 13:53 ` Greg KH 2018-07-17 13:20 Sudip Mukherjee 2018-07-17 13:20 ` Sudip Mukherjee 2018-07-17 12:04 Greg Kroah-Hartman 2018-07-17 12:04 ` Greg KH 2018-07-17 11:41 Sudip Mukherjee 2018-07-17 11:41 ` Sudip Mukherjee 2018-06-30 21:07 Sudip Mukherjee 2018-06-30 21:07 ` Sudip Mukherjee 2018-06-29 11:41 Mathias Nyman 2018-06-29 11:41 ` Mathias Nyman 2018-06-27 12:20 Sudip Mukherjee 2018-06-27 12:20 ` Sudip Mukherjee 2018-06-27 11:59 Sudip Mukherjee 2018-06-27 11:59 ` Sudip Mukherjee 2018-06-25 16:15 Sudip Mukherjee 2018-06-25 16:15 ` Sudip Mukherjee 2018-06-21 11:01 Mathias Nyman 2018-06-21 11:01 ` Mathias Nyman 2018-06-21 0:53 Sudip Mukherjee 2018-06-21 0:53 ` Sudip Mukherjee 2018-06-08 9:07 Sudip Mukherjee 2018-06-08 9:07 ` Sudip Mukherjee 2018-06-07 7:40 Mathias Nyman 2018-06-07 7:40 ` Mathias Nyman 2018-06-06 16:45 Sudip Mukherjee 2018-06-06 16:45 ` Sudip Mukherjee 2018-06-06 16:42 Sudip Mukherjee 2018-06-06 16:42 ` Sudip Mukherjee 2018-06-06 15:36 Andy Shevchenko 2018-06-06 15:36 ` Andy Shevchenko 2018-06-06 14:12 Mathias Nyman 2018-06-06 14:12 ` Mathias Nyman 2018-06-04 15:28 Sudip Mukherjee 2018-06-03 19:37 Sudip Mukherjee 2018-05-24 13:35 Mathias Nyman
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=Pine.LNX.4.44L0.1807171022001.1689-100000@iolanthe.rowland.org \ --to=stern@rowland.harvard.edu \ --cc=andriy.shevchenko@linux.intel.com \ --cc=andy.shevchenko@gmail.com \ --cc=hch@lst.de \ --cc=iommu@lists.linux-foundation.org \ --cc=linux-usb@vger.kernel.org \ --cc=lukaszx.szulc@intel.com \ --cc=m.szyprowski@samsung.com \ --cc=mathias.nyman@intel.com \ --cc=mathias.nyman@linux.intel.com \ --cc=sudipm.mukherjee@gmail.com \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
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.