mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-04-04 04:20:58 +00:00
a2dp_source: check early if stream endpoint is initialised, later call assert
This commit is contained in:
parent
c58b84e8cd
commit
b79396703d
@ -240,7 +240,8 @@ static void a2dp_source_packet_handler_internal(uint8_t packet_type, uint16_t ch
|
|||||||
switch (packet[2]){
|
switch (packet[2]){
|
||||||
case AVDTP_SUBEVENT_SIGNALING_CONNECTION_ESTABLISHED:
|
case AVDTP_SUBEVENT_SIGNALING_CONNECTION_ESTABLISHED:
|
||||||
if (stream_endpoint_configured) return;
|
if (stream_endpoint_configured) return;
|
||||||
|
if (sc.local_stream_endpoint == NULL) return;
|
||||||
|
|
||||||
cid = avdtp_subevent_signaling_connection_established_get_avdtp_cid(packet);
|
cid = avdtp_subevent_signaling_connection_established_get_avdtp_cid(packet);
|
||||||
connection = avdtp_get_connection_for_avdtp_cid(cid);
|
connection = avdtp_get_connection_for_avdtp_cid(cid);
|
||||||
btstack_assert(connection != NULL);
|
btstack_assert(connection != NULL);
|
||||||
@ -267,16 +268,13 @@ static void a2dp_source_packet_handler_internal(uint8_t packet_type, uint16_t ch
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case AVDTP_SUBEVENT_SIGNALING_MEDIA_CODEC_SBC_CAPABILITY:
|
case AVDTP_SUBEVENT_SIGNALING_MEDIA_CODEC_SBC_CAPABILITY:
|
||||||
|
btstack_assert(sc.local_stream_endpoint != NULL);
|
||||||
|
|
||||||
log_info("A2DP received SBC capability, received: local seid %d, remote seid %d, expected: local seid %d, remote seid %d",
|
log_info("A2DP received SBC capability, received: local seid %d, remote seid %d, expected: local seid %d, remote seid %d",
|
||||||
avdtp_subevent_signaling_media_codec_sbc_capability_get_local_seid(packet),
|
avdtp_subevent_signaling_media_codec_sbc_capability_get_local_seid(packet),
|
||||||
avdtp_subevent_signaling_media_codec_sbc_capability_get_remote_seid(packet),
|
avdtp_subevent_signaling_media_codec_sbc_capability_get_remote_seid(packet),
|
||||||
avdtp_stream_endpoint_seid(sc.local_stream_endpoint), remote_seps[sc.active_remote_sep_index].seid );
|
avdtp_stream_endpoint_seid(sc.local_stream_endpoint), remote_seps[sc.active_remote_sep_index].seid );
|
||||||
|
|
||||||
if (!sc.local_stream_endpoint) {
|
|
||||||
log_error("invalid local seid %d", avdtp_subevent_signaling_media_codec_sbc_capability_get_local_seid(packet));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
cid = avdtp_subevent_signaling_media_codec_sbc_capability_get_avdtp_cid(packet);
|
cid = avdtp_subevent_signaling_media_codec_sbc_capability_get_avdtp_cid(packet);
|
||||||
connection = avdtp_get_connection_for_avdtp_cid(cid);
|
connection = avdtp_get_connection_for_avdtp_cid(cid);
|
||||||
btstack_assert(connection != NULL);
|
btstack_assert(connection != NULL);
|
||||||
@ -433,7 +431,8 @@ static void a2dp_source_packet_handler_internal(uint8_t packet_type, uint16_t ch
|
|||||||
cid = avdtp_subevent_signaling_accept_get_avdtp_cid(packet);
|
cid = avdtp_subevent_signaling_accept_get_avdtp_cid(packet);
|
||||||
connection = avdtp_get_connection_for_avdtp_cid(cid);
|
connection = avdtp_get_connection_for_avdtp_cid(cid);
|
||||||
btstack_assert(connection != NULL);
|
btstack_assert(connection != NULL);
|
||||||
|
btstack_assert(sc.local_stream_endpoint != NULL);
|
||||||
|
|
||||||
signal_identifier = avdtp_subevent_signaling_accept_get_signal_identifier(packet);
|
signal_identifier = avdtp_subevent_signaling_accept_get_signal_identifier(packet);
|
||||||
|
|
||||||
log_info("A2DP cmd %s accepted, state %x, is_initiator %u, cid 0x%2x, local seid %d", avdtp_si2str(signal_identifier), connection->a2dp_source_state,
|
log_info("A2DP cmd %s accepted, state %x, is_initiator %u, cid 0x%2x, local seid %d", avdtp_si2str(signal_identifier), connection->a2dp_source_state,
|
||||||
@ -445,26 +444,26 @@ static void a2dp_source_packet_handler_internal(uint8_t packet_type, uint16_t ch
|
|||||||
log_info("A2DP get capabilities for remote seid %d", remote_seid);
|
log_info("A2DP get capabilities for remote seid %d", remote_seid);
|
||||||
avdtp_source_get_capabilities(cid, remote_seid);
|
avdtp_source_get_capabilities(cid, remote_seid);
|
||||||
break;
|
break;
|
||||||
case A2DP_W2_SET_CONFIGURATION:{
|
|
||||||
if (sc.local_stream_endpoint != NULL){
|
case A2DP_W2_SET_CONFIGURATION:
|
||||||
remote_seid = remote_seps[sc.active_remote_sep_index].seid;
|
remote_seid = remote_seps[sc.active_remote_sep_index].seid;
|
||||||
log_info("A2DP initiate set configuration locally and wait for response ... local seid %d, remote seid %d", avdtp_stream_endpoint_seid(sc.local_stream_endpoint), remote_seid);
|
log_info("A2DP initiate set configuration locally and wait for response ... local seid %d, remote seid %d", avdtp_stream_endpoint_seid(sc.local_stream_endpoint), remote_seid);
|
||||||
connection->a2dp_source_state = A2DP_IDLE;
|
connection->a2dp_source_state = A2DP_CONNECTED;
|
||||||
avdtp_source_set_configuration(cid, avdtp_stream_endpoint_seid(sc.local_stream_endpoint), remote_seid, sc.local_stream_endpoint->remote_configuration_bitmap, sc.local_stream_endpoint->remote_configuration);
|
avdtp_source_set_configuration(cid, avdtp_stream_endpoint_seid(sc.local_stream_endpoint), remote_seid, sc.local_stream_endpoint->remote_configuration_bitmap, sc.local_stream_endpoint->remote_configuration);
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
case A2DP_W2_RECONFIGURE_WITH_SEID:
|
case A2DP_W2_RECONFIGURE_WITH_SEID:
|
||||||
log_info("A2DP reconfigured ... local seid %d, active remote seid %d", avdtp_stream_endpoint_seid(sc.local_stream_endpoint), sc.local_stream_endpoint->remote_sep.seid);
|
log_info("A2DP reconfigured ... local seid %d, active remote seid %d", avdtp_stream_endpoint_seid(sc.local_stream_endpoint), sc.local_stream_endpoint->remote_sep.seid);
|
||||||
a2dp_signaling_emit_reconfigured(cid, avdtp_stream_endpoint_seid(sc.local_stream_endpoint), ERROR_CODE_SUCCESS);
|
a2dp_signaling_emit_reconfigured(cid, avdtp_stream_endpoint_seid(sc.local_stream_endpoint), ERROR_CODE_SUCCESS);
|
||||||
connection->a2dp_source_state = A2DP_STREAMING_OPENED;
|
connection->a2dp_source_state = A2DP_STREAMING_OPENED;
|
||||||
break;
|
break;
|
||||||
case A2DP_W2_OPEN_STREAM_WITH_SEID:{
|
|
||||||
|
case A2DP_W2_OPEN_STREAM_WITH_SEID:
|
||||||
log_info("A2DP open stream ... local seid %d, active remote seid %d", avdtp_stream_endpoint_seid(sc.local_stream_endpoint), sc.local_stream_endpoint->remote_sep.seid);
|
log_info("A2DP open stream ... local seid %d, active remote seid %d", avdtp_stream_endpoint_seid(sc.local_stream_endpoint), sc.local_stream_endpoint->remote_sep.seid);
|
||||||
connection->a2dp_source_state = A2DP_W4_OPEN_STREAM_WITH_SEID;
|
connection->a2dp_source_state = A2DP_W4_OPEN_STREAM_WITH_SEID;
|
||||||
avdtp_source_open_stream(cid, avdtp_stream_endpoint_seid(sc.local_stream_endpoint), sc.local_stream_endpoint->remote_sep.seid);
|
avdtp_source_open_stream(cid, avdtp_stream_endpoint_seid(sc.local_stream_endpoint), sc.local_stream_endpoint->remote_sep.seid);
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
case A2DP_STREAMING_OPENED:
|
case A2DP_STREAMING_OPENED:
|
||||||
switch (signal_identifier){
|
switch (signal_identifier){
|
||||||
case AVDTP_SI_START:
|
case AVDTP_SI_START:
|
||||||
@ -579,6 +578,8 @@ uint8_t a2dp_source_disconnect(uint16_t avdtp_cid){
|
|||||||
}
|
}
|
||||||
|
|
||||||
uint8_t a2dp_source_reconfigure_stream_sampling_frequency(uint16_t avdtp_cid, uint32_t sampling_frequency){
|
uint8_t a2dp_source_reconfigure_stream_sampling_frequency(uint16_t avdtp_cid, uint32_t sampling_frequency){
|
||||||
|
btstack_assert(sc.local_stream_endpoint != NULL);
|
||||||
|
|
||||||
avdtp_connection_t * connection = avdtp_get_connection_for_avdtp_cid(avdtp_cid);
|
avdtp_connection_t * connection = avdtp_get_connection_for_avdtp_cid(avdtp_cid);
|
||||||
if (connection == NULL) ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER;
|
if (connection == NULL) ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user