[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <6bed0cff-c2be-4111-a1d3-14ce0e3309db@amlogic.com>
Date: Thu, 3 Jul 2025 17:19:05 +0800
From: Yang Li <yang.li@...ogic.com>
To: Luiz Augusto von Dentz <luiz.dentz@...il.com>
Cc: Marcel Holtmann <marcel@...tmann.org>,
Johan Hedberg <johan.hedberg@...il.com>,
"David S. Miller" <davem@...emloft.net>, Eric Dumazet <edumazet@...gle.com>,
Jakub Kicinski <kuba@...nel.org>, Paolo Abeni <pabeni@...hat.com>,
Simon Horman <horms@...nel.org>, linux-bluetooth@...r.kernel.org,
netdev@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH] Bluetooth: hci_core: lookup pa sync need check BIG sync
state
Hi luiz,
> [ EXTERNAL EMAIL ]
>
> Hi,
>
> On Tue, Jul 1, 2025 at 9:18 PM Yang Li via B4 Relay
> <devnull+yang.li.amlogic.com@...nel.org> wrote:
>> From: Yang Li <yang.li@...ogic.com>
>>
>> Ignore the big sync connections, we are looking for the PA
>> sync connection that was created as a result of the PA sync
>> established event.
> Were you seeing an issue with this, if you do please describe it and
> add the traces, debug logs, etc.
connect list:
[ 61.826679][2 T1974 d.] list conn: conn 00000000a6e8ac83 handle
0x0f01 state 1, flags 0x40000220
pa_sync_conn.flags = HCI_CONN_PA_SYNC
[ 61.827155][2 T1974 d.] list conn: conn 0000000073b03cb6 handle
0x0100 state 1, flags 0x48000220
[ 61.828254][2 T1974 d.] list conn: conn 00000000a7e091c9 handle
0x0101 state 1, flags 0x48000220
big_sync_conn.flags = HCI_CONN_PA_SYNC | HCI_CONN_BIG_SYNC
If the PA sync connection is deleted, then when hci_le_big_sync_lost_evt
is executed, hci_conn_hash_lookup_pa_sync_handle should return NULL,
However, it currently returns the BIS1 connection instead, because bis
conn also has HCI_CONN_PA_SYNC set.
Therefore, I added an HCI_CONN_BIG_SYNC check in
hci_conn_hash_lookup_pa_sync_handle to filter out BIS connections.
>
>> Signed-off-by: Yang Li <yang.li@...ogic.com>
>> ---
>> include/net/bluetooth/hci_core.h | 7 +++++++
>> 1 file changed, 7 insertions(+)
>>
>> diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h
>> index 3ce1fb6f5822..646b0c5fd7a5 100644
>> --- a/include/net/bluetooth/hci_core.h
>> +++ b/include/net/bluetooth/hci_core.h
>> @@ -1400,6 +1400,13 @@ hci_conn_hash_lookup_pa_sync_handle(struct hci_dev *hdev, __u16 sync_handle)
>> if (c->type != BIS_LINK)
>> continue;
>>
>> + /* Ignore the big sync connections, we are looking
>> + * for the PA sync connection that was created as
>> + * a result of the PA sync established event.
>> + */
>> + if (test_bit(HCI_CONN_BIG_SYNC, &c->flags))
>> + continue;
>> +
> hci_conn_hash_lookup_pa_sync_big_handle does:
>
> if (c->type != BIS_LINK ||
> !test_bit(HCI_CONN_PA_SYNC, &c->flags))
Please forgive my misunderstanding.
>
>> /* Ignore the listen hcon, we are looking
>> * for the child hcon that was created as
>> * a result of the PA sync established event.
>>
>> ---
>> base-commit: 3bc46213b81278f3a9df0324768e152de71eb9fe
>> change-id: 20250701-pa_sync-2fc7fc9f592c
>>
>> Best regards,
>> --
>> Yang Li <yang.li@...ogic.com>
>>
>>
>
> --
> Luiz Augusto von Dentz
Powered by blists - more mailing lists