Re: [RFC] Fix scan enable/disable kernel issue for opening socket

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

 



Hi Marcel,

On Fri, Oct 30, 2015 at 8:56 PM, Marcel Holtmann <marcel@xxxxxxxxxxxx> wrote:
> Hi Jakub,
>
>> Issue (on all kernels, including bluetooth-next and latest 4.3 kernel):
>> 1. in bluetoothd pair to two BLE devices using random address
>> (AA:BB:CC:DD:EE:FF and FF:EE:DD:CC:BB:AA), that don't use autoconnect.
>> 2. Make sure all those devices don't advertise.
>> 3. call Device1.Connect() on both devices at same time, with scan
>> initially disabled.
>> 4. Second request will fail right away, instead of timeout in 45
>> seconds (if it doesn't fail repeat, it's a race condition and happens
>> once every time, trying with more, i.e. 5 devices at same time gives
>> bigger change).
>>
>> When calling Device1.Connect() twice, bluetoothd will try to open two
>> sockets, each to different random address device.
>> 1 Inside kernel, for first socket, scan state is checked,and
>> HCI_OP_SET_SCAN_ENABLE is scheduled, but not yet executed.
>> 2. Same happens for second socket - current scan state is checked, and
>> HCI_OP_SET_SCAN_ENABLE is scheduled.
>> 3. Now both HCI_OP_SET_SCAN_ENABLE are executed, second will fail,
>> because first one already enabled scan.
>
> I think that is the fundamental problem here. The state machine is bogus. I said this many time before, in general the scanning needs to be disabled first, whitelist re-programmed and then scanning resumed. The fact that an L2CAP connect() for ATT might be triggered at the same time is really not any reason to not have a proper state machine behind this.
>

The state machine is good, it properly checks all conditions and
schedule commands that are correct at THAT time, but they're being
send to controller later, at different moment in time, at which they
might no longer be correct, because of other commands that were
executed in mean time.

>> To solve this kind of issues, I want to propose adding inside kernel
>> virtual HCI commands, that might be scheduled in hci_request. Virtual
>> HCI command will be able to do some very basic check (i.e. check scan
>> state) and might cause real HCI command to be issued.
>>
>> Commands I'd like to add:
>> VIRT_HCI_SCAN_DISABLE_START - check scan state, remember it, and send
>> HCI_OP_SET_SCAN_ENABLE(enable=false) if it was enabled
>> VIRT_HCI_SCAN_DISABLE_STOP - bring scan state back to state remembered
>> in VIRT_HCI_SCAN_DISABLE_START
>> Those commands must be both scheduled in hci_request, having only one
>> of them in hci_request would be error.
>>
>> VIRT_HCI_SCAN_ENABLE - this command will check current scan state, and
>> send HCI_OP_SET_SCAN_ENABLE(enable=true) if scan was disabled
>> VIRT_HCI_SCAN_DISABLE - this command will check current scan state,
>> and send HCI_OP_SET_SCAN_ENABLE(enable=false) if scan was enabled
>
> This approach does not sound right at all. And honestly I do not see a need for adding such a complex overhead. It is like fixing symptoms. What we need to fix is the root cause.

So after all playing I've done with that right now, only one command
was needed, HCI_OP_VIRT_LE_SCAN_DISABLED - it solves all problems so
far.

>
> And what I like to see is that we actually have mgmt-tester and l2cap-tester test cases first that expose this issue. Then we can ensure that we never break this behavior anymore.

I'll add mgmt-tester test case for that. Going through it will explain
the problem much better.
Hope that when going through it you'll either get convinced that it's
really needed, or proof me wrong.

Jakub

>
> Regards
>
> Marcel
>
--
To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[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