{
tAVDT_TC_TBL *p_tbl;
UINT16 disc_rsn = AVDT_DISC_RSN_NORMAL;
+ tAVDT_CCB *p_ccb;
AVDT_TRACE_DEBUG("avdt_l2c_disconnect_ind_cback lcid: %d, ack_needed: %d\n",
lcid, ack_needed);
/* look up info for this channel */
/* send L2CAP disconnect response */
L2CA_DisconnectRsp(lcid);
} else {
- disc_rsn = AVDT_DISC_RSN_ABNORMAL;
+ if ((p_ccb = avdt_ccb_by_idx(p_tbl->ccb_idx)) != NULL) {
+ UINT16 rsn = L2CA_GetDisconnectReason(p_ccb->peer_addr, BT_TRANSPORT_BR_EDR);
+ if (rsn != 0 && rsn != HCI_ERR_PEER_USER) {
+ disc_rsn = AVDT_DISC_RSN_ABNORMAL;
+ AVDT_TRACE_EVENT("avdt link disc rsn 0x%x", rsn);
+ }
+ }
}
avdt_ad_tc_close_ind(p_tbl, disc_rsn);