[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <eb5715b5-613a-4610-9852-1a6ae67b4153@rowland.harvard.edu>
Date: Mon, 22 Dec 2025 08:34:14 -0500
From: Alan Stern <stern@...land.harvard.edu>
To: 胡连勤 <hulianqin@...o.com>
Cc: Michal Pecio <michal.pecio@...il.com>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
Lee Jones <lee@...nel.org>,
Mathias Nyman <mathias.nyman@...ux.intel.com>,
Mathias Nyman <mathias.nyman@...el.com>,
Sarah Sharp <sarah.a.sharp@...ux.intel.com>,
"linux-usb@...r.kernel.org" <linux-usb@...r.kernel.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
Subject: Re: 答复: [PATCH] usb: xhci: check
Null pointer in segment alloc
On Mon, Dec 22, 2025 at 12:21:09PM +0000, 胡连勤 wrote:
> Hi Michal:
>
> > On Mon, 22 Dec 2025 08:13:21 +0100, Greg Kroah-Hartman wrote:
> > > > An API that insists on its users exercising care, knowledge and
> > > > cognisance sounds fragile and vulnerable.
> > >
> > > Fragile yes, vulnerable no. Let's fix the fragility then, but as has
> > > been pointed out in this thread, we don't know the root cause, and I
> > > don't even think this "fix" would do the right thing anyway.
> >
> > The patch looks wrong. I suspect this happens when add_endpoint() is called
> > concurrently with resume(), which makes little sense. And it means the same
> > code can probably call add_endpoint() before resume(), which makes no
> > sense either. We can't do that with suspended HW.
> >
> > Chances are that this crash isn't even the only thing that could go wrong
> > when such calls are attempted. For one, xhci_resume() drops the spinlock
> > after reporting usb_root_hub_lost_power(), so your guess elsewhere was
> > correct - this code isn't even locked properly.
> >
> > It seems no operations on USB devices during resume() are expected.
Let's be more precise. No extraneous operations are expected on a USB
device while that device is being resumed (i.e., no operations other
than those directly involved with the resume itself). However,
operations on a USB hub or controller are expected and allowed while a
downstream device is being resumed.
> Currently, after checking the logic of our KO section,
> we found that there might be two places simultaneously calling snd_usb_autoresume to wake up the headset device.
That should not make any difference, because the PM core serializes
runtime resume calls. If concurrent autoresume calls can cause a crash
then there is a bug somewhere. Maybe in a sound driver, maybe in a USB
driver, and maybe in the PM core.
To track down the bug, it would help to log the start and end of the
resume call, as well as the add_endpoint() call that gets into trouble.
Alan Stern
Powered by blists - more mailing lists