Re: [PATCH v2] Bluetooth: Use hci_conn data to handle failed LE Connection Complete

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

 



Hi Andrzej/Marcel,

On Thu, May 17, 2012 at 5:05 AM, Andrzej Kaczmarek
<andrzej.kaczmarek@xxxxxxxxx> wrote:
> Hi Marcel,
>
>
> On 16.05.2012 23:48, Marcel Holtmann wrote:
>>>>>
>>>>>       hci_dev_lock(hdev);
>>>>>
>>>>> +     if (ev->status) {
>>>>> +             conn = hci_conn_hash_lookup_state(hdev, LE_LINK,
>>>>> BT_CONNECT);
>>>>> +             if (!conn)
>>>>> +                     goto unlock;
>>>>> +
>>>>> +             mgmt_connect_failed(hdev,&conn->dst, conn->type,
>>>>>
>>>>> +                                 conn->dst_type, ev->status);
>>>>> +             hci_proto_connect_cfm(conn, ev->status);
>>>>> +             conn->state = BT_CLOSED;
>>>>> +             hci_conn_del(conn);
>>>>> +             goto unlock;
>>>>> +     }
>>>>> +
>>>>>       conn = hci_conn_hash_lookup_ba(hdev, LE_LINK,&ev->bdaddr);
>>>>>       if (!conn) {
>>>>>               conn = hci_conn_add(hdev, LE_LINK,&ev->bdaddr);
>>>>
>>>>
>>>> this change is wrong. We are now treating every single adapter as being
>>>> broken. That is not acceptable.
>>>
>>>
>>> Why do you think these adapters are broken? As I explained in cover
>>> letter for v1, spec does not require peer address to be provided in
>>> Connection Complete which is reasonable since we can only have one
>>> pending connection request. Also as Claudio and Andre noticed such
>>> behaviour could be to simplify whitelist implementation - in case of
>>> connection request using whitelist it does not make sense to include
>>> specific peer address in event.
>>
>>
>> what has whitelist behavior to do with this event in the failure case?
>
>
> Just a sidenote on why some vendors may want to omit BD_ADDR and it does not
> make adapter broken. Not directly related to this scenario.

I was taking a look at Core spec change request document [1] and I found this:

Erratum 4215, LE connection complete event missing exception
"... On failure, for this event, all other parameters are not valid."

It clearly states this is an expected behavior and nullify those
parameters doesn't make the adapter broken.

Thus, in case of failure, we should not rely on those parameters
(BD_ADDR included) in order to properly handle LE Connection Complete
Events.

>>>> We should only add a tweak if the BD_ADDR parameter is BDADDR_ANY and
>>>> not as a general rule. In addition if we do this, we need to print a
>>>> warning to dmesg to make this known.
>>>
>>>
>>> Perhaps we can just add warning in case BD_ADDR is not BDADDR_ANY and
>>> we cannot find hci_conn for it - in such case most probably something
>>> went wrong.
>>
>>
>> What are the adapters from Broadcom, CSR, TI and ST are returning in a
>> failure case? Are they all omitting the BD_ADDR value?
>
>
> No, I noticed this on BCM and based on previous comments it seems that this
> is what BCM and ST(E) are doing while CSR and TI return BD_ADDR. Except that
> previously I was using ST-E chip which did return BD_ADDR so this is not
> even consistent per manufacturer.
>
> As said before, omitted BD_ADDR seems to be fine from spec perspective so we
> should not require it to be present. Since we can have only one LE hci_conn
> in BT_CONNECT state it's reasonable to use it here. This is already in
> patch.
>
> What could be indeed added to this patch is warning message in case BD_ADDR
> is not BDADDR_ANY and it does not match one stored in hci_conn (either
> adapter returns random BD_ADDR which is weird or something went wrong).

IMO, this warning message is not really necessary.

BR,

Andre

[1] - https://www.bluetooth.org/Technical/Specifications/enhancements.htm
(must be signed in Bluetooth SIG)
--
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