Lines Matching refs:ase
69 #define ASE_ID(_ase) ase->ep.status.id
186 static void ase_free(struct bt_ascs_ase *ase) in ase_free() argument
188 __ASSERT(ase && ase->conn, "Non-existing ASE"); in ase_free()
190 LOG_DBG("conn %p ase %p id 0x%02x", (void *)ase->conn, ase, ase->ep.status.id); in ase_free()
192 if (ase->ep.iso != NULL) { in ase_free()
193 bt_bap_iso_unbind_ep(ase->ep.iso, &ase->ep); in ase_free()
196 bt_conn_unref(ase->conn); in ase_free()
197 ase->conn = NULL; in ase_free()
199 (void)k_work_cancel_delayable(&ase->disconnect_work); in ase_free()
200 (void)k_work_cancel_delayable(&ase->state_transition_work); in ase_free()
214 static int ase_state_notify(struct bt_ascs_ase *ase) in ase_state_notify() argument
216 struct bt_conn *conn = ase->conn; in ase_state_notify()
228 !bt_gatt_is_subscribed(conn, ase->attr, BT_GATT_CCC_NOTIFY)) { in ase_state_notify()
239 ascs_ep_get_status(&ase->ep, &ase_buf); in ase_state_notify()
249 err = bt_gatt_notify(conn, ase->attr, ase_buf.data, ntf_size); in ase_state_notify()
259 struct bt_ascs_ase *ase = CONTAINER_OF(d_work, struct bt_ascs_ase, in ascs_disconnect_stream_work_handler() local
261 struct bt_bap_ep *ep = &ase->ep; in ascs_disconnect_stream_work_handler()
276 ase, ep, stream, pair_stream); in ascs_disconnect_stream_work_handler()
314 struct bt_ascs_ase *ase = CONTAINER_OF(stream->ep, struct bt_ascs_ase, in ascs_disconnect_stream() local
319 return k_work_reschedule(&ase->disconnect_work, in ascs_disconnect_stream()
323 static void ase_enter_state_idle(struct bt_ascs_ase *ase) in ase_enter_state_idle() argument
325 struct bt_bap_stream *stream = ase->ep.stream; in ase_enter_state_idle()
330 ase->ep.receiver_ready = false; in ase_enter_state_idle()
342 ase_free(ase); in ase_enter_state_idle()
345 static void ase_enter_state_codec_configured(struct bt_ascs_ase *ase) in ase_enter_state_codec_configured() argument
347 struct bt_bap_stream *stream = ase->ep.stream; in ase_enter_state_codec_configured()
352 ase->ep.receiver_ready = false; in ase_enter_state_codec_configured()
356 ops->configured(stream, &ase->ep.qos_pref); in ase_enter_state_codec_configured()
360 static void ase_enter_state_qos_configured(struct bt_ascs_ase *ase) in ase_enter_state_qos_configured() argument
362 struct bt_bap_stream *stream = ase->ep.stream; in ase_enter_state_qos_configured()
367 ase->ep.receiver_ready = false; in ase_enter_state_qos_configured()
375 static void ase_enter_state_enabling(struct bt_ascs_ase *ase) in ase_enter_state_enabling() argument
377 struct bt_bap_stream *stream = ase->ep.stream; in ase_enter_state_enabling()
388 if (ase->ep.dir == BT_AUDIO_DIR_SINK && ase->ep.receiver_ready && ase->ep.iso != NULL && in ase_enter_state_enabling()
389 ase->ep.iso->chan.state == BT_ISO_STATE_CONNECTED) { in ase_enter_state_enabling()
390 ascs_ep_set_state(&ase->ep, BT_BAP_EP_STATE_STREAMING); in ase_enter_state_enabling()
394 static void ase_enter_state_streaming(struct bt_ascs_ase *ase) in ase_enter_state_streaming() argument
396 struct bt_bap_stream *stream = ase->ep.stream; in ase_enter_state_streaming()
407 static void ase_metadata_updated(struct bt_ascs_ase *ase) in ase_metadata_updated() argument
409 struct bt_bap_stream *stream = ase->ep.stream; in ase_metadata_updated()
420 static void ase_exit_state_streaming(struct bt_ascs_ase *ase) in ase_exit_state_streaming() argument
422 struct bt_bap_stream *stream = ase->ep.stream; in ase_exit_state_streaming()
424 const enum bt_bap_ep_state next_state = ascs_ep_get_state(&ase->ep); in ase_exit_state_streaming()
425 uint8_t reason = ase->ep.reason; in ase_exit_state_streaming()
456 static void ase_exit_state_enabling(struct bt_ascs_ase *ase) in ase_exit_state_enabling() argument
458 struct bt_bap_stream *stream = ase->ep.stream; in ase_exit_state_enabling()
460 const enum bt_bap_ep_state next_state = ascs_ep_get_state(&ase->ep); in ase_exit_state_enabling()
470 if (next_state == BT_BAP_EP_STATE_QOS_CONFIGURED && ase->ep.dir == BT_AUDIO_DIR_SINK) { in ase_exit_state_enabling()
479 static void ase_enter_state_disabling(struct bt_ascs_ase *ase) in ase_enter_state_disabling() argument
481 struct bt_bap_stream *stream = ase->ep.stream; in ase_enter_state_disabling()
486 ase->ep.receiver_ready = false; in ase_enter_state_disabling()
494 static void ase_enter_state_releasing(struct bt_ascs_ase *ase) in ase_enter_state_releasing() argument
496 struct bt_bap_stream *stream = ase->ep.stream; in ase_enter_state_releasing()
500 ase->ep.receiver_ready = false; in ase_enter_state_releasing()
513 ascs_ep_set_state(&ase->ep, BT_BAP_EP_STATE_IDLE); in ase_enter_state_releasing()
520 struct bt_ascs_ase *ase = CONTAINER_OF(d_work, struct bt_ascs_ase, state_transition_work); in state_transition_work_handler() local
521 const enum bt_bap_ep_state old_state = ascs_ep_get_state(&ase->ep); in state_transition_work_handler()
522 const enum bt_bap_ep_state new_state = ase->state_pending; in state_transition_work_handler()
525 ase->ep.status.state = new_state; in state_transition_work_handler()
528 if (ase->conn != NULL) { in state_transition_work_handler()
529 err = ase_state_notify(ase); in state_transition_work_handler()
535 ase->ep.status.state = old_state; in state_transition_work_handler()
537 err = bt_conn_get_info(ase->conn, &info); in state_transition_work_handler()
556 LOG_DBG("ase %p ep %p id 0x%02x %s -> %s", ase, &ase->ep, ase->ep.status.id, in state_transition_work_handler()
563 ase_metadata_updated(ase); in state_transition_work_handler()
573 ase_exit_state_streaming(ase); in state_transition_work_handler()
576 ase_exit_state_enabling(ase); in state_transition_work_handler()
585 ase_enter_state_idle(ase); in state_transition_work_handler()
588 ase_enter_state_codec_configured(ase); in state_transition_work_handler()
591 ase_enter_state_qos_configured(ase); in state_transition_work_handler()
594 ase_enter_state_enabling(ase); in state_transition_work_handler()
597 ase_enter_state_streaming(ase); in state_transition_work_handler()
600 ase_enter_state_disabling(ase); in state_transition_work_handler()
603 ase_enter_state_releasing(ase); in state_transition_work_handler()
612 struct bt_ascs_ase *ase = CONTAINER_OF(ep, struct bt_ascs_ase, ep); in ascs_ep_set_state() local
613 const enum bt_bap_ep_state old_state = ascs_ep_get_state(&ase->ep); in ascs_ep_set_state()
639 valid_state_transition = ase->ep.dir == BT_AUDIO_DIR_SOURCE; in ascs_ep_set_state()
646 valid_state_transition = ase->ep.dir == BT_AUDIO_DIR_SINK || in ascs_ep_set_state()
647 ase->unexpected_iso_link_loss; in ascs_ep_set_state()
674 valid_state_transition = ase->ep.dir == BT_AUDIO_DIR_SOURCE; in ascs_ep_set_state()
688 valid_state_transition = ase->ep.dir == BT_AUDIO_DIR_SOURCE; in ascs_ep_set_state()
702 ase->state_pending = state; in ascs_ep_set_state()
704 err = k_work_schedule(&ase->state_transition_work, K_NO_WAIT); in ascs_ep_set_state()
837 struct bt_ascs_ase *ase = &ascs.ase_pool[i]; in ascs_iso_accept() local
841 if (ase->conn != info->acl || in ascs_iso_accept()
842 ase->ep.cig_id != info->cig_id || in ascs_iso_accept()
843 ase->ep.cis_id != info->cis_id) { in ascs_iso_accept()
847 state = ascs_ep_get_state(&ase->ep); in ascs_iso_accept()
849 LOG_WRN("ase %p cannot accept ISO connection", ase); in ascs_iso_accept()
853 __ASSERT(ase->ep.iso != NULL, "ep %p not bound with ISO", &ase->ep); in ascs_iso_accept()
855 chan = &ase->ep.iso->chan; in ascs_iso_accept()
857 LOG_WRN("ase %p chan %p already connected", ase, chan); in ascs_iso_accept()
979 struct bt_ascs_ase *ase = CONTAINER_OF(ep, struct bt_ascs_ase, ep); in ascs_ep_iso_connected() local
997 ase->unexpected_iso_link_loss = false; in ascs_ep_iso_connected()
1046 struct bt_ascs_ase *ase = CONTAINER_OF(ep, struct bt_ascs_ase, ep); in ascs_ep_iso_disconnected() local
1065 (void)k_work_cancel_delayable(&ase->disconnect_work); in ascs_ep_iso_disconnected()
1078 ase->unexpected_iso_link_loss = true; in ascs_ep_iso_disconnected()
1176 static int ase_release(struct bt_ascs_ase *ase, uint8_t reason, struct bt_bap_ascs_rsp *rsp) in ase_release() argument
1178 enum bt_bap_ep_state state = ascs_ep_get_state(&ase->ep); in ase_release()
1194 err = unicast_server_cb->release(ase->ep.stream, rsp); in ase_release()
1206 ase->ep.reason = reason; in ase_release()
1208 ascs_ep_set_state(&ase->ep, BT_BAP_EP_STATE_RELEASING); in ase_release()
1216 struct bt_ascs_ase *ase = CONTAINER_OF(ep, struct bt_ascs_ase, ep); in bt_ascs_release_ase() local
1217 const enum bt_bap_ep_state state = ascs_ep_get_state(&ase->ep); in bt_ascs_release_ase()
1220 ase_free(ase); in bt_ascs_release_ase()
1224 return ase_release(ase, BT_HCI_ERR_LOCALHOST_TERM_CONN, BT_BAP_ASCS_RSP_NULL); in bt_ascs_release_ase()
1227 static int ase_disable(struct bt_ascs_ase *ase, uint8_t reason, struct bt_bap_ascs_rsp *rsp) in ase_disable() argument
1233 LOG_DBG("ase %p", ase); in ase_disable()
1235 ep = &ase->ep; in ase_disable()
1286 struct bt_ascs_ase *ase = CONTAINER_OF(ep, struct bt_ascs_ase, ep); in bt_ascs_disable_ase() local
1288 return ase_disable(ase, BT_HCI_ERR_LOCALHOST_TERM_CONN, BT_BAP_ASCS_RSP_NULL); in bt_ascs_disable_ase()
1294 struct bt_ascs_ase *ase = &ascs.ase_pool[i]; in disconnected() local
1296 if (ase->conn != conn) { in disconnected()
1300 if (ase->ep.status.state != BT_BAP_EP_STATE_IDLE) { in disconnected()
1309 ase->ep.reason = reason; in disconnected()
1310 ase->state_pending = BT_BAP_EP_STATE_IDLE; in disconnected()
1311 state_transition_work_handler(&ase->state_transition_work.work); in disconnected()
1374 struct bt_ascs_ase *ase = user_data; in ase_attr_cb() local
1376 if (ase->ep.status.id == POINTER_TO_UINT(BT_AUDIO_CHRC_USER_DATA(attr))) { in ase_attr_cb()
1377 ase->attr = attr; in ase_attr_cb()
1395 static void ase_init(struct bt_ascs_ase *ase, struct bt_conn *conn, uint8_t id) in ase_init() argument
1397 memset(ase, 0, sizeof(*ase)); in ase_init()
1399 ascs_ep_init(&ase->ep, id); in ase_init()
1401 ase->conn = bt_conn_ref(conn); in ase_init()
1404 bt_gatt_foreach_attr_type(0x0001, 0xffff, ASE_UUID(id), NULL, 0, ase_attr_cb, ase); in ase_init()
1406 __ASSERT(ase->attr, "ASE characteristic not found\n"); in ase_init()
1408 k_work_init_delayable(&ase->disconnect_work, ascs_disconnect_stream_work_handler); in ase_init()
1409 k_work_init_delayable(&ase->state_transition_work, state_transition_work_handler); in ase_init()
1414 struct bt_ascs_ase *ase = NULL; in ase_new() local
1420 ase = &ascs.ase_pool[i]; in ase_new()
1425 if (ase == NULL) { in ase_new()
1429 ase_init(ase, conn, id); in ase_new()
1431 LOG_DBG("conn %p new ase %p id 0x%02x", (void *)conn, ase, id); in ase_new()
1433 return ase; in ase_new()
1439 struct bt_ascs_ase *ase = &ascs.ase_pool[i]; in ase_find() local
1441 if (ase->conn == conn && ase->ep.status.id == id) { in ase_find()
1442 return ase; in ase_find()
1454 struct bt_ascs_ase *ase = NULL; in ascs_ase_read() local
1462 ase = ase_find(conn, ase_id); in ascs_ase_read()
1466 if (ase == NULL) { in ascs_ase_read()
1477 ascs_ep_get_status(&ase->ep, &ase_buf); in ascs_ase_read()
1556 static int ase_config(struct bt_ascs_ase *ase, const struct bt_ascs_config *cfg) in ase_config() argument
1566 ase, cfg->latency, cfg->phy, cfg->codec.id, cfg->codec.cid, cfg->codec.vid, in ase_config()
1572 ascs_cp_rsp_add(ASE_ID(ase), BT_BAP_ASCS_RSP_CODE_CONF_INVALID, in ase_config()
1580 ascs_cp_rsp_add(ASE_ID(ase), BT_BAP_ASCS_RSP_CODE_CONF_INVALID, in ase_config()
1591 switch (ase->ep.status.state) { in ase_config()
1601 bt_bap_ep_state_str(ase->ep.status.state)); in ase_config()
1602 ascs_cp_rsp_add(ASE_ID(ase), BT_BAP_ASCS_RSP_CODE_INVALID_ASE_STATE, in ase_config()
1610 (void)memcpy(&codec_cfg, &ase->ep.codec_cfg, sizeof(codec_cfg)); in ase_config()
1612 err = ascs_ep_set_codec(&ase->ep, cfg->codec.id, sys_le16_to_cpu(cfg->codec.cid), in ase_config()
1617 (void)memcpy(&ase->ep.codec_cfg, &codec_cfg, sizeof(codec_cfg)); in ase_config()
1618 ascs_cp_rsp_add(ASE_ID(ase), rsp.code, rsp.reason); in ase_config()
1622 if (ase->ep.stream != NULL) { in ase_config()
1625 err = unicast_server_cb->reconfig(ase->ep.stream, ase->ep.dir, in ase_config()
1626 &ase->ep.codec_cfg, &ase->ep.qos_pref, in ase_config()
1634 if (err == 0 && !bt_bap_valid_qos_pref(&ase->ep.qos_pref)) { in ase_config()
1655 (void)memcpy(&ase->ep.codec_cfg, &codec_cfg, sizeof(codec_cfg)); in ase_config()
1656 ascs_cp_rsp_add(ASE_ID(ase), rsp.code, rsp.reason); in ase_config()
1661 stream = ase->ep.stream; in ase_config()
1666 err = unicast_server_cb->config(ase->conn, &ase->ep, ase->ep.dir, in ase_config()
1667 &ase->ep.codec_cfg, &stream, in ase_config()
1668 &ase->ep.qos_pref, &rsp); in ase_config()
1675 if (err == 0 && !bt_bap_valid_qos_pref(&ase->ep.qos_pref)) { in ase_config()
1696 (void)memcpy(&ase->ep.codec_cfg, &codec_cfg, sizeof(codec_cfg)); in ase_config()
1697 ascs_cp_rsp_add(ASE_ID(ase), rsp.code, rsp.reason); in ase_config()
1705 ascs_cp_rsp_success(ASE_ID(ase)); in ase_config()
1707 bt_bap_stream_attach(ase->conn, stream, &ase->ep, &ase->ep.codec_cfg); in ase_config()
1709 ascs_ep_set_state(&ase->ep, BT_BAP_EP_STATE_CODEC_CONFIGURED); in ase_config()
1717 struct bt_ascs_ase *ase = &ascs.ase_pool[i]; in ep_lookup_stream() local
1719 if (ase->conn == conn && ase->ep.stream == stream) { in ep_lookup_stream()
1720 return &ase->ep; in ep_lookup_stream()
1732 struct bt_ascs_ase *ase = NULL; in bt_ascs_config_ase() local
1750 ase = ase_new(conn, i); in bt_ascs_config_ase()
1755 if (ase == NULL) { in bt_ascs_config_ase()
1760 ep = &ase->ep; in bt_ascs_config_ase()
1787 ase_free(ase); in bt_ascs_config_ase()
1887 struct bt_ascs_ase *ase; in ascs_config() local
1893 LOG_DBG("ase 0x%02x cc_len %u", cfg->ase, cfg->cc_len); in ascs_config()
1895 if (!cfg->ase || cfg->ase > ASE_COUNT) { in ascs_config()
1896 LOG_WRN("Invalid ASE ID: %u", cfg->ase); in ascs_config()
1897 ascs_cp_rsp_add(cfg->ase, BT_BAP_ASCS_RSP_CODE_INVALID_ASE, in ascs_config()
1902 ase = ase_find(conn, cfg->ase); in ascs_config()
1903 if (ase != NULL) { in ascs_config()
1904 ase_config(ase, cfg); in ascs_config()
1908 ase = ase_new(conn, cfg->ase); in ascs_config()
1909 if (!ase) { in ascs_config()
1910 ascs_cp_rsp_add(cfg->ase, BT_BAP_ASCS_RSP_CODE_NO_MEM, in ascs_config()
1912 LOG_WRN("No free ASE found for config ASE ID 0x%02x", cfg->ase); in ascs_config()
1916 err = ase_config(ase, cfg); in ascs_config()
1918 ase_free(ase); in ascs_config()
1928 struct bt_ascs_ase *ase = &ascs.ase_pool[i]; in bt_ascs_foreach_ep() local
1930 if (ase->conn == conn) { in bt_ascs_foreach_ep()
1931 func(&ase->ep, user_data); in bt_ascs_foreach_ep()
1936 static void ase_qos(struct bt_ascs_ase *ase, uint8_t cig_id, uint8_t cis_id, in ase_qos() argument
1939 struct bt_bap_ep *ep = &ase->ep; in ase_qos()
1943 "latency %u pd %u", ase, cig_id, cis_id, qos->interval, qos->framing, qos->phy, in ase_qos()
2007 iso = bap_iso_get_or_new(ase->conn, cig_id, cis_id); in ase_qos()
2099 struct bt_ascs_ase *ase; in ascs_qos() local
2103 LOG_DBG("ase 0x%02x", qos->ase); in ascs_qos()
2105 if (!is_valid_ase_id(qos->ase)) { in ascs_qos()
2106 ascs_cp_rsp_add(qos->ase, BT_BAP_ASCS_RSP_CODE_INVALID_ASE, in ascs_qos()
2108 LOG_WRN("Unknown ase 0x%02x", qos->ase); in ascs_qos()
2112 ase = ase_find(conn, qos->ase); in ascs_qos()
2113 if (!ase) { in ascs_qos()
2115 ascs_cp_rsp_add(qos->ase, BT_BAP_ASCS_RSP_CODE_INVALID_ASE_STATE, in ascs_qos()
2128 ase_qos(ase, qos->cig, qos->cis, &cqos, &rsp); in ascs_qos()
2129 ascs_cp_rsp_add(qos->ase, rsp.code, rsp.reason); in ascs_qos()
2271 struct bt_ascs_ase *ase = CONTAINER_OF(ep, struct bt_ascs_ase, ep); in ascs_verify_metadata() local
2273 .conn = ase->conn, in ascs_verify_metadata()
2304 static void ase_metadata(struct bt_ascs_ase *ase, struct bt_ascs_metadata *meta) in ase_metadata() argument
2313 LOG_DBG("ase %p meta->len %u", ase, meta->len); in ase_metadata()
2315 ep = &ase->ep; in ase_metadata()
2326 ascs_cp_rsp_add(ASE_ID(ase), BT_BAP_ASCS_RSP_CODE_INVALID_ASE_STATE, in ase_metadata()
2355 ascs_cp_rsp_add(ASE_ID(ase), rsp.code, rsp.reason); in ase_metadata()
2364 ascs_cp_rsp_success(ASE_ID(ase)); in ase_metadata()
2367 static int ase_enable(struct bt_ascs_ase *ase, struct bt_ascs_metadata *meta) in ase_enable() argument
2375 LOG_DBG("ase %p meta->len %u", ase, meta->len); in ase_enable()
2377 ep = &ase->ep; in ase_enable()
2383 ascs_cp_rsp_add(ASE_ID(ase), BT_BAP_ASCS_RSP_CODE_INVALID_ASE_STATE, in ase_enable()
2412 ascs_cp_rsp_add(ASE_ID(ase), rsp.code, rsp.reason); in ase_enable()
2422 ascs_cp_rsp_success(ASE_ID(ase)); in ase_enable()
2486 struct bt_ascs_ase *ase; in ascs_enable() local
2491 if (!is_valid_ase_id(meta->ase)) { in ascs_enable()
2492 ascs_cp_rsp_add(meta->ase, BT_BAP_ASCS_RSP_CODE_INVALID_ASE, in ascs_enable()
2494 LOG_WRN("Unknown ase 0x%02x", meta->ase); in ascs_enable()
2498 ase = ase_find(conn, meta->ase); in ascs_enable()
2499 if (!ase) { in ascs_enable()
2500 LOG_DBG("Invalid operation for idle ase 0x%02x", meta->ase); in ascs_enable()
2501 ascs_cp_rsp_add(meta->ase, BT_BAP_ASCS_RSP_CODE_INVALID_ASE_STATE, in ascs_enable()
2506 ase_enable(ase, meta); in ascs_enable()
2512 static void ase_start(struct bt_ascs_ase *ase) in ase_start() argument
2519 LOG_DBG("ase %p", ase); in ase_start()
2521 ep = &ase->ep; in ase_start()
2526 ascs_cp_rsp_add(ASE_ID(ase), BT_BAP_ASCS_RSP_CODE_INVALID_ASE_STATE, in ase_start()
2537 ascs_cp_rsp_add(ASE_ID(ase), BT_BAP_ASCS_RSP_CODE_INVALID_ASE_STATE, in ase_start()
2559 ascs_cp_rsp_add(ASE_ID(ase), rsp.code, rsp.reason); in ase_start()
2568 ascs_cp_rsp_success(ASE_ID(ase)); in ase_start()
2612 struct bt_ascs_ase *ase; in ascs_start() local
2639 ase = ase_find(conn, id); in ascs_start()
2640 if (!ase) { in ascs_start()
2647 ase_start(ase); in ascs_start()
2695 struct bt_ascs_ase *ase; in ascs_disable() local
2709 ase = ase_find(conn, id); in ascs_disable()
2710 if (!ase) { in ascs_disable()
2717 ase_disable(ase, BT_HCI_ERR_REMOTE_USER_TERM_CONN, &rsp); in ascs_disable()
2724 static void ase_stop(struct bt_ascs_ase *ase) in ase_stop() argument
2732 LOG_DBG("ase %p", ase); in ase_stop()
2734 ep = &ase->ep; in ase_stop()
2738 ascs_cp_rsp_add(ASE_ID(ase), BT_BAP_ASCS_RSP_CODE_INVALID_ASE_STATE, in ase_stop()
2761 ascs_cp_rsp_add(ASE_ID(ase), rsp.code, rsp.reason); in ase_stop()
2779 ascs_cp_rsp_success(ASE_ID(ase)); in ase_stop()
2824 struct bt_ascs_ase *ase; in ascs_stop() local
2851 ase = ase_find(conn, id); in ascs_stop()
2852 if (!ase) { in ascs_stop()
2859 ase_stop(ase); in ascs_stop()
2924 struct bt_ascs_ase *ase; in ascs_metadata() local
2932 ascs_cp_rsp_add(meta->ase, BT_BAP_ASCS_RSP_CODE_NO_MEM, in ascs_metadata()
2937 if (!is_valid_ase_id(meta->ase)) { in ascs_metadata()
2938 ascs_cp_rsp_add(meta->ase, BT_BAP_ASCS_RSP_CODE_INVALID_ASE, in ascs_metadata()
2940 LOG_WRN("Unknown ase 0x%02x", meta->ase); in ascs_metadata()
2944 ase = ase_find(conn, meta->ase); in ascs_metadata()
2945 if (!ase) { in ascs_metadata()
2946 LOG_DBG("Invalid operation for idle ase 0x%02x", meta->ase); in ascs_metadata()
2947 ascs_cp_rsp_add(meta->ase, BT_BAP_ASCS_RSP_CODE_INVALID_ASE_STATE, in ascs_metadata()
2952 ase_metadata(ase, meta); in ascs_metadata()
3001 struct bt_ascs_ase *ase; in ascs_release() local
3015 ase = ase_find(conn, id); in ascs_release()
3016 if (!ase) { in ascs_release()
3023 ase_release(ase, BT_HCI_ERR_REMOTE_USER_TERM_CONN, &rsp); in ascs_release()
3262 struct bt_ascs_ase *ase = &ascs.ase_pool[i]; in bt_ascs_cleanup() local
3264 if (ase->conn != NULL) { in bt_ascs_cleanup()
3265 bt_ascs_release_ase(&ase->ep); in bt_ascs_cleanup()