diff options
author | Ravi Nagarajan <nravi@broadcom.com> | 2012-06-01 19:24:52 +0530 |
---|---|---|
committer | Matthew Xie <mattx@google.com> | 2012-07-14 11:19:22 -0700 |
commit | 7b4048c6064ab21da67dc3450bdfd431f109e4fc (patch) | |
tree | 46c62eaf3f37c24e2e03064b50fd2a0fcfcd49fc | |
parent | f476c7d052409d27d60cbe8d17c9ed14c663518e (diff) | |
download | external_bluetooth_bluedroid-7b4048c6064ab21da67dc3450bdfd431f109e4fc.zip external_bluetooth_bluedroid-7b4048c6064ab21da67dc3450bdfd431f109e4fc.tar.gz external_bluetooth_bluedroid-7b4048c6064ab21da67dc3450bdfd431f109e4fc.tar.bz2 |
If peer initiates connection and does SETCONFIG, if the SETCONFIG is for SBC codec, use the same SEID, else discover to find out the SEPs supported
Change-Id: I4d362e1cb5c7b702be26d10f257274e54d7b6dd7
-rw-r--r-- | bta/av/bta_av_aact.c | 31 |
1 files changed, 27 insertions, 4 deletions
diff --git a/bta/av/bta_av_aact.c b/bta/av/bta_av_aact.c index 2bcbf01..c6ce55a 100644 --- a/bta/av/bta_av_aact.c +++ b/bta/av/bta_av_aact.c @@ -1102,6 +1102,8 @@ void bta_av_security_rsp (tBTA_AV_SCB *p_scb, tBTA_AV_DATA *p_data) void bta_av_setconfig_rsp (tBTA_AV_SCB *p_scb, tBTA_AV_DATA *p_data) { UINT8 num = p_data->ci_setconfig.num_seid + 1; + UINT8 *p_seid = p_data->ci_setconfig.p_seid; + int i; /* we like this codec_type. find the sep_idx */ bta_av_adjust_seps_idx(p_scb); @@ -1125,10 +1127,31 @@ void bta_av_setconfig_rsp (tBTA_AV_SCB *p_scb, tBTA_AV_DATA *p_data) if (p_scb->cur_psc_mask & AVDT_PSC_DELAY_RPT) p_scb->avdt_version = AVDT_VERSION_SYNC; - /* We need to know all the SEPs on SNK */ - /* Getcap for all SEPs will follow after Discover */ - APPL_TRACE_DEBUG0("bta_av_setconfig_rsp: start DISCOVER"); - bta_av_discover_req(p_scb, NULL); + + if (p_scb->codec_type == BTA_AV_CODEC_SBC || num > 1) + { + /* if SBC is used by the SNK as INT, discover req is not sent in bta_av_config_ind. + * call disc_res now */ + p_scb->p_cos->disc_res(p_scb->hndl, num, num, p_scb->peer_addr); + } + else + { + /* we do not know the peer device and it is using non-SBC codec + * we need to know all the SEPs on SNK */ + bta_av_discover_req(p_scb, NULL); + return; + } + + for (i = 1; i < num; i++) + { + APPL_TRACE_DEBUG2("sep_info[%d] SEID: %d", i, p_seid[i-1]); + /* initialize the sep_info[] to get capabilities */ + p_scb->sep_info[i].in_use = FALSE; + p_scb->sep_info[i].tsep = AVDT_TSEP_SNK; + p_scb->sep_info[i].media_type = p_scb->media_type; + p_scb->sep_info[i].seid = p_seid[i-1]; + } + bta_av_next_getcap(p_scb, p_data); } } |