From 429756e59184ae09ab7764fcbaa7f0c69e8fd929 Mon Sep 17 00:00:00 2001 From: Benjamin Lucke Date: Tue, 31 Oct 2023 07:20:05 +0100 Subject: [PATCH] Bluetooth: TBS: Fixed return call_index 0 after overflow Fixed range of call_index 1 to 255, since 0 is reserved for outgoing calls. Signed-off-by: Benjamin Lucke --- subsys/bluetooth/audio/tbs.c | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/subsys/bluetooth/audio/tbs.c b/subsys/bluetooth/audio/tbs.c index 9159d2b23247dc..86588c11c7140d 100644 --- a/subsys/bluetooth/audio/tbs.c +++ b/subsys/bluetooth/audio/tbs.c @@ -307,18 +307,21 @@ static void tbs_set_terminate_reason(struct tbs_service_inst *inst, static uint8_t next_free_call_index(void) { for (int i = 0; i < CONFIG_BT_TBS_MAX_CALLS; i++) { - static uint8_t next_call_index = 1; - const struct bt_tbs_call *call = lookup_call(next_call_index); - - if (call == NULL) { - return next_call_index++; - } + static uint8_t next_call_index; + const struct bt_tbs_call *call; + /* For each new call, the call index should be incremented */ next_call_index++; - if (next_call_index == UINT8_MAX) { + + if (next_call_index == BT_TBS_FREE_CALL_INDEX) { /* call_index = 0 reserved for outgoing calls */ next_call_index = 1; } + + call = lookup_call(next_call_index); + if (call == NULL) { + return next_call_index; + } } LOG_DBG("No more free call spots");