* [PATCH BlueZ] transport: Complete Acquire for Sink ASE entering Enabling
@ 2026-06-09 21:11 Simon Mikuda
2026-06-09 23:04 ` [BlueZ] " bluez.test.bot
2026-06-10 18:40 ` [PATCH BlueZ] " patchwork-bot+bluetooth
0 siblings, 2 replies; 3+ messages in thread
From: Simon Mikuda @ 2026-06-09 21:11 UTC (permalink / raw)
To: linux-bluetooth; +Cc: Simon Mikuda
On the QoS to Enabling transition the IO is not yet available because
the CIS is not established, so the handler returns early and a pending
Acquire is left unanswered once the IO later arrives.
Notify the connecting callbacks once the fd is attached so the
transport can re-run the Enabling handling and complete the Acquire.
---
profiles/audio/transport.c | 7 +++++++
src/shared/bap.c | 28 +++++++++++++++++++---------
2 files changed, 26 insertions(+), 9 deletions(-)
diff --git a/profiles/audio/transport.c b/profiles/audio/transport.c
index 4b9d26c5e..22a755064 100644
--- a/profiles/audio/transport.c
+++ b/profiles/audio/transport.c
@@ -2397,6 +2397,13 @@ static void bap_connecting(struct bt_bap_stream *stream, bool state, int fd,
return;
bap_update_links(transport);
+
+ /* IO connected; re-run Enabling to complete a deferred Acquire. */
+ if (!state && fd >= 0 && bt_bap_stream_get_state(stream) ==
+ BT_BAP_STREAM_STATE_ENABLING)
+ bap_state_changed(stream, BT_BAP_STREAM_STATE_ENABLING,
+ BT_BAP_STREAM_STATE_ENABLING,
+ user_data);
}
static bool transport_bap_is_playback(struct media_transport *transport)
diff --git a/src/shared/bap.c b/src/shared/bap.c
index deb85b264..09f671a15 100644
--- a/src/shared/bap.c
+++ b/src/shared/bap.c
@@ -3006,6 +3006,20 @@ static bool bap_stream_io_attach(struct bt_bap_stream *stream, int fd,
return true;
}
+static void bap_stream_notify_connecting(struct bt_bap_stream *stream,
+ bool connecting, int fd)
+{
+ const struct queue_entry *entry;
+
+ for (entry = queue_get_entries(stream->bap->state_cbs); entry;
+ entry = entry->next) {
+ struct bt_bap_state *state = entry->data;
+
+ if (state->connecting)
+ state->connecting(stream, connecting, fd, state->data);
+ }
+}
+
static void bap_stream_set_io(void *data, void *user_data)
{
struct bt_bap_stream *stream = data;
@@ -3042,6 +3056,10 @@ static void bap_stream_set_io(void *data, void *user_data)
bt_bap_stream_stop(stream, NULL, NULL);
break;
}
+
+ /* Notify IO connected so transports can complete pending requests. */
+ if (fd >= 0)
+ bap_stream_notify_connecting(stream, false, fd);
}
static void ascs_ase_rsp_add_errno(struct iovec *iov, uint8_t id, int err)
@@ -7028,7 +7046,6 @@ static void bap_stream_io_connecting(void *data, void *user_data)
{
struct bt_bap_stream *stream = data;
int fd = PTR_TO_INT(user_data);
- const struct queue_entry *entry;
if (!stream)
return;
@@ -7038,14 +7055,7 @@ static void bap_stream_io_connecting(void *data, void *user_data)
else
bap_stream_io_detach(stream);
- for (entry = queue_get_entries(stream->bap->state_cbs); entry;
- entry = entry->next) {
- struct bt_bap_state *state = entry->data;
-
- if (state->connecting)
- state->connecting(stream, stream->io ? true : false,
- fd, state->data);
- }
+ bap_stream_notify_connecting(stream, stream->io ? true : false, fd);
}
int bt_bap_stream_io_connecting(struct bt_bap_stream *stream, int fd)
--
2.43.0
^ permalink raw reply related [flat|nested] 3+ messages in thread
* RE: [BlueZ] transport: Complete Acquire for Sink ASE entering Enabling
2026-06-09 21:11 [PATCH BlueZ] transport: Complete Acquire for Sink ASE entering Enabling Simon Mikuda
@ 2026-06-09 23:04 ` bluez.test.bot
2026-06-10 18:40 ` [PATCH BlueZ] " patchwork-bot+bluetooth
1 sibling, 0 replies; 3+ messages in thread
From: bluez.test.bot @ 2026-06-09 23:04 UTC (permalink / raw)
To: linux-bluetooth, simon.mikuda
[-- Attachment #1: Type: text/plain, Size: 1600 bytes --]
This is automated email and please do not reply to this email!
Dear submitter,
Thank you for submitting the patches to the linux bluetooth mailing list.
This is a CI test results with your patch series:
PW Link:https://patchwork.kernel.org/project/bluetooth/list/?series=1108826
---Test result---
Test Summary:
CheckPatch PASS 0.38 seconds
GitLint PASS 0.25 seconds
BuildEll PASS 18.46 seconds
BluezMake PASS 675.35 seconds
MakeCheck PASS 15.28 seconds
MakeDistcheck PASS 227.96 seconds
CheckValgrind PASS 260.62 seconds
CheckSmatch WARNING 315.70 seconds
bluezmakeextell PASS 170.28 seconds
IncrementalBuild PASS 665.24 seconds
ScanBuild PASS 938.94 seconds
Details
##############################
Test: CheckSmatch - WARNING
Desc: Run smatch tool with source
Output:
src/shared/bap.c:317:25: warning: array of flexible structuressrc/shared/bap.c: note: in included file:./src/shared/ascs.h:88:25: warning: array of flexible structuressrc/shared/bap.c:317:25: warning: array of flexible structuressrc/shared/bap.c: note: in included file:./src/shared/ascs.h:88:25: warning: array of flexible structuressrc/shared/bap.c:317:25: warning: array of flexible structuressrc/shared/bap.c: note: in included file:./src/shared/ascs.h:88:25: warning: array of flexible structures
https://github.com/bluez/bluez/pull/2210
---
Regards,
Linux Bluetooth
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH BlueZ] transport: Complete Acquire for Sink ASE entering Enabling
2026-06-09 21:11 [PATCH BlueZ] transport: Complete Acquire for Sink ASE entering Enabling Simon Mikuda
2026-06-09 23:04 ` [BlueZ] " bluez.test.bot
@ 2026-06-10 18:40 ` patchwork-bot+bluetooth
1 sibling, 0 replies; 3+ messages in thread
From: patchwork-bot+bluetooth @ 2026-06-10 18:40 UTC (permalink / raw)
To: Simon Mikuda; +Cc: linux-bluetooth
Hello:
This patch was applied to bluetooth/bluez.git (master)
by Luiz Augusto von Dentz <luiz.von.dentz@intel.com>:
On Tue, 9 Jun 2026 23:11:29 +0200 you wrote:
> On the QoS to Enabling transition the IO is not yet available because
> the CIS is not established, so the handler returns early and a pending
> Acquire is left unanswered once the IO later arrives.
>
> Notify the connecting callbacks once the fd is attached so the
> transport can re-run the Enabling handling and complete the Acquire.
>
> [...]
Here is the summary with links:
- [BlueZ] transport: Complete Acquire for Sink ASE entering Enabling
https://git.kernel.org/pub/scm/bluetooth/bluez.git/?id=3047c2a4c5ea
You are awesome, thank you!
--
Deet-doot-dot, I am a bot.
https://korg.docs.kernel.org/patchwork/pwbot.html
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2026-06-10 18:40 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-06-09 21:11 [PATCH BlueZ] transport: Complete Acquire for Sink ASE entering Enabling Simon Mikuda
2026-06-09 23:04 ` [BlueZ] " bluez.test.bot
2026-06-10 18:40 ` [PATCH BlueZ] " patchwork-bot+bluetooth
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox