RE: [bluetooth-next V2] Bluetooth: handle device reset event

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




> -----Original Message-----
> From: Marcel Holtmann [mailto:marcel@xxxxxxxxxxxx]
> Sent: Wednesday, March 10, 2010 6:49 PM
> To: Winkler, Tomas
> Cc: linux-bluetooth@xxxxxxxxxxxxxxx; Cohen, Guy; Rindjunsky, Ron; Paskar,
> Gregory
> Subject: RE: [bluetooth-next V2] Bluetooth: handle device reset event
> 
> Hi Tomas,
> 
> > > > A Bluetooth device experiencing hardware failure may issue
> > > > a HARDWARE_ERROR hci event. The reaction to this event is device
> > > > reset flow implemented in following sequence.
> > > >
> > > > 1. Notify: HCI_DEV_DOWN
> > > > 2. Reinitialize internal structures.
> > > > 3. Call driver flush function
> > > > 4. Send HCI reset request to the device.
> > > > 5. Send HCI init sequence reset to the device.
> > > > 6. Notify HCI_DEV_UP.
> > >
> > > I prefer if we create a generic per controller workqueue first before
> > > having a workqueue for every task. Something similar to what the
> > > mac80211 layer offers right now.
> >
> > That would be good approach but we are using default kernel workqueue in
> this solution so there is no workqueue for every task.
> > I'm not sure if this effort should block this patch.
> 
> I have an initial patch that I have to dig out. It is actually not that
> complicated. And I would prefer to get that one first before we apply
> this patch.

Okay, I can test this particular flow with your patch if you send it to me.

> The reason why I really wanna solve this is because of potential race
> conditions between the workqueue and a device removal. I have a bad
> feeling that even with the current sysfs workqueue we have a race
> condition hiding somewhere. So if going forward we have to shift more
> and more code into workqueues we need a single point where this can be
> fixed.

Understood.

In that context I would need to do some more instrumentation to test this kind of race for this feature. 

> > > Also in a second step we might wanna move the HCI event processing
> > > completely into a workqueue. If we get no performance hit with that,
> > > then sysfs handling and device reset becomes a lot simpler and less
> > > prone to race conditions with device removal.
> >
> > Looks good to me. So when this is ready we can move also the reset also to
> per controller queue.
> 
> I haven't done any performance testing with this approach. So I hope we
> are not shooting ourselves in the foot with it.

Thanks
Tomas
---------------------------------------------------------------------
Intel Israel (74) Limited

This e-mail and any attachments may contain confidential material for
the sole use of the intended recipient(s). Any review or distribution
by others is strictly prohibited. If you are not the intended
recipient, please contact the sender and delete all copies.
��.n��������+%������w��{.n�����{����^n�r������&��z�ޗ�zf���h���~����������_��+v���)ߣ�m


[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux