From 7b4048c6064ab21da67dc3450bdfd431f109e4fc Mon Sep 17 00:00:00 2001 From: Ravi Nagarajan Date: Fri, 1 Jun 2012 19:24:52 +0530 Subject: 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 --- bta/av/bta_av_aact.c | 31 +++++++++++++++++++++++++++---- 1 file 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); } } -- cgit v1.1