diff options
author | Srikanth Uppala <suppala@broadcom.com> | 2012-06-17 21:44:48 -0700 |
---|---|---|
committer | Matthew Xie <mattx@google.com> | 2012-07-14 11:19:23 -0700 |
commit | 1144d2b375fc67c9b48298e0ffd774d969cfd2cc (patch) | |
tree | 4d36d4f8be4942d769300c242caeb9b9096c6a35 /stack/avrc | |
parent | fed66f7b66d29da466e2e67befe3238e7ed8fc6a (diff) | |
download | external_bluetooth_bluedroid-1144d2b375fc67c9b48298e0ffd774d969cfd2cc.zip external_bluetooth_bluedroid-1144d2b375fc67c9b48298e0ffd774d969cfd2cc.tar.gz external_bluetooth_bluedroid-1144d2b375fc67c9b48298e0ffd774d969cfd2cc.tar.bz2 |
resubmit code-cleanup changes lost in gerrit merge
Change-Id: Iebc520d9b10ef220a83a16ff55efa46b4c5a0d27
Diffstat (limited to 'stack/avrc')
-rw-r--r-- | stack/avrc/avrc_api.c | 557 | ||||
-rw-r--r-- | stack/avrc/avrc_bld_ct.c | 1102 | ||||
-rw-r--r-- | stack/avrc/avrc_bld_tg.c | 1547 | ||||
-rw-r--r-- | stack/avrc/avrc_int.h | 21 | ||||
-rw-r--r-- | stack/avrc/avrc_opt.c | 5 | ||||
-rw-r--r-- | stack/avrc/avrc_pars_ct.c | 663 | ||||
-rw-r--r-- | stack/avrc/avrc_pars_tg.c | 452 | ||||
-rw-r--r-- | stack/avrc/avrc_sdp.c | 34 | ||||
-rw-r--r-- | stack/avrc/avrc_utils.c | 254 |
9 files changed, 0 insertions, 4635 deletions
diff --git a/stack/avrc/avrc_api.c b/stack/avrc/avrc_api.c index dd7e752..94425af 100644 --- a/stack/avrc/avrc_api.c +++ b/stack/avrc/avrc_api.c @@ -98,354 +98,6 @@ static UINT8 * avrc_get_data_ptr(BT_HDR *p_pkt) return p_data; } -#if (AVRC_METADATA_INCLUDED == TRUE) -/****************************************************************************** -** -** Function avrc_prep_end_frag -** -** Description This function prepares an end response fragment -** -** -** Returns Nothing. -** -******************************************************************************/ -static void avrc_prep_end_frag(UINT8 handle) -{ - tAVRC_FRAG_CB *p_fcb; - BT_HDR *p_pkt_new; - UINT8 *p_data; - - AVRC_TRACE_DEBUG0 ("avrc_prep_end_frag" ); - p_fcb = &avrc_cb.fcb[handle]; - p_pkt_new = p_fcb->p_fmsg; - p_pkt_new->len -= (AVRC_MAX_CTRL_DATA_LEN - AVRC_VENDOR_HDR_SIZE - AVRC_MIN_META_HDR_SIZE); - p_pkt_new->offset += (AVRC_MAX_CTRL_DATA_LEN - AVRC_VENDOR_HDR_SIZE - AVRC_MIN_META_HDR_SIZE); - p_data = (UINT8 *)(p_pkt_new+1) + p_pkt_new->offset; - *p_data++ = (AVRC_RSP_ACCEPT & AVRC_CTYPE_MASK); - *p_data++ = (AVRC_SUB_PANEL << AVRC_SUBTYPE_SHIFT); - *p_data++ = AVRC_OP_VENDOR; - AVRC_CO_ID_TO_BE_STREAM(p_data, AVRC_CO_METADATA); - *p_data++ = p_fcb->frag_pdu; - *p_data++ = AVRC_PKT_END; - UINT16_TO_BE_STREAM(p_data, (p_pkt_new->len - AVRC_VENDOR_HDR_SIZE - AVRC_MIN_META_HDR_SIZE)); /* 4=pdu, pkt_type & len */ -} - -/****************************************************************************** -** -** Function avrc_send_continue_frag -** -** Description This function sends a continue response fragment -** -** -** Returns Nothing. -** -******************************************************************************/ -static void avrc_send_continue_frag(UINT8 handle, UINT8 label) -{ - tAVRC_FRAG_CB *p_fcb; - BT_HDR *p_pkt_old, *p_pkt; - UINT8 *p_old, *p_data; - UINT8 cr = AVCT_RSP; - tAVRC_RSP rej_rsp; - - p_fcb = &avrc_cb.fcb[handle]; - p_pkt = p_fcb->p_fmsg; - - AVRC_TRACE_DEBUG1 ("avrc_send_continue_frag len(%d) / AVRC_MAX_CTRL_DATA_LEN", p_pkt->len ); - if (p_pkt->len > AVRC_MAX_CTRL_DATA_LEN) - { - p_pkt_old = p_fcb->p_fmsg; - p_pkt = (BT_HDR *)GKI_getbuf((UINT16)(AVRC_PACKET_LEN + AVCT_MSG_OFFSET + BT_HDR_SIZE)); - if (p_pkt) - { - p_pkt->len = AVRC_MAX_CTRL_DATA_LEN; - p_pkt->offset = AVCT_MSG_OFFSET; - p_pkt->layer_specific = p_pkt_old->layer_specific; - p_pkt->event = p_pkt_old->event; - p_old = (UINT8 *)(p_pkt_old+1) + p_pkt_old->offset; - p_data = (UINT8 *)(p_pkt+1) + p_pkt->offset; - memcpy (p_data, p_old, AVRC_MAX_CTRL_DATA_LEN); - /* use AVRC continue packet type */ - p_data += AVRC_VENDOR_HDR_SIZE; - p_data++; /* pdu */ - *p_data++ = AVRC_PKT_CONTINUE; - UINT16_TO_BE_STREAM(p_data, (AVRC_MAX_CTRL_DATA_LEN - AVRC_VENDOR_HDR_SIZE - 4)); /* 4=pdu, pkt_type & len */ - - /* prepare the left over for as an end fragment */ - avrc_prep_end_frag (handle); - } - else - { - /* use the current GKI buffer to send Internal error status */ - p_pkt = p_fcb->p_fmsg; - p_fcb->p_fmsg = NULL; - p_fcb->frag_enabled = FALSE; - AVRC_TRACE_ERROR0 ("AVRC_MsgReq no buffers for fragmentation - send internal error" ); - p_data = (UINT8 *)(p_pkt+1) + p_pkt->offset; - *p_data++ = AVRC_PDU_REQUEST_CONTINUATION_RSP; - *p_data++ = 0; - UINT16_TO_BE_STREAM(p_data, 0); - p_pkt->len = 4; - rej_rsp.pdu = AVRC_PDU_REQUEST_CONTINUATION_RSP; - rej_rsp.status = AVRC_STS_INTERNAL_ERR; - AVRC_BldResponse( handle, (tAVRC_RESPONSE *)&rej_rsp, &p_pkt); - cr = AVCT_RSP; - } - } - else - { - /* end fragment. clean the control block */ - p_fcb->frag_enabled = FALSE; - p_fcb->p_fmsg = NULL; - } - AVCT_MsgReq( handle, label, cr, p_pkt); -} - -/****************************************************************************** -** -** Function avrc_proc_vendor_command -** -** Description This function processes received vendor command. -** -** -** Returns if not NULL, the response to send right away. -** -******************************************************************************/ -static BT_HDR * avrc_proc_vendor_command(UINT8 handle, UINT8 label, - BT_HDR *p_pkt, tAVRC_MSG_VENDOR *p_msg) -{ - BT_HDR *p_rsp = NULL; - UINT8 *p_data; - UINT8 *p_begin; - UINT8 pkt_type; - BOOLEAN abort_frag = FALSE; - tAVRC_STS status = AVRC_STS_NO_ERROR; - tAVRC_FRAG_CB *p_fcb; - - p_begin = (UINT8 *)(p_pkt+1) + p_pkt->offset; - p_data = p_begin + AVRC_VENDOR_HDR_SIZE; - pkt_type = *(p_data + 1) & AVRC_PKT_TYPE_MASK; - - if (pkt_type != AVRC_PKT_SINGLE) - { - /* reject - commands can only be in single packets at AVRCP level */ - AVRC_TRACE_ERROR1 ("commands must be in single packet pdu:0x%x", *p_data ); - /* use the current GKI buffer to send the reject */ - status = AVRC_STS_BAD_CMD; - } - /* check if there are fragments waiting to be sent */ - else if (avrc_cb.fcb[handle].frag_enabled) - { - p_fcb = &avrc_cb.fcb[handle]; - if (p_msg->company_id == AVRC_CO_METADATA) - { - switch (*p_data) - { - case AVRC_PDU_ABORT_CONTINUATION_RSP: - /* aborted by CT - send accept response */ - abort_frag = TRUE; - p_begin = (UINT8 *)(p_pkt+1) + p_pkt->offset; - *p_begin = (AVRC_RSP_ACCEPT & AVRC_CTYPE_MASK); - if (*(p_data + 4) != p_fcb->frag_pdu) - { - *p_begin = (AVRC_RSP_REJ & AVRC_CTYPE_MASK); - *(p_data + 4) = AVRC_STS_BAD_PARAM; - } - else - { - p_data = (p_begin + AVRC_VENDOR_HDR_SIZE + 2); - UINT16_TO_BE_STREAM(p_data, 0); - p_pkt->len = (p_data - p_begin); - } - AVCT_MsgReq( handle, label, AVCT_RSP, p_pkt); - p_msg->hdr.opcode = AVRC_OP_DROP; /* used the p_pkt to send response */ - break; - - case AVRC_PDU_REQUEST_CONTINUATION_RSP: - if (*(p_data + 4) == p_fcb->frag_pdu) - { - avrc_send_continue_frag(handle, label); - p_msg->hdr.opcode = AVRC_OP_DROP_N_FREE; - } - else - { - /* the pdu id does not match - reject the command using the current GKI buffer */ - AVRC_TRACE_ERROR2("avrc_proc_vendor_command continue pdu: 0x%x does not match current re-assembly pdu: 0x%x", - *(p_data + 4), p_fcb->frag_pdu); - status = AVRC_STS_BAD_PARAM; - abort_frag = TRUE; - } - break; - - default: - /* implicit abort */ - abort_frag = TRUE; - } - } - else - { - abort_frag = TRUE; - /* implicit abort */ - } - - if (abort_frag) - { - if (p_fcb->p_fmsg) - GKI_freebuf(p_fcb->p_fmsg); - p_fcb->p_fmsg = NULL; - p_fcb->frag_enabled = FALSE; - } - } - - if (status != AVRC_STS_NO_ERROR) - { - /* use the current GKI buffer to build/send the reject message */ - p_data = (UINT8 *)(p_pkt+1) + p_pkt->offset; - *p_data++ = AVRC_RSP_REJ; - p_data += AVRC_VENDOR_HDR_SIZE; /* pdu */ - *p_data++ = 0; /* pkt_type */ - UINT16_TO_BE_STREAM(p_data, 1); /* len */ - *p_data++ = status; /* error code */ - p_pkt->len = AVRC_VENDOR_HDR_SIZE + 5; - p_rsp = p_pkt; - } - - return p_rsp; -} - -/****************************************************************************** -** -** Function avrc_proc_far_msg -** -** Description This function processes vendor command/response fragmetation -** and reassembly -** -** Returns 0, to report the message with msg_cback . -** -******************************************************************************/ -static UINT8 avrc_proc_far_msg(UINT8 handle, UINT8 label, UINT8 cr, BT_HDR **pp_pkt, tAVRC_MSG_VENDOR *p_msg) -{ - BT_HDR *p_pkt = *pp_pkt; - UINT8 *p_data; - BOOLEAN drop = FALSE; - BT_HDR *p_rsp = NULL; - BT_HDR *p_cmd = NULL; - BOOLEAN req_continue = FALSE; - BT_HDR *p_pkt_new = NULL; - UINT8 pkt_type; - UINT16 buf_len; - tAVRC_RASM_CB *p_rcb; - tAVRC_NEXT_CMD avrc_cmd; - - p_data = (UINT8 *)(p_pkt+1) + p_pkt->offset; - pkt_type = *(p_data + 1) & AVRC_PKT_TYPE_MASK; - AVRC_TRACE_DEBUG1 ("pkt_type %d", pkt_type ); - p_rcb = &avrc_cb.rcb[handle]; - if (p_msg->company_id == AVRC_CO_METADATA) - { - /* check if the message needs to be re-assembled */ - if (pkt_type == AVRC_PKT_SINGLE || pkt_type == AVRC_PKT_START) - { - /* previous fragments need to be dropped, when received another new message */ - p_rcb->rasm_offset = 0; - if (p_rcb->p_rmsg) - { - GKI_freebuf(p_rcb->p_rmsg); - p_rcb->p_rmsg = NULL; - } - } - - if (pkt_type != AVRC_PKT_SINGLE && cr == AVCT_RSP) - { - /* not a single response packet - need to re-assemble metadata messages */ - if (pkt_type == AVRC_PKT_START) - { - p_rcb->rasm_offset = p_pkt->offset; - p_rcb->p_rmsg = p_pkt; - /* set offset to point to where to copy next - use the same re-asm logic as AVCT */ - p_rcb->p_rmsg->offset += p_rcb->p_rmsg->len; - p_rcb->rasm_pdu = *p_data; - req_continue = TRUE; - } - else - { - /* get size of buffer holding assembled message */ - buf_len = GKI_get_buf_size (p_rcb->p_rmsg) - sizeof(BT_HDR); - /* adjust offset and len of fragment for header byte */ - p_pkt->offset += (AVRC_VENDOR_HDR_SIZE + AVRC_MIN_META_HDR_SIZE); - p_pkt->len -= (AVRC_VENDOR_HDR_SIZE + AVRC_MIN_META_HDR_SIZE); - /* verify length */ - if ((p_rcb->p_rmsg->offset + p_pkt->len) > buf_len) - { - AVRC_TRACE_WARNING0("Fragmented message too big! - report the partial message"); - p_pkt->len = buf_len - p_rcb->p_rmsg->offset; - pkt_type = AVRC_PKT_END; - } - - /* copy contents of p_pkt to p_rx_msg */ - memcpy((UINT8 *)(p_rcb->p_rmsg + 1) + p_rcb->p_rmsg->offset, - (UINT8 *)(p_pkt + 1) + p_pkt->offset, p_pkt->len); - - if (pkt_type == AVRC_PKT_END) - { - p_rcb->p_rmsg->offset = p_rcb->rasm_offset; - p_rcb->p_rmsg->len += p_pkt->len; - p_pkt_new = p_rcb->p_rmsg; - p_rcb->rasm_offset = 0; - p_rcb->p_rmsg = NULL; - p_msg->p_vendor_data = (UINT8 *)(p_pkt_new+1) + p_pkt_new->offset; - p_msg->hdr.ctype = p_msg->p_vendor_data[0] & AVRC_CTYPE_MASK; - p_msg->p_vendor_data += AVRC_VENDOR_HDR_SIZE; /* 6 = ctype, subunit*, opcode & CO_ID */ - p_msg->vendor_len = p_pkt_new->len - AVRC_VENDOR_HDR_SIZE; - p_data = p_msg->p_vendor_data + 1; /* skip pdu */ - *p_data++ = AVRC_PKT_SINGLE; - UINT16_TO_BE_STREAM(p_data, (p_msg->vendor_len - AVRC_MIN_META_HDR_SIZE)); - AVRC_TRACE_DEBUG3("end frag:%d, total len:%d, offset:%d", p_pkt->len, p_pkt_new->len, p_pkt_new->offset); - } - else - { - p_rcb->p_rmsg->offset += p_pkt->len; - p_rcb->p_rmsg->len += p_pkt->len; - p_pkt_new = NULL; - req_continue = TRUE; - } - GKI_freebuf(p_pkt); - *pp_pkt = p_pkt_new; - } - } - - if (cr == AVCT_CMD) - { - p_rsp = avrc_proc_vendor_command(handle, label, *pp_pkt, p_msg); - if (p_rsp) - { - AVCT_MsgReq( handle, label, AVCT_RSP, p_rsp); - drop = 3; - } - else if (p_msg->hdr.opcode == AVRC_OP_DROP) - { - drop = 1; - } - else if (p_msg->hdr.opcode == AVRC_OP_DROP_N_FREE) - drop = 4; - - } - else if (cr == AVCT_RSP && req_continue == TRUE) - { - avrc_cmd.pdu = AVRC_PDU_REQUEST_CONTINUATION_RSP; - avrc_cmd.status = AVRC_STS_NO_ERROR; - avrc_cmd.target_pdu = p_rcb->rasm_pdu; - if (AVRC_BldCommand ((tAVRC_COMMAND *)&avrc_cmd, &p_cmd) == AVRC_STS_NO_ERROR) - { - cr = AVCT_CMD; - drop = 2; - AVRC_MsgReq (handle, (UINT8)(label+1), cr, p_cmd); - } - } - } - return drop; -} -#endif /* (AVRC_METADATA_INCLUDED == TRUE) */ /****************************************************************************** ** @@ -497,17 +149,6 @@ static void avrc_msg_cback(UINT8 handle, UINT8 label, UINT8 cr, p_data = (UINT8 *)(p_pkt+1) + p_pkt->offset; memset(&msg, 0, sizeof(tAVRC_MSG) ); -#if ((AVRC_ADV_CTRL_INCLUDED == TRUE) && (AVCT_BROWSE_INCLUDED == TRUE)) - if (p_pkt->layer_specific == AVCT_DATA_BROWSE) - { - opcode = AVRC_OP_BROWSE; - msg.browse.hdr.ctype= cr; - msg.browse.p_browse_data = p_data; - msg.browse.browse_len = p_pkt->len; - msg.browse.p_browse_pkt = p_pkt; - } - else -#endif { msg.hdr.ctype = p_data[0] & AVRC_CTYPE_MASK; AVRC_TRACE_DEBUG4("avrc_msg_cback handle:%d, ctype:%d, offset:%d, len: %d", @@ -602,34 +243,6 @@ static void avrc_msg_cback(UINT8 handle, UINT8 label, UINT8 cr, p_msg->p_vendor_data = p_data; p_msg->vendor_len = p_pkt->len - (p_data - p_begin); -#if (AVRC_METADATA_INCLUDED == TRUE) - drop = avrc_proc_far_msg(handle, label, cr, &p_pkt, p_msg); - if (drop) - { - free = FALSE; - if (drop == 4) - free = TRUE; -#if (BT_USE_TRACES == TRUE) - switch (drop) - { - case 1: - p_drop_msg = "sent_frag"; - break; - case 2: - p_drop_msg = "req_cont"; - break; - case 3: - p_drop_msg = "sent_frag3"; - break; - case 4: - p_drop_msg = "sent_frag_free"; - break; - default: - p_drop_msg = "sent_fragd"; - } -#endif - } -#endif /* (AVRC_METADATA_INCLUDED == TRUE) */ break; case AVRC_OP_PASS_THRU: @@ -657,12 +270,6 @@ static void avrc_msg_cback(UINT8 handle, UINT8 label, UINT8 cr, msg.pass.p_pass_data = NULL; break; -#if ((AVRC_ADV_CTRL_INCLUDED == TRUE) && (AVCT_BROWSE_INCLUDED == TRUE)) - case AVRC_OP_BROWSE: - /* the event data is handled already. - * this empty "case" is to keep the message from being rejected by the default case. */ - break; -#endif default: if ((avrc_cb.ccb[handle].control & AVRC_CT_TARGET) && (cr == AVCT_CMD)) @@ -676,9 +283,6 @@ static void avrc_msg_cback(UINT8 handle, UINT8 label, UINT8 cr, } else /* drop the event */ { -#if ((AVRC_ADV_CTRL_INCLUDED == TRUE) && (AVCT_BROWSE_INCLUDED == TRUE)) - if (opcode != AVRC_OP_BROWSE) -#endif drop = TRUE; } @@ -717,12 +321,6 @@ static void avrc_msg_cback(UINT8 handle, UINT8 label, UINT8 cr, } #endif -#if ((AVRC_ADV_CTRL_INCLUDED == TRUE) && (AVCT_BROWSE_INCLUDED == TRUE)) - if (opcode == AVRC_OP_BROWSE && msg.browse.p_browse_pkt == NULL) - { - free = FALSE; - } -#endif if (free) GKI_freebuf(p_pkt); @@ -847,10 +445,6 @@ UINT16 AVRC_Open(UINT8 *p_handle, tAVRC_CONN_CB *p_ccb, BD_ADDR_PTR peer_addr) if (status == AVCT_SUCCESS) { memcpy(&avrc_cb.ccb[*p_handle], p_ccb, sizeof(tAVRC_CONN_CB)); -#if (AVRC_METADATA_INCLUDED == TRUE) - memset(&avrc_cb.fcb[*p_handle], 0, sizeof(tAVRC_FRAG_CB)); - memset(&avrc_cb.rcb[*p_handle], 0, sizeof(tAVRC_RASM_CB)); -#endif } AVRC_TRACE_DEBUG4("AVRC_Open role: %d, control:%d status:%d, handle:%d", cc.role, cc.control, status, *p_handle); @@ -881,43 +475,6 @@ UINT16 AVRC_Close(UINT8 handle) return AVCT_RemoveConn(handle); } -#if ((AVRC_ADV_CTRL_INCLUDED == TRUE) && (AVCT_BROWSE_INCLUDED == TRUE)) -/****************************************************************************** -** -** Function AVRC_OpenBrowse -** -** Description This function is called to open a browsing connection to AVCTP. -** The connection can be either an initiator or acceptor, as -** determined by the p_conn_role. -** The handle is returned by a previous call to AVRC_Open. -** -** Returns AVRC_SUCCESS if successful. -** AVRC_NO_RESOURCES if there are not enough resources to open -** the connection. -** -******************************************************************************/ -UINT16 AVRC_OpenBrowse(UINT8 handle, UINT8 conn_role) -{ - return AVCT_CreateBrowse(handle, conn_role); -} - -/****************************************************************************** -** -** Function AVRC_CloseBrowse -** -** Description Close a connection opened with AVRC_OpenBrowse(). -** This function is called when the -** application is no longer using a connection. -** -** Returns AVRC_SUCCESS if successful. -** AVRC_BAD_HANDLE if handle is invalid. -** -******************************************************************************/ -UINT16 AVRC_CloseBrowse(UINT8 handle) -{ - return AVCT_RemoveBrowse(handle); -} -#endif /****************************************************************************** ** @@ -937,121 +494,7 @@ UINT16 AVRC_CloseBrowse(UINT8 handle) ******************************************************************************/ UINT16 AVRC_MsgReq (UINT8 handle, UINT8 label, UINT8 ctype, BT_HDR *p_pkt) { -#if (AVRC_METADATA_INCLUDED == TRUE) - UINT8 *p_data; - UINT8 cr = AVCT_CMD; - BOOLEAN chk_frag = TRUE; - UINT8 *p_start = NULL; - tAVRC_FRAG_CB *p_fcb; - UINT16 len; - BT_HDR *p_pkt_new; -#if ((AVRC_ADV_CTRL_INCLUDED == TRUE) && (AVCT_BROWSE_INCLUDED == TRUE)) - UINT16 peer_mtu; -#endif - - if (!p_pkt) - return AVRC_BAD_PARAM; - - if (ctype >= AVRC_RSP_NOT_IMPL) - cr = AVCT_RSP; - - if (p_pkt->event == AVRC_OP_VENDOR) - { - /* add AVRCP Vendor Dependent headers */ - p_start = ((UINT8 *)(p_pkt + 1) + p_pkt->offset); - p_pkt->offset -= AVRC_VENDOR_HDR_SIZE; - p_pkt->len += AVRC_VENDOR_HDR_SIZE; - p_data = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - *p_data++ = (ctype & AVRC_CTYPE_MASK); - *p_data++ = (AVRC_SUB_PANEL << AVRC_SUBTYPE_SHIFT); - *p_data++ = AVRC_OP_VENDOR; - AVRC_CO_ID_TO_BE_STREAM(p_data, AVRC_CO_METADATA); - } - else if (p_pkt->event == AVRC_OP_PASS_THRU) - { - /* add AVRCP Pass Through headers */ - p_start = ((UINT8 *)(p_pkt + 1) + p_pkt->offset); - p_pkt->offset -= AVRC_PASS_THRU_SIZE; - p_pkt->len += AVRC_PASS_THRU_SIZE; - p_data = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - *p_data++ = (ctype & AVRC_CTYPE_MASK); - *p_data++ = (AVRC_SUB_PANEL << AVRC_SUBTYPE_SHIFT); - *p_data++ = AVRC_OP_PASS_THRU;/* opcode */ - *p_data++ = AVRC_ID_VENDOR; /* operation id */ - *p_data++ = 5; /* operation data len */ - AVRC_CO_ID_TO_BE_STREAM(p_data, AVRC_CO_METADATA); - } -#if ((AVRC_ADV_CTRL_INCLUDED == TRUE) && (AVCT_BROWSE_INCLUDED == TRUE)) - else - { - chk_frag = FALSE; - peer_mtu = AVCT_GetBrowseMtu (handle); - if (p_pkt->len > (peer_mtu-AVCT_HDR_LEN_SINGLE)) - { - AVRC_TRACE_ERROR3 ("p_pkt->len(%d) > peer_mtu(%d-%d)", p_pkt->len, peer_mtu, AVCT_HDR_LEN_SINGLE ); - GKI_freebuf(p_pkt); - return AVRC_MSG_TOO_BIG; - } - } -#endif - - /* abandon previous fragments */ - p_fcb = &avrc_cb.fcb[handle]; - if (p_fcb->frag_enabled) - p_fcb->frag_enabled = FALSE; - - if (p_fcb->p_fmsg) - { - GKI_freebuf(p_fcb->p_fmsg); - p_fcb->p_fmsg = NULL; - } - - /* AVRCP spec has not defined any control channel commands that needs fragmentation at this level - * check for fragmentation only on the response */ - if ((cr == AVCT_RSP) && (chk_frag == TRUE)) - { - if (p_pkt->len > AVRC_MAX_CTRL_DATA_LEN) - { - AVRC_TRACE_DEBUG1 ("p_pkt->len(%d) > AVRC_MAX_CTRL_DATA_LEN", p_pkt->len ); - p_pkt_new = (BT_HDR *)GKI_getbuf((UINT16)(AVRC_PACKET_LEN + AVCT_MSG_OFFSET + BT_HDR_SIZE)); - if (p_pkt_new) - { - p_fcb->frag_enabled = TRUE; - p_fcb->p_fmsg = p_pkt; - p_fcb->frag_pdu = *p_start; - p_pkt = p_pkt_new; - p_pkt_new = p_fcb->p_fmsg; - p_pkt->len = AVRC_MAX_CTRL_DATA_LEN; - p_pkt->offset = p_pkt_new->offset; - p_pkt->layer_specific = p_pkt_new->layer_specific; - p_pkt->event = p_pkt_new->event; - p_data = (UINT8 *)(p_pkt+1) + p_pkt->offset; - p_start -= AVRC_VENDOR_HDR_SIZE; - memcpy (p_data, p_start, AVRC_MAX_CTRL_DATA_LEN); - /* use AVRC start packet type */ - p_data += AVRC_VENDOR_HDR_SIZE; - p_data++; /* pdu */ - *p_data++ = AVRC_PKT_START; - len = (AVRC_MAX_CTRL_DATA_LEN - AVRC_VENDOR_HDR_SIZE - AVRC_MIN_META_HDR_SIZE); /* 4 pdu, pkt_type & len */ - UINT16_TO_BE_STREAM(p_data, len); - - /* prepare the left over for as an end fragment */ - avrc_prep_end_frag (handle); - AVRC_TRACE_DEBUG3 ("p_pkt len:%d/%d, next len:%d", p_pkt->len, len, p_fcb->p_fmsg->len ); - } - else - { - AVRC_TRACE_ERROR0 ("AVRC_MsgReq no buffers for fragmentation" ); - GKI_freebuf(p_pkt); - return AVRC_NO_RESOURCES; - } - } - } - - return AVCT_MsgReq( handle, label, cr, p_pkt); -#else return AVRC_NO_RESOURCES; -#endif } diff --git a/stack/avrc/avrc_bld_ct.c b/stack/avrc/avrc_bld_ct.c deleted file mode 100644 index a1d5fa1..0000000 --- a/stack/avrc/avrc_bld_ct.c +++ /dev/null @@ -1,1102 +0,0 @@ -/***************************************************************************** -** -** Name: avrc_bld_ct.c -** -** Description:Interface to AVRCP build message functions for the Control Role -** -** Copyright (c) 2008-2008, Broadcom Corp., All Rights Reserved. -** Broadcom Bluetooth Core. Proprietary and confidential. -** -*****************************************************************************/ -#include <string.h> - -#include "gki.h" -#include "avrc_api.h" -#include "avrc_defs.h" -#include "avrc_int.h" - -/***************************************************************************** -** Global data -*****************************************************************************/ - - -#if (AVRC_METADATA_INCLUDED == TRUE) -/******************************************************************************* -** -** Function avrc_bld_get_capability_cmd -** -** Description This function builds the Get Capability command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_capability_cmd (tAVRC_GET_CAPS_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - if (!AVRC_IS_VALID_CAP_ID(p_cmd->capability_id)) - { - AVRC_TRACE_ERROR1("avrc_bld_get_capability_cmd bad capability_id:0x%x", p_cmd->capability_id); - return AVRC_STS_BAD_PARAM; - } - - AVRC_TRACE_API0("avrc_bld_get_capability_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - - /* add fixed lenth - capability_id(1) */ - UINT16_TO_BE_STREAM(p_data, 1); - /* add the capability_id */ - UINT8_TO_BE_STREAM(p_data, p_cmd->capability_id); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_list_app_settings_attr_cmd -** -** Description This function builds the List Application Settings Attribute -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_list_app_settings_attr_cmd (tAVRC_CMD *p_cmd, BT_HDR *p_pkt) -{ - AVRC_TRACE_API0("avrc_bld_list_app_settings_attr_cmd"); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_list_app_settings_values_cmd -** -** Description This function builds the List Application Setting Values -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_list_app_settings_values_cmd (tAVRC_LIST_APP_VALUES_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - if (!AVRC_IsValidPlayerAttr(p_cmd->attr_id)) - { - AVRC_TRACE_ERROR1("avrc_bld_list_app_settings_values_cmd bad attr:0x%x", p_cmd->attr_id); - return AVRC_STS_BAD_PARAM; - } - - AVRC_TRACE_API0("avrc_bld_list_app_settings_values_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - - /* add fixed lenth - attr_id(1) */ - UINT16_TO_BE_STREAM(p_data, 1); - /* add the attr_id */ - UINT8_TO_BE_STREAM(p_data, p_cmd->attr_id); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_get_cur_app_setting_value_cmd -** -** Description This function builds the Get Current Application Setting Value -** or the Get Application Setting Attribute Text command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_cur_app_setting_value_cmd (tAVRC_GET_CUR_APP_VALUE_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len; - UINT16 len = 0; - UINT8 xx; - UINT8 *p_count; - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_len = p_data = p_start + 2; /* pdu + rsvd */ - - BE_STREAM_TO_UINT16(len, p_data); - p_count = p_data; - if (len == 0) - { - /* first time initialize the attribute count */ - *p_count = 0; - p_data++; - len = 1; - } - else - { - p_data = p_start + p_pkt->len; - } - - for (xx=0; xx<p_cmd->num_attr; xx++) - { - if (AVRC_IsValidPlayerAttr(p_cmd->attrs[xx])) - { - (*p_count)++; - UINT8_TO_BE_STREAM(p_data, p_cmd->attrs[xx]); - len++; - } - } - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_set_app_setting_value_cmd -** -** Description This function builds the Set Application Setting Value -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_set_app_setting_value_cmd (tAVRC_SET_APP_VALUE_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len; - UINT16 len; - UINT8 xx; - UINT8 *p_count; - - if (!p_cmd->p_vals) - { - AVRC_TRACE_ERROR0("avrc_bld_set_app_setting_value_cmd NULL parameter"); - return AVRC_STS_BAD_PARAM; - } - - AVRC_TRACE_API1("avrc_bld_set_app_setting_value_cmd num_val:%d", p_cmd->num_val); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 2; /* pdu + rsvd */ - - BE_STREAM_TO_UINT16(len, p_data); - p_count = p_data; - if (len == 0) - { - /* first time initialize the attribute count */ - *p_count = 0; - p_data++; - len = 1; - } - else - { - p_data = p_start + p_pkt->len; - } - - - for (xx=0; xx<p_cmd->num_val; xx++) - { - AVRC_TRACE_DEBUG3("[%d] id/val = 0x%x/0x%x", xx, p_cmd->p_vals[xx].attr_id, p_cmd->p_vals[xx].attr_val); - if (avrc_is_valid_player_attrib_value(p_cmd->p_vals[xx].attr_id, p_cmd->p_vals[xx].attr_val)) - { - (*p_count)++; - UINT8_TO_BE_STREAM(p_data, p_cmd->p_vals[xx].attr_id); - UINT8_TO_BE_STREAM(p_data, p_cmd->p_vals[xx].attr_val); - len += 2; - } - } - - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_get_app_setting_attr_text_cmd -** -** Description This function builds the Get Application Setting Attribute Text -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_app_setting_attr_text_cmd (tAVRC_GET_APP_ATTR_TXT_CMD *p_cmd, BT_HDR *p_pkt) -{ - AVRC_TRACE_API0("avrc_bld_get_app_setting_attr_text_cmd"); - return avrc_bld_get_cur_app_setting_value_cmd((tAVRC_GET_CUR_APP_VALUE_CMD *)p_cmd, p_pkt); - -} - -/******************************************************************************* -** -** Function avrc_bld_get_app_setting_value_text_cmd -** -** Description This function builds the Get Application Setting Value Text -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_app_setting_value_text_cmd (tAVRC_GET_APP_VAL_TXT_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len; - UINT16 len = 0; - UINT8 xx; - UINT8 *p_count; - - AVRC_TRACE_API0("avrc_bld_get_app_setting_value_text_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 2; /* pdu + rsvd */ - - BE_STREAM_TO_UINT16(len, p_data); - p_count = p_data + 1; - if (len == 0) - { - /* first time initialize the attribute count */ - UINT8_TO_BE_STREAM(p_data, p_cmd->attr_id); - *p_count = 0; - p_data++; - len = 2; - } - else - { - p_data = p_start + p_pkt->len; - } - - for (xx=0; xx<p_cmd->num_val; xx++) - { - (*p_count)++; - UINT8_TO_BE_STREAM(p_data, p_cmd->vals[xx]); - len++; - } - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_inform_charset_cmd -** -** Description This function builds the Inform Displayable Character Set -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_inform_charset_cmd (tAVRC_INFORM_CHARSET_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT16 len = 0; - UINT8 xx; - - AVRC_TRACE_API0("avrc_bld_inform_charset_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - - len = 1 + (p_cmd->num_id << 1); - UINT16_TO_BE_STREAM(p_data, len); - - UINT8_TO_BE_STREAM(p_data, p_cmd->num_id); - for (xx=0; xx<p_cmd->num_id; xx++) - { - UINT16_TO_BE_STREAM(p_data, p_cmd->charsets[xx]); - } - - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_inform_battery_status_cmd -** -** Description This function builds the Inform Battery Status -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_inform_battery_status_cmd (tAVRC_BATTERY_STATUS_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - if (!AVRC_IS_VALID_BATTERY_STATUS(p_cmd->battery_status)) - { - AVRC_TRACE_ERROR1("avrc_bld_inform_battery_status_cmd bad battery_status:0x%x", p_cmd->battery_status); - return AVRC_STS_BAD_PARAM; - } - - AVRC_TRACE_API0("avrc_bld_inform_battery_status_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - /* add fixed lenth - battery_status(1) */ - UINT16_TO_BE_STREAM(p_data, 1); - /* add the battery_status */ - UINT8_TO_BE_STREAM(p_data, p_cmd->battery_status); - - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_get_elem_attrs_cmd -** -** Description This function builds the Get Element Attributes -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_elem_attrs_cmd (tAVRC_GET_ELEM_ATTRS_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len; - UINT16 len = 0; - UINT8 xx; - UINT8 *p_count; - - AVRC_TRACE_API0("avrc_bld_get_elem_attrs_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_len = p_start + 2; /* pdu + rsvd */ - p_data = p_len + 2; - - /* 8 byte identifier 0 - PLAYING - the only valid one */ - UINT32_TO_BE_STREAM(p_data, 0); - UINT32_TO_BE_STREAM(p_data, 0); - - p_count = p_data; - p_data++; - *p_count = 0; - len = 9; - for (xx=0; xx<p_cmd->num_attr; xx++) - { - if (AVRC_IS_VALID_MEDIA_ATTRIBUTE(p_cmd->attrs[xx])) - { - (*p_count)++; - UINT32_TO_BE_STREAM(p_data, p_cmd->attrs[xx]); - len += 4; - } - } - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_get_play_status_cmd -** -** Description This function builds the Get Play Status -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_play_status_cmd (tAVRC_CMD *p_cmd, BT_HDR *p_pkt) -{ - AVRC_TRACE_API0("avrc_bld_get_play_status_cmd"); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_notify_cmd -** -** Description This function builds the Register Notification command. -** -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_notify_cmd (tAVRC_REG_NOTIF_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - AVRC_TRACE_API0("avrc_bld_notify_cmd"); - if (!AVRC_IS_VALID_EVENT_ID(p_cmd->event_id)) - { - AVRC_TRACE_ERROR1("avrc_bld_notify_cmd bad event_id:0x%x", p_cmd->event_id); - return AVRC_STS_BAD_PARAM; - } - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - - /* add fixed lenth 5 - event_id (1) + interval(4) */ - UINT16_TO_BE_STREAM(p_data, 5); - UINT8_TO_BE_STREAM(p_data, p_cmd->event_id); - UINT32_TO_BE_STREAM(p_data, p_cmd->param); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_next_cmd -** -** Description This function builds the Request Continue or Abort command. -** -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_next_cmd (tAVRC_NEXT_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - AVRC_TRACE_API0("avrc_bld_next_cmd"); - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - - /* add fixed lenth 1 - pdu_id (1) */ - UINT16_TO_BE_STREAM(p_data, 1); - UINT8_TO_BE_STREAM(p_data, p_cmd->target_pdu); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_group_navigation_cmd -** -** Description This function builds the Group Navigation -** command. -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -tAVRC_STS avrc_bld_group_navigation_cmd (UINT16 navi_id, BT_HDR *p_pkt) -{ - UINT8 *p_data; - - if (!AVRC_IS_VALID_GROUP(navi_id)) - { - AVRC_TRACE_ERROR1("avrc_bld_group_navigation_cmd bad navigation op id: %d", navi_id); - return AVRC_STS_BAD_PARAM; - } - - AVRC_TRACE_API0("avrc_bld_group_navigation_cmd"); - p_data = (UINT8 *)(p_pkt+1) + p_pkt->offset; - UINT16_TO_BE_STREAM(p_data, navi_id); - p_pkt->len = 2; - return AVRC_STS_NO_ERROR; -} - -/***************************************************************************** -** the following commands are introduced in AVRCP 1.4 -*****************************************************************************/ - -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) -/******************************************************************************* -** -** Function avrc_bld_set_addr_player_cmd -** -** Description This function builds the Set Addresses Player command. -** -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_set_addr_player_cmd (tAVRC_SET_ADDR_PLAYER_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - AVRC_TRACE_API0("avrc_bld_set_addr_player_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - /* add fixed lenth - player_id(2) */ - UINT16_TO_BE_STREAM(p_data, 2); - UINT16_TO_BE_STREAM(p_data, p_cmd->player_id); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_set_abs_volume_cmd -** -** Description This function builds the Set Absolute Volume command. -** -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_set_abs_volume_cmd (tAVRC_SET_VOLUME_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - AVRC_TRACE_API0("avrc_bld_set_abs_volume_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - /* add fixed lenth 1 - volume (1) */ - UINT16_TO_BE_STREAM(p_data, 1); - UINT8_TO_BE_STREAM(p_data, (AVRC_MAX_VOLUME & p_cmd->volume)); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_set_browsed_player_cmd -** -** Description This function builds the Set Browsed Player command. -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_set_browsed_player_cmd (tAVRC_SET_BR_PLAYER_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - AVRC_TRACE_API0("avrc_bld_set_browsed_player_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 1; /* pdu */ - /* add fixed lenth - player_id(2) */ - UINT16_TO_BE_STREAM(p_data, 2); - UINT16_TO_BE_STREAM(p_data, p_cmd->player_id); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} -#endif - -/******************************************************************************* -** -** Function avrc_bld_get_folder_items_cmd -** -** Description This function builds the Get Folder Items command. -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_get_folder_items_cmd (tAVRC_GET_ITEMS_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len, xx; - UINT16 len = 0; - - AVRC_TRACE_API0("avrc_bld_get_folder_items_cmd"); - if (p_cmd->scope > AVRC_SCOPE_NOW_PLAYING || p_cmd->start_item > p_cmd->end_item) - { - AVRC_TRACE_ERROR3("bad scope:0x%x or range (%d-%d)", p_cmd->scope, p_cmd->start_item, p_cmd->end_item); - return AVRC_STS_BAD_PARAM; - } - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_len = p_start + 1; /* pdu */ - p_data = p_len + 2; - - UINT8_TO_BE_STREAM(p_data, p_cmd->scope); - UINT32_TO_BE_STREAM(p_data, p_cmd->start_item); - UINT32_TO_BE_STREAM(p_data, p_cmd->end_item); - /* do not allow us to send the command with attribute list when scope is player list */ - if (p_cmd->scope == AVRC_SCOPE_PLAYER_LIST) - p_cmd->attr_count = 0; - - UINT8_TO_BE_STREAM(p_data, p_cmd->attr_count); - len = 10; - if ((p_cmd->attr_count != AVRC_FOLDER_ITEM_COUNT_NONE) && - (p_cmd->attr_count > 0)) - { - if (p_cmd->p_attr_list) - { - for (xx=0; xx<p_cmd->attr_count; xx++) - { - UINT32_TO_BE_STREAM(p_data, p_cmd->p_attr_list[xx]); - len += 4; - } - } - else - { - AVRC_TRACE_ERROR1("attr_count:%d but NULL p_attr_list", p_cmd->attr_count); - return AVRC_STS_BAD_PARAM; - } - } - - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} -#endif - -/******************************************************************************* -** -** Function avrc_bld_change_path_cmd -** -** Description This function builds the Change Path command. -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_change_path_cmd (tAVRC_CHG_PATH_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - AVRC_TRACE_API0("avrc_bld_change_path_cmd"); - if (p_cmd->direction != AVRC_DIR_UP && p_cmd->direction != AVRC_DIR_DOWN) - { - AVRC_TRACE_ERROR1("AVRC_BldChangePathCmd bad direction:%d", p_cmd->direction); - return AVRC_STS_BAD_PARAM; - } - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 1; /* pdu */ - /* add fixed lenth - uid_counter(2) + direction(1) + uid(8) */ - UINT16_TO_BE_STREAM(p_data, 11); - UINT16_TO_BE_STREAM(p_data, p_cmd->uid_counter); - *p_data++ = p_cmd->direction; - ARRAY_TO_BE_STREAM(p_data, p_cmd->folder_uid, AVRC_UID_SIZE); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} -#endif - -/******************************************************************************* -** -** Function avrc_bld_get_item_attrs_cmd -** -** Description This function builds the Get Item Attributes command. -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_get_item_attrs_cmd (tAVRC_GET_ATTRS_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len, xx; - UINT16 len; - UINT8 *p_count; - - AVRC_TRACE_API0("avrc_bld_get_item_attrs_cmd"); - if (p_cmd->scope > AVRC_SCOPE_NOW_PLAYING) - { - AVRC_TRACE_ERROR1("bad scope:%d", p_cmd->scope); - return AVRC_STS_BAD_PARAM; - } - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_len = p_start + 1; /* pdu */ - p_data = p_len + 2; - - UINT8_TO_BE_STREAM(p_data, p_cmd->scope); - ARRAY_TO_BE_STREAM(p_data, p_cmd->uid, AVRC_UID_SIZE); - UINT16_TO_BE_STREAM(p_data, p_cmd->uid_counter); - //UINT8_TO_BE_STREAM(p_data, p_cmd->attr_count); - p_count = p_data++; - len = AVRC_UID_SIZE + 4; - *p_count = 0; - - if (p_cmd->attr_count>0) - { - if (p_cmd->p_attr_list) - { - for (xx=0; xx<p_cmd->attr_count; xx++) - { - if (AVRC_IS_VALID_MEDIA_ATTRIBUTE(p_cmd->p_attr_list[xx])) - { - (*p_count)++; - UINT32_TO_BE_STREAM(p_data, p_cmd->p_attr_list[xx]); - len += 4; - } -#if (BT_USE_TRACES == TRUE) - else - { - AVRC_TRACE_ERROR1("invalid attr id:%d", p_cmd->p_attr_list[xx]); - } -#endif - } - } -#if (BT_USE_TRACES == TRUE) - else - { - AVRC_TRACE_ERROR1("attr_count:%d, NULL p_attr_list", p_cmd->attr_count); - } -#endif - } - UINT16_TO_BE_STREAM(p_len, len); - - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} -#endif - -/******************************************************************************* -** -** Function avrc_bld_search_cmd -** -** Description This function builds the Search command. -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_search_cmd (tAVRC_SEARCH_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT16 len; - - AVRC_TRACE_API0("avrc_bld_search_cmd"); - if (!p_cmd->string.p_str) - { - AVRC_TRACE_ERROR0("null string"); - return AVRC_STS_BAD_PARAM; - } - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 1; /* pdu */ - /* variable lenth */ - len = p_cmd->string.str_len + 4; - UINT16_TO_BE_STREAM(p_data, len); - - UINT16_TO_BE_STREAM(p_data, p_cmd->string.charset_id); - UINT16_TO_BE_STREAM(p_data, p_cmd->string.str_len); - ARRAY_TO_BE_STREAM(p_data, p_cmd->string.p_str, p_cmd->string.str_len); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} -#endif - -/******************************************************************************* -** -** Function avrc_bld_play_item_cmd -** -** Description This function builds the Play Item command. -** -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_play_item_cmd (tAVRC_PLAY_ITEM_CMD *p_cmd, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - AVRC_TRACE_API0("avrc_bld_play_item_cmd"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - - /* fixed lenth - scope(1) + uid(8) + uid_counter(2) */ - UINT16_TO_BE_STREAM(p_data, 11); - - UINT8_TO_BE_STREAM(p_data, p_cmd->scope); - ARRAY_TO_BE_STREAM(p_data, p_cmd->uid, AVRC_UID_SIZE); - UINT16_TO_BE_STREAM(p_data, p_cmd->uid_counter); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_add_to_now_playing_cmd -** -** Description This function builds the Add to Now Playing command. -** -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_add_to_now_playing_cmd (tAVRC_ADD_TO_PLAY_CMD *p_cmd, BT_HDR *p_pkt) -{ - AVRC_TRACE_API0("avrc_bld_add_to_now_playing_cmd"); - return avrc_bld_play_item_cmd((tAVRC_PLAY_ITEM_CMD *)p_cmd, p_pkt); -} - -#endif /* AVRC_ADV_CTRL_INCLUDED=TRUE */ - -/******************************************************************************* -** -** Function avrc_bld_init_cmd_buffer -** -** Description This function initializes the command buffer based on PDU -** -** Returns NULL, if no GKI buffer or failure to build the message. -** Otherwise, the GKI buffer that contains the initialized message. -** -*******************************************************************************/ -static BT_HDR *avrc_bld_init_cmd_buffer(tAVRC_COMMAND *p_cmd) -{ - UINT16 offset, chnl = AVCT_DATA_CTRL, len=AVRC_META_CMD_POOL_SIZE; - BT_HDR *p_pkt=NULL; - UINT8 opcode; - - opcode = avrc_opcode_from_pdu(p_cmd->pdu); - AVRC_TRACE_API2("avrc_bld_init_cmd_buffer: pdu=%x, opcode=%x", p_cmd->pdu, opcode); - - switch (opcode) - { -#if (AVCT_BROWSE_INCLUDED == TRUE) - case AVRC_OP_BROWSE: - chnl = AVCT_DATA_BROWSE; - offset = AVCT_BROWSE_OFFSET; - len = AVRC_BROWSE_POOL_SIZE; - break; -#endif /* AVCT_BROWSE_INCLUDED */ - - case AVRC_OP_PASS_THRU: - offset = AVRC_MSG_PASS_THRU_OFFSET; - break; - - case AVRC_OP_VENDOR: - offset = AVRC_MSG_VENDOR_OFFSET; - break; - } - - /* allocate and initialize the buffer */ - p_pkt = (BT_HDR *)GKI_getbuf(len); - if (p_pkt) - { - UINT8 *p_data, *p_start; - - p_pkt->layer_specific = chnl; - p_pkt->event = opcode; - p_pkt->offset = offset; - p_data = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_start = p_data; - - /* pass thru - group navigation - has a two byte op_id, so dont do it here */ - if (opcode != AVRC_OP_PASS_THRU) - *p_data++ = p_cmd->pdu; - - switch (opcode) - { - case AVRC_OP_VENDOR: - /* reserved 0, packet_type 0 */ - UINT8_TO_BE_STREAM(p_data, 0); - /* continue to the next "case to add length */ -#if (AVCT_BROWSE_INCLUDED == TRUE) - case AVRC_OP_BROWSE: -#endif - /* add fixed lenth - 0 */ - UINT16_TO_BE_STREAM(p_data, 0); - break; - } - - p_pkt->len = (p_data - p_start); - } - p_cmd->cmd.opcode = opcode; - return p_pkt; -} - -/******************************************************************************* -** -** Function AVRC_BldCommand -** -** Description This function builds the given AVRCP command to the given -** GKI buffer -** -** Returns AVRC_STS_NO_ERROR, if the command is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -tAVRC_STS AVRC_BldCommand( tAVRC_COMMAND *p_cmd, BT_HDR **pp_pkt) -{ - tAVRC_STS status = AVRC_STS_BAD_PARAM; - BT_HDR *p_pkt; - BOOLEAN alloc = FALSE; - - AVRC_TRACE_API2("AVRC_BldCommand: pdu=%x status=%x", p_cmd->cmd.pdu, p_cmd->cmd.status); - if (!p_cmd || !pp_pkt) - { - AVRC_TRACE_API2("AVRC_BldCommand. Invalid parameters passed. p_cmd=%p, pp_pkt=%p", p_cmd, pp_pkt); - return AVRC_STS_BAD_PARAM; - } - - if (*pp_pkt == NULL) - { - if ((*pp_pkt = avrc_bld_init_cmd_buffer(p_cmd)) == NULL) - { - AVRC_TRACE_API0("AVRC_BldCommand: Failed to initialize command buffer"); - return AVRC_STS_INTERNAL_ERR; - } - alloc = TRUE; - } - status = AVRC_STS_NO_ERROR; - p_pkt = *pp_pkt; - - switch (p_cmd->pdu) - { - case AVRC_PDU_NEXT_GROUP: /* 0x00 */ - case AVRC_PDU_PREV_GROUP: /* 0x01 */ - status = avrc_bld_group_navigation_cmd (p_cmd->pdu, p_pkt); - break; - - case AVRC_PDU_GET_CAPABILITIES: - status = avrc_bld_get_capability_cmd(&p_cmd->get_caps, p_pkt); - break; - - case AVRC_PDU_LIST_PLAYER_APP_ATTR: - status = avrc_bld_list_app_settings_attr_cmd(&p_cmd->list_app_attr, p_pkt); - break; - - case AVRC_PDU_LIST_PLAYER_APP_VALUES: - status = avrc_bld_list_app_settings_values_cmd(&p_cmd->list_app_values, p_pkt); - break; - - case AVRC_PDU_GET_CUR_PLAYER_APP_VALUE: - status = avrc_bld_get_cur_app_setting_value_cmd(&p_cmd->get_cur_app_val, p_pkt); - break; - - case AVRC_PDU_SET_PLAYER_APP_VALUE: - status = avrc_bld_set_app_setting_value_cmd(&p_cmd->set_app_val, p_pkt); - break; - - case AVRC_PDU_GET_PLAYER_APP_ATTR_TEXT: - status = avrc_bld_get_app_setting_attr_text_cmd(&p_cmd->get_app_attr_txt, p_pkt); - break; - - case AVRC_PDU_GET_PLAYER_APP_VALUE_TEXT: - status = avrc_bld_get_app_setting_value_text_cmd(&p_cmd->get_app_val_txt, p_pkt); - break; - - case AVRC_PDU_INFORM_DISPLAY_CHARSET: - status = avrc_bld_inform_charset_cmd(&p_cmd->inform_charset, p_pkt); - break; - - case AVRC_PDU_INFORM_BATTERY_STAT_OF_CT: - status = avrc_bld_inform_battery_status_cmd(&p_cmd->inform_battery_status, p_pkt); - break; - - case AVRC_PDU_GET_ELEMENT_ATTR: - status = avrc_bld_get_elem_attrs_cmd(&p_cmd->get_elem_attrs, p_pkt); - break; - - case AVRC_PDU_GET_PLAY_STATUS: - status = avrc_bld_get_play_status_cmd(&p_cmd->get_play_status, p_pkt); - break; - - case AVRC_PDU_REGISTER_NOTIFICATION: - status = avrc_bld_notify_cmd(&p_cmd->reg_notif, p_pkt); - break; - - case AVRC_PDU_REQUEST_CONTINUATION_RSP: /* 0x40 */ - status = avrc_bld_next_cmd(&p_cmd->continu, p_pkt); - break; - - case AVRC_PDU_ABORT_CONTINUATION_RSP: /* 0x41 */ - status = avrc_bld_next_cmd(&p_cmd->abort, p_pkt); - break; - -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) - case AVRC_PDU_SET_ABSOLUTE_VOLUME: /* 0x50 */ - status = avrc_bld_set_abs_volume_cmd(&p_cmd->volume, p_pkt); - break; - - case AVRC_PDU_SET_ADDRESSED_PLAYER: /* 0x60 */ - status = avrc_bld_set_addr_player_cmd(&p_cmd->addr_player, p_pkt); - break; - - case AVRC_PDU_PLAY_ITEM: /* 0x74 */ - status = avrc_bld_play_item_cmd(&p_cmd->play_item, p_pkt); - break; - - case AVRC_PDU_ADD_TO_NOW_PLAYING: /* 0x90 */ - status = avrc_bld_add_to_now_playing_cmd(&p_cmd->add_to_play, p_pkt); - break; - -#if (AVCT_BROWSE_INCLUDED == TRUE) - case AVRC_PDU_SET_BROWSED_PLAYER: /* 0x70 */ - status = avrc_bld_set_browsed_player_cmd(&p_cmd->br_player, p_pkt); - break; - - case AVRC_PDU_GET_FOLDER_ITEMS: /* 0x71 */ - status = avrc_bld_get_folder_items_cmd(&p_cmd->get_items, p_pkt); - break; - - case AVRC_PDU_CHANGE_PATH: /* 0x72 */ - status = avrc_bld_change_path_cmd(&p_cmd->chg_path, p_pkt); - break; - - case AVRC_PDU_GET_ITEM_ATTRIBUTES: /* 0x73 */ - status = avrc_bld_get_item_attrs_cmd(&p_cmd->get_attrs, p_pkt); - break; - - case AVRC_PDU_SEARCH: /* 0x80 */ - status = avrc_bld_search_cmd(&p_cmd->search, p_pkt); - break; -#endif -#endif - - } - - if (alloc && (status != AVRC_STS_NO_ERROR) ) - { - GKI_freebuf(p_pkt); - *pp_pkt = NULL; - } - AVRC_TRACE_API1("AVRC_BldCommand: returning %d", status); - return status; -} -#endif /* (AVRC_METADATA_INCLUDED == TRUE) */ - diff --git a/stack/avrc/avrc_bld_tg.c b/stack/avrc/avrc_bld_tg.c deleted file mode 100644 index 667499e..0000000 --- a/stack/avrc/avrc_bld_tg.c +++ /dev/null @@ -1,1547 +0,0 @@ -/***************************************************************************** -** -** Name: avrc_bld_tg.c -** -** Description:Interface to AVRCP build message functions for the Target Role -** -** Copyright (c) 2008-2008, Broadcom Corp., All Rights Reserved. -** Broadcom Bluetooth Core. Proprietary and confidential. -** -*****************************************************************************/ -#include <string.h> - -#include "gki.h" -#include "avrc_api.h" -#include "avrc_defs.h" -#include "avrc_int.h" - -/***************************************************************************** -** Global data -*****************************************************************************/ -#if (AVRC_METADATA_INCLUDED == TRUE) - -/******************************************************************************* -** -** Function avrc_bld_get_capability_rsp -** -** Description This function builds the Get Capability response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_capability_rsp (tAVRC_GET_CAPS_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start, *p_len, *p_count; - UINT16 len = 0; - UINT8 xx; - UINT32 *p_company_id; - UINT8 *p_event_id; - tAVRC_STS status = AVRC_STS_NO_ERROR; - - if (!(AVRC_IS_VALID_CAP_ID(p_rsp->capability_id))) - { - AVRC_TRACE_ERROR1("avrc_bld_get_capability_rsp bad parameter. p_rsp: %x", p_rsp); - status = AVRC_STS_BAD_PARAM; - return status; - } - - AVRC_TRACE_API0("avrc_bld_get_capability_rsp"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 2; /* pdu + rsvd */ - - BE_STREAM_TO_UINT16(len, p_data); - UINT8_TO_BE_STREAM(p_data, p_rsp->capability_id); - p_count = p_data; - - if (len == 0) - { - *p_count = p_rsp->count; - p_data++; - len = 2; /* move past the capability_id and count */ - } - else - { - p_data = p_start + p_pkt->len; - *p_count += p_rsp->count; - } - - if (p_rsp->capability_id == AVRC_CAP_COMPANY_ID) - { - p_company_id = p_rsp->param.company_id; - for (xx=0; xx< p_rsp->count; xx++) - { - UINT24_TO_BE_STREAM(p_data, p_company_id[xx]); - } - len += p_rsp->count * 3; - } - else - { - p_event_id = p_rsp->param.event_id; - *p_count = 0; - for (xx=0; xx< p_rsp->count; xx++) - { - if (AVRC_IS_VALID_EVENT_ID(p_event_id[xx])) - { - (*p_count)++; - UINT8_TO_BE_STREAM(p_data, p_event_id[xx]); - } - } - len += (*p_count); - } - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - status = AVRC_STS_NO_ERROR; - - return status; -} - -/******************************************************************************* -** -** Function avrc_bld_list_app_settings_attr_rsp -** -** Description This function builds the List Application Settings Attribute -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_list_app_settings_attr_rsp (tAVRC_LIST_APP_ATTR_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start, *p_len, *p_num; - UINT16 len = 0; - UINT8 xx; - - AVRC_TRACE_API0("avrc_bld_list_app_settings_attr_rsp"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 2; /* pdu + rsvd */ - - BE_STREAM_TO_UINT16(len, p_data); - p_num = p_data; - if (len == 0) - { - /* first time initialize the attribute count */ - *p_num = 0; - p_data++; - } - else - { - p_data = p_start + p_pkt->len; - } - - for (xx=0; xx<p_rsp->num_attr; xx++) - { - if(AVRC_IsValidPlayerAttr(p_rsp->attrs[xx])) - { - (*p_num)++; - UINT8_TO_BE_STREAM(p_data, p_rsp->attrs[xx]); - } - } - - len = *p_num + 1; - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_list_app_settings_values_rsp -** -** Description This function builds the List Application Setting Values -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_list_app_settings_values_rsp (tAVRC_LIST_APP_VALUES_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start, *p_len, *p_num; - UINT8 xx; - UINT16 len; - - AVRC_TRACE_API0("avrc_bld_list_app_settings_values_rsp"); - - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 2; /* pdu + rsvd */ - - /* get the existing length, if any, and also the num attributes */ - BE_STREAM_TO_UINT16(len, p_data); - p_num = p_data; - /* first time initialize the attribute count */ - if (len == 0) - { - *p_num = p_rsp->num_val; - p_data++; - } - else - { - p_data = p_start + p_pkt->len; - *p_num += p_rsp->num_val; - } - - - for (xx=0; xx<p_rsp->num_val; xx++) - { - UINT8_TO_BE_STREAM(p_data, p_rsp->vals[xx]); - } - - len = *p_num + 1; - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_get_cur_app_setting_value_rsp -** -** Description This function builds the Get Current Application Setting Value -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_cur_app_setting_value_rsp (tAVRC_GET_CUR_APP_VALUE_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start, *p_len, *p_count; - UINT16 len; - UINT8 xx; - - if (!p_rsp->p_vals) - { - AVRC_TRACE_ERROR0("avrc_bld_get_cur_app_setting_value_rsp NULL parameter"); - return AVRC_STS_BAD_PARAM; - } - - AVRC_TRACE_API0("avrc_bld_get_cur_app_setting_value_rsp"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 2; /* pdu + rsvd */ - - BE_STREAM_TO_UINT16(len, p_data); - p_count = p_data; - if (len == 0) - { - /* first time initialize the attribute count */ - *p_count = 0; - p_data++; - } - else - { - p_data = p_start + p_pkt->len; - } - - for (xx=0; xx<p_rsp->num_val; xx++) - { - if (avrc_is_valid_player_attrib_value(p_rsp->p_vals[xx].attr_id, p_rsp->p_vals[xx].attr_val)) - { - (*p_count)++; - UINT8_TO_BE_STREAM(p_data, p_rsp->p_vals[xx].attr_id); - UINT8_TO_BE_STREAM(p_data, p_rsp->p_vals[xx].attr_val); - } - } - len = ((*p_count) << 1) + 1; - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_set_app_setting_value_rsp -** -** Description This function builds the Set Application Setting Value -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_set_app_setting_value_rsp (tAVRC_RSP *p_rsp, BT_HDR *p_pkt) -{ - /* nothing to be added. */ - AVRC_TRACE_API0("avrc_bld_set_app_setting_value_rsp"); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_app_setting_text_rsp -** -** Description This function builds the Get Application Settings Attribute Text -** or Get Application Settings Value Text response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_app_setting_text_rsp (tAVRC_GET_APP_ATTR_TXT_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start, *p_len, *p_count; - UINT16 len, len_left; - UINT8 xx; - tAVRC_STS sts = AVRC_STS_NO_ERROR; - UINT8 num_added = 0; - - if (!p_rsp->p_attrs) - { - AVRC_TRACE_ERROR0("avrc_bld_app_setting_text_rsp NULL parameter"); - return AVRC_STS_BAD_PARAM; - } - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 2; /* pdu + rsvd */ - len_left = GKI_get_buf_size(p_pkt) - BT_HDR_SIZE - p_pkt->offset - p_pkt->len; - - BE_STREAM_TO_UINT16(len, p_data); - p_count = p_data; - - if (len == 0) - { - *p_count = 0; - p_data++; - } - else - { - p_data = p_start + p_pkt->len; - } - - for (xx=0; xx<p_rsp->num_attr; xx++) - { - if (len_left < (p_rsp->p_attrs[xx].str_len + 4)) - { - AVRC_TRACE_ERROR3("avrc_bld_app_setting_text_rsp out of room (str_len:%d, left:%d)", - xx, p_rsp->p_attrs[xx].str_len, len_left); - p_rsp->num_attr = num_added; - sts = AVRC_STS_INTERNAL_ERR; - break; - } - if ( !p_rsp->p_attrs[xx].str_len || !p_rsp->p_attrs[xx].p_str ) - { - AVRC_TRACE_ERROR1("avrc_bld_app_setting_text_rsp NULL attr text[%d]", xx); - continue; - } - UINT8_TO_BE_STREAM(p_data, p_rsp->p_attrs[xx].attr_id); - UINT16_TO_BE_STREAM(p_data, p_rsp->p_attrs[xx].charset_id); - UINT8_TO_BE_STREAM(p_data, p_rsp->p_attrs[xx].str_len); - ARRAY_TO_BE_STREAM(p_data, p_rsp->p_attrs[xx].p_str, p_rsp->p_attrs[xx].str_len); - (*p_count)++; - num_added++; - } - len = p_data - p_count; - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - - return sts; -} - -/******************************************************************************* -** -** Function avrc_bld_get_app_setting_attr_text_rsp -** -** Description This function builds the Get Application Setting Attribute Text -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_app_setting_attr_text_rsp (tAVRC_GET_APP_ATTR_TXT_RSP *p_rsp, BT_HDR *p_pkt) -{ - AVRC_TRACE_API0("avrc_bld_get_app_setting_attr_text_rsp"); - return avrc_bld_app_setting_text_rsp(p_rsp, p_pkt); -} - -/******************************************************************************* -** -** Function avrc_bld_get_app_setting_value_text_rsp -** -** Description This function builds the Get Application Setting Value Text -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_app_setting_value_text_rsp (tAVRC_GET_APP_ATTR_TXT_RSP *p_rsp, BT_HDR *p_pkt) -{ - AVRC_TRACE_API0("avrc_bld_get_app_setting_value_text_rsp"); - return avrc_bld_app_setting_text_rsp(p_rsp, p_pkt); -} - -/******************************************************************************* -** -** Function avrc_bld_inform_charset_rsp -** -** Description This function builds the Inform Displayable Character Set -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_inform_charset_rsp (tAVRC_RSP *p_rsp, BT_HDR *p_pkt) -{ - /* nothing to be added. */ - AVRC_TRACE_API0("avrc_bld_inform_charset_rsp"); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_inform_battery_status_rsp -** -** Description This function builds the Inform Battery Status -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_inform_battery_status_rsp (tAVRC_RSP *p_rsp, BT_HDR *p_pkt) -{ - /* nothing to be added. */ - AVRC_TRACE_API0("avrc_bld_inform_battery_status_rsp"); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_get_elem_attrs_rsp -** -** Description This function builds the Get Element Attributes -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_elem_attrs_rsp (tAVRC_GET_ELEM_ATTRS_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start, *p_len, *p_count; - UINT16 len; - UINT8 xx; - - AVRC_TRACE_API0("avrc_bld_get_elem_attrs_rsp"); - if (!p_rsp->p_attrs) - { - AVRC_TRACE_ERROR0("avrc_bld_get_elem_attrs_rsp NULL parameter"); - return AVRC_STS_BAD_PARAM; - } - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 2; /* pdu + rsvd */ - - BE_STREAM_TO_UINT16(len, p_data); - p_count = p_data; - - if (len == 0) - { - *p_count = 0; - p_data++; - } - else - { - p_data = p_start + p_pkt->len; - } - - for (xx=0; xx<p_rsp->num_attr; xx++) - { - if (!AVRC_IS_VALID_MEDIA_ATTRIBUTE(p_rsp->p_attrs[xx].attr_id)) - { - AVRC_TRACE_ERROR2("avrc_bld_get_elem_attrs_rsp invalid attr id[%d]: %d", xx, p_rsp->p_attrs[xx].attr_id); - continue; - } - if ( !p_rsp->p_attrs[xx].name.p_str ) - { - p_rsp->p_attrs[xx].name.str_len = 0; - } - UINT32_TO_BE_STREAM(p_data, p_rsp->p_attrs[xx].attr_id); - UINT16_TO_BE_STREAM(p_data, p_rsp->p_attrs[xx].name.charset_id); - UINT16_TO_BE_STREAM(p_data, p_rsp->p_attrs[xx].name.str_len); - ARRAY_TO_BE_STREAM(p_data, p_rsp->p_attrs[xx].name.p_str, p_rsp->p_attrs[xx].name.str_len); - (*p_count)++; - } - len = p_data - p_count; - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_get_play_status_rsp -** -** Description This function builds the Get Play Status -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_get_play_status_rsp (tAVRC_GET_PLAY_STATUS_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - AVRC_TRACE_API0("avrc_bld_get_play_status_rsp"); - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; - - /* add fixed lenth - song len(4) + song position(4) + status(1) */ - UINT16_TO_BE_STREAM(p_data, 9); - UINT32_TO_BE_STREAM(p_data, p_rsp->song_len); - UINT32_TO_BE_STREAM(p_data, p_rsp->song_pos); - UINT8_TO_BE_STREAM(p_data, p_rsp->play_status); - p_pkt->len = (p_data - p_start); - - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_notify_rsp -** -** Description This function builds the Notification response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_notify_rsp (tAVRC_REG_NOTIF_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len; - UINT16 len = 0; - UINT8 xx; - tAVRC_STS status = AVRC_STS_NO_ERROR; - - AVRC_TRACE_API0("avrc_bld_notify_rsp"); - - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 2; /* pdu + rsvd */ - p_data += 2; - - UINT8_TO_BE_STREAM(p_data, p_rsp->event_id); - switch (p_rsp->event_id) - { - case AVRC_EVT_PLAY_STATUS_CHANGE: /* 0x01 */ - /* p_rsp->param.play_status >= AVRC_PLAYSTATE_STOPPED is always TRUE */ - if ((p_rsp->param.play_status <= AVRC_PLAYSTATE_REV_SEEK) || - (p_rsp->param.play_status == AVRC_PLAYSTATE_ERROR) ) - { - UINT8_TO_BE_STREAM(p_data, p_rsp->param.play_status); - len = 2; - } - else - { - AVRC_TRACE_ERROR0("bad play state"); - status = AVRC_STS_BAD_PARAM; - } - break; - - case AVRC_EVT_TRACK_CHANGE: /* 0x02 */ - ARRAY_TO_BE_STREAM(p_data, p_rsp->param.track, AVRC_UID_SIZE); - len = (UINT8)(AVRC_UID_SIZE + 1); - break; - - case AVRC_EVT_TRACK_REACHED_END: /* 0x03 */ - case AVRC_EVT_TRACK_REACHED_START: /* 0x04 */ -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) - case AVRC_EVT_NOW_PLAYING_CHANGE: /* 0x09 */ - case AVRC_EVT_AVAL_PLAYERS_CHANGE: /* 0x0a */ -#endif - len = 1; - break; - - case AVRC_EVT_PLAY_POS_CHANGED: /* 0x05 */ - UINT32_TO_BE_STREAM(p_data, p_rsp->param.play_pos); - len = 5; - break; - - case AVRC_EVT_BATTERY_STATUS_CHANGE: /* 0x06 */ - if (AVRC_IS_VALID_BATTERY_STATUS(p_rsp->param.battery_status)) - { - UINT8_TO_BE_STREAM(p_data, p_rsp->param.battery_status); - len = 2; - } - else - { - AVRC_TRACE_ERROR0("bad battery status"); - status = AVRC_STS_BAD_PARAM; - } - break; - - case AVRC_EVT_SYSTEM_STATUS_CHANGE: /* 0x07 */ - if (AVRC_IS_VALID_SYSTEM_STATUS(p_rsp->param.system_status)) - { - UINT8_TO_BE_STREAM(p_data, p_rsp->param.system_status); - len = 2; - } - else - { - AVRC_TRACE_ERROR0("bad system status"); - status = AVRC_STS_BAD_PARAM; - } - break; - - case AVRC_EVT_APP_SETTING_CHANGE: /* 0x08 */ - if (p_rsp->param.player_setting.num_attr > AVRC_MAX_APP_SETTINGS) - p_rsp->param.player_setting.num_attr = AVRC_MAX_APP_SETTINGS; - - if (p_rsp->param.player_setting.num_attr > 0) - { - UINT8_TO_BE_STREAM(p_data, p_rsp->param.player_setting.num_attr); - len = 2; - for (xx=0; xx<p_rsp->param.player_setting.num_attr; xx++) - { - if (avrc_is_valid_player_attrib_value(p_rsp->param.player_setting.attr_id[xx], p_rsp->param.player_setting.attr_value[xx])) - { - UINT8_TO_BE_STREAM(p_data, p_rsp->param.player_setting.attr_id[xx]); - UINT8_TO_BE_STREAM(p_data, p_rsp->param.player_setting.attr_value[xx]); - } - else - { - AVRC_TRACE_ERROR0("bad player app seeting attribute or value"); - status = AVRC_STS_BAD_PARAM; - break; - } - len += 2; - } - } - else - status = AVRC_STS_BAD_PARAM; - break; - -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) - case AVRC_EVT_ADDR_PLAYER_CHANGE: /* 0x0b */ - UINT16_TO_BE_STREAM(p_data, p_rsp->param.addr_player.player_id); /* player_id */ - UINT16_TO_BE_STREAM(p_data, p_rsp->param.addr_player.uid_counter); /* uid counter */ - len = 5; - break; - - case AVRC_EVT_UIDS_CHANGE: /* 0x0c */ - UINT16_TO_BE_STREAM(p_data, p_rsp->param.uid_counter); /* uid counter */ - len = 3; - break; - - case AVRC_EVT_VOLUME_CHANGE: /* 0x0d */ - UINT8_TO_BE_STREAM(p_data, (UINT8)(p_rsp->param.volume&AVRC_MAX_VOLUME)); - len = 2; - break; -#endif - - default: - status = AVRC_STS_BAD_PARAM; - AVRC_TRACE_ERROR0("unknown event_id"); - } - - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - - return status; -} - -/******************************************************************************* -** -** Function avrc_bld_next_rsp -** -** Description This function builds the Request Continue or Abort -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_next_rsp (tAVRC_RSP *p_rsp, BT_HDR *p_pkt) -{ - /* nothing to be added. */ - AVRC_TRACE_API0("avrc_bld_next_rsp"); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_group_navigation_rsp -** -** Description This function builds the Group Navigation -** response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -tAVRC_STS avrc_bld_group_navigation_rsp (UINT16 navi_id, BT_HDR *p_pkt) -{ - UINT8 *p_data; - - if (!AVRC_IS_VALID_GROUP(navi_id)) - { - AVRC_TRACE_ERROR1("avrc_bld_group_navigation_rsp bad navigation op id: %d", navi_id); - return AVRC_STS_BAD_PARAM; - } - - AVRC_TRACE_API0("avrc_bld_group_navigation_rsp"); - p_data = (UINT8 *)(p_pkt+1) + p_pkt->offset; - UINT16_TO_BE_STREAM(p_data, navi_id); - p_pkt->len = 2; - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_rejected_rsp -** -** Description This function builds the General Response response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_rejected_rsp( tAVRC_RSP *p_rsp, BT_HDR *p_pkt ) -{ - UINT8 *p_data, *p_start; -#if (AVCT_BROWSE_INCLUDED == TRUE) - UINT8 opcode = avrc_opcode_from_pdu(p_rsp->pdu); -#endif - - AVRC_TRACE_API2("avrc_bld_rejected_rsp: status=%d, pdu:x%x", p_rsp->status, p_rsp->pdu); - - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; -#if (AVCT_BROWSE_INCLUDED == TRUE) - if (opcode == AVRC_OP_BROWSE) - { - p_data = p_start + 1; - if (avrc_opcode_from_pdu(*p_start) != AVRC_OP_BROWSE) - { - /* if the given opcode is not recognized as a browsing command opcode, use general reject command */ - *p_start = AVRC_PDU_GENERAL_REJECT; - } - } - else -#endif - { - p_data = p_start + 2; - } - AVRC_TRACE_DEBUG1("pdu:x%x", *p_start); - - UINT16_TO_BE_STREAM(p_data, 1); - UINT8_TO_BE_STREAM(p_data, p_rsp->status); - p_pkt->len = p_data - p_start; - - return AVRC_STS_NO_ERROR; -} - - -/***************************************************************************** -** the following commands are introduced in AVRCP 1.4 -*****************************************************************************/ - -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) -/******************************************************************************* -** -** Function avrc_bld_ctrl_status_rsp -** -** Description This function builds the responses with a UINT8 parameter. -** -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_ctrl_status_rsp (tAVRC_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 2; /* pdu + rsvd */ - - /* add fixed lenth - status(1) */ - UINT16_TO_BE_STREAM(p_data, 1); - UINT8_TO_BE_STREAM(p_data, p_rsp->status); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} - -/******************************************************************************* -** -** Function avrc_bld_set_addr_player_rsp -** -** Description This function builds the Set Addresses Player response. -** -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_set_addr_player_rsp (tAVRC_RSP *p_rsp, BT_HDR *p_pkt) -{ - AVRC_TRACE_API0("avrc_bld_set_addr_player_rsp"); - return avrc_bld_ctrl_status_rsp(p_rsp, p_pkt); -} - -/******************************************************************************* -** -** Function avrc_bld_set_abs_volume_rsp -** -** Description This function builds the Set Absolute Volume response. -** -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_set_abs_volume_rsp (tAVRC_SET_VOLUME_RSP *p_rsp, BT_HDR *p_pkt) -{ - p_rsp->status = (p_rsp->volume & AVRC_MAX_VOLUME); - AVRC_TRACE_API2("avrc_bld_set_abs_volume_rsp volume:%d, sts:%d", p_rsp->volume, p_rsp->status); - return avrc_bld_ctrl_status_rsp((tAVRC_RSP *)p_rsp, p_pkt); -} - - -/******************************************************************************* -** -** Function avrc_bld_set_browsed_player_rsp -** -** Description This function builds the Set Browsed Player response. -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_set_browsed_player_rsp (tAVRC_SET_BR_PLAYER_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len, xx; - UINT16 len; - tAVRC_NAME *p_folders = p_rsp->p_folders; - UINT16 len_left; - UINT8 *p_num; - UINT16 mtu; - - AVRC_TRACE_API0("avrc_bld_set_browsed_player_rsp"); - /* make sure the given GKI buffer can accomodate this response */ - len_left = GKI_get_buf_size(p_pkt) - BT_HDR_SIZE; - p_data = (UINT8 *)(p_pkt + 1); - BE_STREAM_TO_UINT16 (mtu, p_data); - if (len_left > mtu) - { - len_left = mtu; - } - len_left = len_left - p_pkt->offset - p_pkt->len; - AVRC_TRACE_DEBUG2("len_left:%d, mtu:%d ", len_left, mtu); - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 1; /* pdu */ - - /* the existing len */ - BE_STREAM_TO_UINT16(len, p_data); - p_num = p_data + 9; - if (len == 0) - { - /* first time initialize the attribute count */ - UINT8_TO_BE_STREAM(p_data, p_rsp->status); - UINT16_TO_BE_STREAM(p_data, p_rsp->uid_counter); - UINT32_TO_BE_STREAM(p_data, p_rsp->num_items); - UINT16_TO_BE_STREAM(p_data, p_rsp->charset_id); - *p_num = 0; - p_data++; - len = 10; - len_left -= 12; /* assuming that we would never use a GKI buffer that is too small for headers */ - } - else - { - p_data = p_start + p_pkt->len; - } - - for (xx=0; (xx<p_rsp->folder_depth) && (len_left>(p_folders[xx].str_len + 2)); xx++) - { - (*p_num)++; - UINT16_TO_BE_STREAM(p_data, p_folders[xx].str_len); - ARRAY_TO_BE_STREAM(p_data, p_folders[xx].p_str, p_folders[xx].str_len); - len += (p_folders[xx].str_len + 2); - } - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} -#endif - - -/******************************************************************************* -** -** Function avrc_bld_get_folder_items_rsp -** -** Description This function builds the Get Folder Items response. -** The error code is returned in *p_status. -** AVRC_STS_INTERNAL_ERR means no GKI buffers. -** Try again later or with smaller item_count -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** AVRC_STS_INTERNAL_ERR, if the given GKI buffer does not have enough room -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_get_folder_items_rsp (tAVRC_GET_ITEMS_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len, xx; - UINT16 len; - UINT16 item_len; - UINT8 *p_item_len, yy; - tAVRC_ITEM_PLAYER *p_player; - tAVRC_ITEM_FOLDER *p_folder; - tAVRC_ITEM_MEDIA *p_media; - tAVRC_ATTR_ENTRY *p_attr; - tAVRC_ITEM *p_item_list = p_rsp->p_item_list; - tAVRC_STS status = AVRC_STS_NO_ERROR; - UINT16 len_left; - UINT8 *p_num, *p; - UINT8 *p_item_start, *p_attr_count; - UINT16 item_count; - UINT16 mtu; - - AVRC_TRACE_API0("avrc_bld_get_folder_items_rsp"); - /* make sure the given GKI buffer can accomodate this response */ - len_left = GKI_get_buf_size(p_pkt) - BT_HDR_SIZE; - p = (UINT8 *)(p_pkt + 1); - BE_STREAM_TO_UINT16 (mtu, p); - if (len_left > mtu) - len_left = mtu; - len_left = len_left - p_pkt->offset - p_pkt->len; - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 1; /* pdu */ - - /* the existing len */ - BE_STREAM_TO_UINT16(len, p_data); - p_num = p_data + 3; - if (len == 0) - { - /* first time initialize the attribute count */ - UINT8_TO_BE_STREAM(p_data, p_rsp->status); - UINT16_TO_BE_STREAM(p_data, p_rsp->uid_counter); - item_count = 0; - p_data+= 2; - len = 5; - len_left -= 5; - } - else - { - p_data = p_start + p_pkt->len; - p = p_num; - BE_STREAM_TO_UINT16 (item_count, p); - } - AVRC_TRACE_DEBUG3("len:%d, len_left:%d, num:%d", len, len_left, item_count); - - /* min len required = item_type(1) + item len(2) + min item (14) = 17 */ - for (xx=0; xx<p_rsp->item_count && len_left > 17; xx++) - { - p_item_start = p_data; - UINT8_TO_BE_STREAM(p_data, p_item_list[xx].item_type); - /* variable item lenth - save the location to add length */ - p_item_len = p_data; - p_data += 2; - item_len = 0; - len_left -= 3; /* item_type(1) + item len(2) */ - switch (p_item_list[xx].item_type) - { - case AVRC_ITEM_PLAYER: - /* min len required: 2 + 1 + 4 + 1 + 16 + 2 + 2 = 30 + str_len */ - p_player = &p_item_list[xx].u.player; - item_len = AVRC_FEATURE_MASK_SIZE + p_player->name.str_len + 12; - if ((len_left > item_len) && - p_player->name.p_str && - (p_player->major_type & AVRC_MJ_TYPE_INVALID) == 0 && - (p_player->sub_type & AVRC_SUB_TYPE_INVALID) == 0 && - (p_player->play_status <= AVRC_PLAYSTATE_REV_SEEK || p_player->play_status == AVRC_PLAYSTATE_ERROR) ) - { - UINT16_TO_BE_STREAM(p_data, p_player->player_id); - UINT8_TO_BE_STREAM(p_data, p_player->major_type); - UINT32_TO_BE_STREAM(p_data, p_player->sub_type); - UINT8_TO_BE_STREAM(p_data, p_player->play_status); - ARRAY_TO_BE_STREAM(p_data, p_player->features, AVRC_FEATURE_MASK_SIZE); - UINT16_TO_BE_STREAM(p_data, p_player->name.charset_id); - UINT16_TO_BE_STREAM(p_data, p_player->name.str_len); - ARRAY_TO_BE_STREAM(p_data, p_player->name.p_str, p_player->name.str_len); - } - else - { - p_data = p_item_start; - } - break; - - case AVRC_ITEM_FOLDER: - /* min len required: 8 + 1 + 1 + 2 + 2 = 14 + str_len */ - p_folder = &p_item_list[xx].u.folder; - item_len = AVRC_UID_SIZE + p_folder->name.str_len + 6; - if ((len_left > item_len) && - p_folder->name.p_str && - p_folder->type <= AVRC_FOLDER_TYPE_YEARS && - p_folder->playable <= TRUE) - { - ARRAY_TO_BE_STREAM(p_data, p_folder->uid, AVRC_UID_SIZE); - UINT8_TO_BE_STREAM(p_data, p_folder->type); - UINT8_TO_BE_STREAM(p_data, p_folder->playable); - UINT16_TO_BE_STREAM(p_data, p_folder->name.charset_id); - UINT16_TO_BE_STREAM(p_data, p_folder->name.str_len); - ARRAY_TO_BE_STREAM(p_data, p_folder->name.p_str, p_folder->name.str_len); - } - else - { - p_data = p_item_start; - } - break; - - case AVRC_ITEM_MEDIA: - /* min len required: 8 + 1 + 2 + 2 + 1 = 14 + str_len */ - p_media = &p_item_list[xx].u.media; - item_len = AVRC_UID_SIZE + p_media->name.str_len + 6; - if ((len_left > item_len) && - p_media->name.p_str && - p_media->type <= AVRC_MEDIA_TYPE_VIDEO) - { - ARRAY_TO_BE_STREAM(p_data, p_media->uid, AVRC_UID_SIZE); - UINT8_TO_BE_STREAM(p_data, p_media->type); - UINT16_TO_BE_STREAM(p_data, p_media->name.charset_id); - UINT16_TO_BE_STREAM(p_data, p_media->name.str_len); - ARRAY_TO_BE_STREAM(p_data, p_media->name.p_str, p_media->name.str_len); - p_attr_count = p_data++; - *p_attr_count = 0; - len_left -= item_len; - if (p_media->attr_count>0) - { - p_attr = p_media->p_attr_list; - for (yy=0; yy<p_media->attr_count && len_left > 8; yy++) - { - if (p_attr[yy].name.p_str && - AVRC_IS_VALID_MEDIA_ATTRIBUTE(p_attr[yy].attr_id) && - (len_left >= (p_attr[yy].name.str_len + 8)) ) - { - (*p_attr_count) ++; - UINT32_TO_BE_STREAM(p_data, p_attr[yy].attr_id); - UINT16_TO_BE_STREAM(p_data, p_attr[yy].name.charset_id); - UINT16_TO_BE_STREAM(p_data, p_attr[yy].name.str_len); - ARRAY_TO_BE_STREAM(p_data, p_attr[yy].name.p_str, p_attr[yy].name.str_len); - item_len += (p_attr[yy].name.str_len + 8); - len_left -= (p_attr[yy].name.str_len + 8); - } - } - } - } - else - { - p_data = p_item_start; - } - break; - } /* switch item_type */ - - if (p_item_start != p_data) - { - /* successfully added the item */ - item_count++; - /* fill in variable item lenth */ - UINT16_TO_BE_STREAM(p_item_len, item_len); - } - else - { - /* some item is not added properly - set an error status */ - if (len_left > item_len) - status = AVRC_STS_INTERNAL_ERR; - else - status = AVRC_STS_BAD_PARAM; - } - - len += item_len; - len += 3; /* the item_type(1) and item_len(2) */ - AVRC_TRACE_DEBUG4("len:%d, len_left:%d, num:%d, item_len:%d", len, len_left, item_count, item_len); - } /* for item_count */ - - UINT16_TO_BE_STREAM(p_num, item_count); - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - - if (p_rsp->item_count != xx) - { - p_rsp->item_count = xx; - if (status == AVRC_STS_NO_ERROR) - status = AVRC_STS_INTERNAL_ERR; - } - - return status; -} -#endif - - -/******************************************************************************* -** -** Function avrc_bld_change_path_rsp -** -** Description This function builds the Change Path response. -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_change_path_rsp (tAVRC_CHG_PATH_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_start + 1; /* pdu */ - /* add fixed lenth - status(1) + num_items(4) */ - UINT16_TO_BE_STREAM(p_data, 5); - UINT8_TO_BE_STREAM(p_data, p_rsp->status); - UINT32_TO_BE_STREAM(p_data, p_rsp->num_items); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} -#endif - - -/******************************************************************************* -** -** Function avrc_bld_get_item_attrs_rsp -** -** Description This function builds the Get Item Attributes response. -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** AVRC_STS_INTERNAL_ERR, if the given GKI buffer does not have enough room -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_get_item_attrs_rsp (tAVRC_GET_ATTRS_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start; - UINT8 *p_len, xx; - UINT16 len, len_left; - UINT8 *p_num; - UINT16 mtu; - - AVRC_TRACE_API0("avrc_bld_get_item_attrs_rsp"); - /* calculate the GKI buffer size needed and validate the parameters */ - if (!p_rsp->p_attr_list) - { - AVRC_TRACE_ERROR0("NULL p_attr_list"); - return AVRC_STS_BAD_PARAM; - } - - /* check the length before adding the attr to the message */ - len = 2; - for (xx=0; xx<p_rsp->attr_count; xx++) - { - if(p_rsp->p_attr_list[xx].name.p_str == 0 || - !AVRC_IS_VALID_MEDIA_ATTRIBUTE(p_rsp->p_attr_list[xx].attr_id)) - { - AVRC_TRACE_ERROR2("[%d] NULL p_attr_list str or bad attr_id:%d", xx, p_rsp->p_attr_list[xx].attr_id); - return AVRC_STS_BAD_PARAM; - } - len += (p_rsp->p_attr_list[xx].name.str_len + 8); - } - len_left = GKI_get_buf_size(p_pkt) - BT_HDR_SIZE; - p_data = (UINT8 *)(p_pkt + 1); - BE_STREAM_TO_UINT16 (mtu, p_data); - if (len_left > mtu) - { - len_left = mtu; - } - len_left = len_left - p_pkt->offset - p_pkt->len; - - AVRC_TRACE_DEBUG3("len_left:%d, mtu:%d len needed:%d", len_left, mtu, len); - if (len_left < 11) /* 11 is 4/attr_id + 2/charset_id + 2/str_len + 3/first timer/attr count & len */ - { - return AVRC_STS_INTERNAL_ERR; - } - if (len > len_left) - { - AVRC_TRACE_ERROR0("The GKI buffer does not have enough room to hold the given data."); - } - - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 1; /* pdu */ - - /* the existing len */ - BE_STREAM_TO_UINT16(len, p_data); - p_num = p_data + 1; - if (len == 0) - { - /* first time initialize the attribute count */ - UINT8_TO_BE_STREAM(p_data, p_rsp->status); - *p_num = 0; - p_data++; - len = 2; - len_left -= 3; - } - else - { - p_data = p_start + p_pkt->len; - } - - - for (xx=0; (xx<p_rsp->attr_count) && (len_left>9); xx++) - { - (*p_num)++; - UINT32_TO_BE_STREAM(p_data, p_rsp->p_attr_list[xx].attr_id); - UINT16_TO_BE_STREAM(p_data, p_rsp->p_attr_list[xx].name.charset_id); - UINT16_TO_BE_STREAM(p_data, p_rsp->p_attr_list[xx].name.str_len); - len_left -= 8; - if (p_rsp->p_attr_list[xx].name.str_len > len_left) - p_rsp->p_attr_list[xx].name.str_len = len_left; - ARRAY_TO_BE_STREAM(p_data, p_rsp->p_attr_list[xx].name.p_str, p_rsp->p_attr_list[xx].name.str_len); - len_left -= p_rsp->p_attr_list[xx].name.str_len; - len += (p_rsp->p_attr_list[xx].name.str_len + 8); - } - - UINT16_TO_BE_STREAM(p_len, len); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} -#endif - - -/******************************************************************************* -** -** Function avrc_bld_search_rsp -** -** Description This function builds the Search response. -** -** This message goes through the Browsing channel and is -** valid only when AVCT_BROWSE_INCLUDED compile option is TRUE -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -#if (AVCT_BROWSE_INCLUDED == TRUE) -static tAVRC_STS avrc_bld_search_rsp (tAVRC_SEARCH_RSP *p_rsp, BT_HDR *p_pkt) -{ - UINT8 *p_data, *p_start, *p_len; - - AVRC_TRACE_API0("avrc_bld_search_rsp"); - /* get the existing length, if any, and also the num attributes */ - p_start = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_data = p_len = p_start + 1; /* pdu */ - - /* add fixed lenth - status(1) + uid_counter(2) + num_items(4) */ - UINT16_TO_BE_STREAM(p_data, 7); - UINT8_TO_BE_STREAM(p_data, p_rsp->status); - UINT16_TO_BE_STREAM(p_data, p_rsp->uid_counter); - UINT32_TO_BE_STREAM(p_data, p_rsp->num_items); - p_pkt->len = (p_data - p_start); - return AVRC_STS_NO_ERROR; -} -#endif - - -/******************************************************************************* -** -** Function avrc_bld_play_item_rsp -** -** Description This function builds the Play Item response. -** -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_play_item_rsp (tAVRC_RSP *p_rsp, BT_HDR *p_pkt) -{ - AVRC_TRACE_API0("avrc_bld_play_item_rsp"); - return avrc_bld_ctrl_status_rsp(p_rsp, p_pkt); -} - - -/******************************************************************************* -** -** Function avrc_bld_add_to_now_playing_rsp -** -** Description This function builds the Add to Now Playing response. -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -static tAVRC_STS avrc_bld_add_to_now_playing_rsp (tAVRC_RSP *p_rsp, BT_HDR *p_pkt) -{ - AVRC_TRACE_API0("avrc_bld_add_to_now_playing_rsp"); - return avrc_bld_ctrl_status_rsp(p_rsp, p_pkt); -} - -#endif /* AVRC_ADV_CTRL_INCLUDED=TRUE */ - -/******************************************************************************* -** -** Function avrc_bld_init_rsp_buffer -** -** Description This function initializes the response buffer based on PDU -** -** Returns NULL, if no GKI buffer or failure to build the message. -** Otherwise, the GKI buffer that contains the initialized message. -** -*******************************************************************************/ -static BT_HDR *avrc_bld_init_rsp_buffer(tAVRC_RESPONSE *p_rsp) -{ - UINT16 offset, chnl = AVCT_DATA_CTRL, len=AVRC_META_CMD_POOL_SIZE; - BT_HDR *p_pkt=NULL; - UINT8 opcode = avrc_opcode_from_pdu(p_rsp->pdu); - - AVRC_TRACE_API3("avrc_bld_init_rsp_buffer: pdu=%x, opcode=%x/%x", p_rsp->pdu, opcode, p_rsp->rsp.opcode); - if (opcode != p_rsp->rsp.opcode && p_rsp->rsp.status != AVRC_STS_NO_ERROR && avrc_is_valid_opcode(p_rsp->rsp.opcode)) - { - opcode = p_rsp->rsp.opcode; - AVRC_TRACE_API1("opcode=%x", opcode); - } - - switch (opcode) - { -#if (AVCT_BROWSE_INCLUDED == TRUE) - case AVRC_OP_BROWSE: - chnl = AVCT_DATA_BROWSE; - offset = AVCT_BROWSE_OFFSET; - len = AVRC_BROWSE_POOL_SIZE; - break; -#endif /* AVCT_BROWSE_INCLUDED */ - - case AVRC_OP_PASS_THRU: - offset = AVRC_MSG_PASS_THRU_OFFSET; - break; - - case AVRC_OP_VENDOR: - offset = AVRC_MSG_VENDOR_OFFSET; - if (p_rsp->pdu == AVRC_PDU_GET_ELEMENT_ATTR) - len = AVRC_BROWSE_POOL_SIZE; - break; - } - - /* allocate and initialize the buffer */ - p_pkt = (BT_HDR *)GKI_getbuf(len); - if (p_pkt) - { - UINT8 *p_data, *p_start; - - p_pkt->layer_specific = chnl; - p_pkt->event = opcode; - p_pkt->offset = offset; - p_data = (UINT8 *)(p_pkt + 1) + p_pkt->offset; - p_start = p_data; - - /* pass thru - group navigation - has a two byte op_id, so dont do it here */ - if (opcode != AVRC_OP_PASS_THRU) - *p_data++ = p_rsp->pdu; - - switch (opcode) - { - case AVRC_OP_VENDOR: - /* reserved 0, packet_type 0 */ - UINT8_TO_BE_STREAM(p_data, 0); - /* continue to the next "case to add length */ -#if (AVCT_BROWSE_INCLUDED == TRUE) - case AVRC_OP_BROWSE: -#endif - /* add fixed lenth - 0 */ - UINT16_TO_BE_STREAM(p_data, 0); - break; - } - - p_pkt->len = (p_data - p_start); - } - p_rsp->rsp.opcode = opcode; - return p_pkt; -} - -/******************************************************************************* -** -** Function AVRC_BldResponse -** -** Description This function builds the given AVRCP response to the given -** GKI buffer -** -** Returns AVRC_STS_NO_ERROR, if the response is built successfully -** Otherwise, the error code. -** -*******************************************************************************/ -tAVRC_STS AVRC_BldResponse( UINT8 handle, tAVRC_RESPONSE *p_rsp, BT_HDR **pp_pkt) -{ - tAVRC_STS status = AVRC_STS_BAD_PARAM; - BT_HDR *p_pkt; - BOOLEAN alloc = FALSE; -#if ((AVRC_ADV_CTRL_INCLUDED == TRUE) && (AVCT_BROWSE_INCLUDED == TRUE)) - UINT8 *p; - UINT16 peer_mtu; -#endif - - if (!p_rsp || !pp_pkt) - { - AVRC_TRACE_API2("AVRC_BldResponse. Invalid parameters passed. p_rsp=%p, pp_pkt=%p", p_rsp, pp_pkt); - return AVRC_STS_BAD_PARAM; - } - - if (*pp_pkt == NULL) - { - if ((*pp_pkt = avrc_bld_init_rsp_buffer(p_rsp)) == NULL) - { - AVRC_TRACE_API0("AVRC_BldResponse: Failed to initialize response buffer"); - return AVRC_STS_INTERNAL_ERR; - } -#if ((AVRC_ADV_CTRL_INCLUDED == TRUE) && (AVCT_BROWSE_INCLUDED == TRUE)) - if ((*pp_pkt)->layer_specific == AVCT_DATA_BROWSE) - { - p = (UINT8 *)((*pp_pkt) + 1); - peer_mtu = AVCT_GetBrowseMtu(handle) - AVCT_HDR_LEN_SINGLE; - UINT16_TO_BE_STREAM(p, peer_mtu); - } -#endif - alloc = TRUE; - } - status = AVRC_STS_NO_ERROR; - p_pkt = *pp_pkt; - - AVRC_TRACE_API2("AVRC_BldResponse: pdu=%x status=%x", p_rsp->rsp.pdu, p_rsp->rsp.status); - if (p_rsp->rsp.status != AVRC_STS_NO_ERROR) - { - return( avrc_bld_rejected_rsp(&p_rsp->rsp, p_pkt) ); - } - - switch (p_rsp->pdu) - { - case AVRC_PDU_NEXT_GROUP: - case AVRC_PDU_PREV_GROUP: - status = avrc_bld_group_navigation_rsp(p_rsp->pdu, p_pkt); - break; - - case AVRC_PDU_GET_CAPABILITIES: - status = avrc_bld_get_capability_rsp(&p_rsp->get_caps, p_pkt); - break; - - case AVRC_PDU_LIST_PLAYER_APP_ATTR: - status = avrc_bld_list_app_settings_attr_rsp(&p_rsp->list_app_attr, p_pkt); - break; - - case AVRC_PDU_LIST_PLAYER_APP_VALUES: - status = avrc_bld_list_app_settings_values_rsp(&p_rsp->list_app_values, p_pkt); - break; - - case AVRC_PDU_GET_CUR_PLAYER_APP_VALUE: - status = avrc_bld_get_cur_app_setting_value_rsp(&p_rsp->get_cur_app_val, p_pkt); - break; - - case AVRC_PDU_SET_PLAYER_APP_VALUE: - status = avrc_bld_set_app_setting_value_rsp(&p_rsp->set_app_val, p_pkt); - break; - - case AVRC_PDU_GET_PLAYER_APP_ATTR_TEXT: - status = avrc_bld_get_app_setting_attr_text_rsp(&p_rsp->get_app_attr_txt, p_pkt); - break; - - case AVRC_PDU_GET_PLAYER_APP_VALUE_TEXT: - status = avrc_bld_get_app_setting_value_text_rsp(&p_rsp->get_app_val_txt, p_pkt); - break; - - case AVRC_PDU_INFORM_DISPLAY_CHARSET: - status = avrc_bld_inform_charset_rsp(&p_rsp->inform_charset, p_pkt); - break; - - case AVRC_PDU_INFORM_BATTERY_STAT_OF_CT: - status = avrc_bld_inform_battery_status_rsp(&p_rsp->inform_battery_status, p_pkt); - break; - - case AVRC_PDU_GET_ELEMENT_ATTR: - status = avrc_bld_get_elem_attrs_rsp(&p_rsp->get_elem_attrs, p_pkt); - break; - - case AVRC_PDU_GET_PLAY_STATUS: - status = avrc_bld_get_play_status_rsp(&p_rsp->get_play_status, p_pkt); - break; - - case AVRC_PDU_REGISTER_NOTIFICATION: - status = avrc_bld_notify_rsp(&p_rsp->reg_notif, p_pkt); - break; - - case AVRC_PDU_REQUEST_CONTINUATION_RSP: /* 0x40 */ - status = avrc_bld_next_rsp(&p_rsp->continu, p_pkt); - break; - - case AVRC_PDU_ABORT_CONTINUATION_RSP: /* 0x41 */ - status = avrc_bld_next_rsp(&p_rsp->abort, p_pkt); - break; - -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) - case AVRC_PDU_SET_ABSOLUTE_VOLUME: /* 0x50 */ - status = avrc_bld_set_abs_volume_rsp(&p_rsp->volume, p_pkt); - break; - - case AVRC_PDU_SET_ADDRESSED_PLAYER: /* 0x60 */ - status = avrc_bld_set_addr_player_rsp(&p_rsp->addr_player, p_pkt); - break; - - case AVRC_PDU_PLAY_ITEM: /* 0x74 */ - status = avrc_bld_play_item_rsp(&p_rsp->play_item, p_pkt); - break; - - case AVRC_PDU_ADD_TO_NOW_PLAYING: /* 0x90 */ - status = avrc_bld_add_to_now_playing_rsp(&p_rsp->add_to_play, p_pkt); - break; - -#if (AVCT_BROWSE_INCLUDED == TRUE) - case AVRC_PDU_SET_BROWSED_PLAYER: /* 0x70 */ - status = avrc_bld_set_browsed_player_rsp(&p_rsp->br_player, p_pkt); - break; - - case AVRC_PDU_GET_FOLDER_ITEMS: /* 0x71 */ - status = avrc_bld_get_folder_items_rsp(&p_rsp->get_items, p_pkt); - break; - - case AVRC_PDU_CHANGE_PATH: /* 0x72 */ - status = avrc_bld_change_path_rsp(&p_rsp->chg_path, p_pkt); - break; - - case AVRC_PDU_GET_ITEM_ATTRIBUTES: /* 0x73 */ - status = avrc_bld_get_item_attrs_rsp(&p_rsp->get_attrs, p_pkt); - break; - - case AVRC_PDU_SEARCH: /* 0x80 */ - status = avrc_bld_search_rsp(&p_rsp->search, p_pkt); - break; -#endif -#endif - } - - if (alloc && (status != AVRC_STS_NO_ERROR) ) - { - GKI_freebuf(p_pkt); - *pp_pkt = NULL; - } - AVRC_TRACE_API1("AVRC_BldResponse: returning %d", status); - return status; -} - -#endif /* (AVRC_METADATA_INCLUDED == TRUE)*/ - diff --git a/stack/avrc/avrc_int.h b/stack/avrc/avrc_int.h index 33e561c..a2a4073 100644 --- a/stack/avrc/avrc_int.h +++ b/stack/avrc/avrc_int.h @@ -83,31 +83,10 @@ ** Type definitions *****************************************************************************/ -#if (AVRC_METADATA_INCLUDED == TRUE) -/* type for Metadata fragmentation control block */ -typedef struct -{ - BT_HDR *p_fmsg; /* the fragmented message */ - UINT8 frag_pdu; /* the PDU ID for fragmentation */ - BOOLEAN frag_enabled; /* fragmentation flag */ -} tAVRC_FRAG_CB; - -/* type for Metadata re-assembly control block */ -typedef struct -{ - BT_HDR *p_rmsg; /* the received message */ - UINT16 rasm_offset; /* re-assembly flag, the offset of the start fragment */ - UINT8 rasm_pdu; /* the PDU ID for re-assembly */ -} tAVRC_RASM_CB; -#endif typedef struct { tAVRC_CONN_CB ccb[AVCT_NUM_CONN]; -#if (AVRC_METADATA_INCLUDED == TRUE) - tAVRC_FRAG_CB fcb[AVCT_NUM_CONN]; - tAVRC_RASM_CB rcb[AVCT_NUM_CONN]; -#endif tAVRC_FIND_CBACK *p_cback; /* pointer to application callback */ tSDP_DISCOVERY_DB *p_db; /* pointer to discovery database */ UINT16 service_uuid; /* service UUID to search */ diff --git a/stack/avrc/avrc_opt.c b/stack/avrc/avrc_opt.c index 7711655..8902ac9 100644 --- a/stack/avrc/avrc_opt.c +++ b/stack/avrc/avrc_opt.c @@ -40,13 +40,8 @@ static BT_HDR * avrc_vendor_msg(tAVRC_MSG_VENDOR *p_msg) WC_ASSERT(p_msg != NULL); -#if AVRC_METADATA_INCLUDED == TRUE - WC_ASSERT(AVRC_META_CMD_POOL_SIZE > (AVRC_MIN_CMD_LEN+p_msg->vendor_len)); - if ((p_cmd = (BT_HDR *) GKI_getpoolbuf(AVRC_META_CMD_POOL_ID)) != NULL) -#else WC_ASSERT(AVRC_CMD_POOL_SIZE > (AVRC_MIN_CMD_LEN+p_msg->vendor_len)); if ((p_cmd = (BT_HDR *) GKI_getpoolbuf(AVRC_CMD_POOL_ID)) != NULL) -#endif { p_cmd->offset = AVCT_MSG_OFFSET; p_data = (UINT8 *)(p_cmd + 1) + p_cmd->offset; diff --git a/stack/avrc/avrc_pars_ct.c b/stack/avrc/avrc_pars_ct.c deleted file mode 100644 index 4feb256..0000000 --- a/stack/avrc/avrc_pars_ct.c +++ /dev/null @@ -1,663 +0,0 @@ -/***************************************************************************** -** -** Name: avrc_pars_ct.c -** -** Description:Interface to AVRCP parse message functions for the Control Role -** -** Copyright (c) 2008-2008, Broadcom Corp., All Rights Reserved. -** Broadcom Bluetooth Core. Proprietary and confidential. -** -*****************************************************************************/ -#include <string.h> - -#include "gki.h" -#include "avrc_api.h" -#include "avrc_defs.h" -#include "avrc_int.h" - -/***************************************************************************** -** Global data -*****************************************************************************/ - -#if (AVRC_METADATA_INCLUDED == TRUE) - -/******************************************************************************* -** -** Function avrc_pars_vendor_rsp -** -** Description This function parses the vendor specific commands defined by -** Bluetooth SIG -** -** Returns AVRC_STS_NO_ERROR, if the message in p_data is parsed successfully. -** Otherwise, the error code defined by AVRCP 1.4 -** -*******************************************************************************/ -static tAVRC_STS avrc_pars_vendor_rsp(tAVRC_MSG_VENDOR *p_msg, tAVRC_RESPONSE *p_result, UINT8 *p_buf, UINT16 buf_len) -{ - tAVRC_STS status = AVRC_STS_NO_ERROR; - UINT8 *p = p_msg->p_vendor_data; - UINT16 len; - UINT8 xx, yy; - tAVRC_NOTIF_RSP_PARAM *p_param; - tAVRC_APP_SETTING *p_app_set; - tAVRC_APP_SETTING_TEXT *p_app_txt; - tAVRC_ATTR_ENTRY *p_entry; - UINT32 *p_u32; - UINT8 *p_u8; - UINT16 size_needed; - - BE_STREAM_TO_UINT8 (p_result->pdu, p); - p++; /* skip the reserved/packe_type byte */ - BE_STREAM_TO_UINT16 (len, p); - AVRC_TRACE_DEBUG4("avrc_pars_vendor_rsp() ctype:0x%x pdu:0x%x, len:%d/0x%x", p_msg->hdr.ctype, p_result->pdu, len, len); - if (p_msg->hdr.ctype == AVRC_RSP_REJ) - { - p_result->rsp.status = *p; - return p_result->rsp.status; - } - - switch (p_result->pdu) - { - case AVRC_PDU_GET_CAPABILITIES: /* 0x10 */ - p_result->get_caps.capability_id = *p++; - if (AVRC_IS_VALID_CAP_ID(p_result->get_caps.capability_id)) - { - p_result->get_caps.count = *p++; - if (p_result->get_caps.capability_id == AVRC_CAP_COMPANY_ID) - { - p_u32 = p_result->get_caps.param.company_id; - for (xx=0; xx<p_result->get_caps.count; xx++) - { - AVRC_BE_STREAM_TO_CO_ID (p_u32[xx], p); - } - } - else - { - p_u8 = p_result->get_caps.param.event_id; - for (xx=0; xx<p_result->get_caps.count; xx++) - { - BE_STREAM_TO_UINT8 (p_u8[xx], p); - } - } - } - else - status = AVRC_STS_BAD_PARAM; - break; - - case AVRC_PDU_LIST_PLAYER_APP_ATTR: /* 0x11 */ - BE_STREAM_TO_UINT8 (p_result->list_app_attr.num_attr, p); - p_u8 = p_result->list_app_attr.attrs; - for(xx=0, yy=0; xx< p_result->list_app_attr.num_attr; xx++) - { - /* only report the valid player app attributes */ - if (AVRC_IsValidPlayerAttr(*p)) - p_u8[yy++] = *p; - p++; - } - p_result->list_app_attr.num_attr = yy; - break; - - case AVRC_PDU_LIST_PLAYER_APP_VALUES: /* 0x12 */ - BE_STREAM_TO_UINT8 (p_result->list_app_values.num_val, p); - p_u8 = p_result->list_app_values.vals; - for(xx=0; xx< p_result->list_app_values.num_val; xx++) - { - p_u8[xx] = *p++; - } - break; - - case AVRC_PDU_GET_CUR_PLAYER_APP_VALUE: /* 0x13 */ - BE_STREAM_TO_UINT8 (p_result->get_cur_app_val.num_val, p); - size_needed = sizeof(tAVRC_APP_SETTING); - if (p_buf) - { - p_result->get_cur_app_val.p_vals = (tAVRC_APP_SETTING *)p_buf; - p_app_set = p_result->get_cur_app_val.p_vals; - for(xx=0; ((xx< p_result->get_cur_app_val.num_val) && (buf_len > size_needed)); xx++) - { - buf_len -= size_needed; - BE_STREAM_TO_UINT8 (p_app_set[xx].attr_id, p); - BE_STREAM_TO_UINT8 (p_app_set[xx].attr_val, p); - } - if (xx != p_result->get_cur_app_val.num_val) - { - AVRC_TRACE_ERROR2("GET_CUR_PLAYER_APP_VALUE not enough room:%d orig num_val:%d", - xx, p_result->get_cur_app_val.num_val); - p_result->get_cur_app_val.num_val = xx; - } - } - else - { - AVRC_TRACE_ERROR2("GET_CUR_PLAYER_APP_VALUE not enough room:len: %d needed for struct: %d", buf_len, size_needed); - status = AVRC_STS_INTERNAL_ERR; - } - break; - - case AVRC_PDU_SET_PLAYER_APP_VALUE: /* 0x14 */ - case AVRC_PDU_INFORM_DISPLAY_CHARSET: /* 0x17 */ - case AVRC_PDU_INFORM_BATTERY_STAT_OF_CT:/* 0x18 */ - /* no additional parameters */ - if (len != 0) - status = AVRC_STS_INTERNAL_ERR; - break; - - case AVRC_PDU_GET_PLAYER_APP_ATTR_TEXT: /* 0x15 */ - case AVRC_PDU_GET_PLAYER_APP_VALUE_TEXT:/* 0x16 */ - BE_STREAM_TO_UINT8 (p_result->get_app_attr_txt.num_attr, p); - size_needed = sizeof(tAVRC_APP_SETTING_TEXT) * p_result->get_app_attr_txt.num_attr; - if (p_buf && (buf_len > size_needed)) - { - p_result->get_app_attr_txt.p_attrs = (tAVRC_APP_SETTING_TEXT *)p_buf; - p_app_txt = p_result->get_app_attr_txt.p_attrs; - p_u8 = p_buf + size_needed; - buf_len -= size_needed; - for(xx=0; xx< p_result->get_app_attr_txt.num_attr; xx++) - { - BE_STREAM_TO_UINT8 (p_app_txt[xx].attr_id, p); - BE_STREAM_TO_UINT16 (p_app_txt[xx].charset_id, p); - BE_STREAM_TO_UINT8 (p_app_txt[xx].str_len, p); - p_app_txt[xx].p_str = p_u8; - if (buf_len > p_app_txt[xx].str_len) - { - BE_STREAM_TO_ARRAY(p, p_u8, p_app_txt[xx].str_len); - p_u8 += p_app_txt[xx].str_len; - buf_len -= p_app_txt[xx].str_len; - } - else - { - AVRC_TRACE_ERROR4("GET_CUR_PLAYER_APP_VALUE not enough room:[%d] len orig/left: %d/%d, orig num_attr:%d", - xx, p_app_txt[xx].str_len, buf_len, p_result->get_app_attr_txt.num_attr); - p_app_txt[xx].str_len = (UINT8)buf_len; - BE_STREAM_TO_ARRAY(p, p_u8, p_app_txt[xx].str_len); - p_result->get_app_attr_txt.num_attr = xx+1; - status = AVRC_STS_INTERNAL_ERR; - break; - } - } - } - else - { - AVRC_TRACE_ERROR2("GET_CUR_PLAYER_APP_VALUE not enough room:len: %d needed for struct: %d", buf_len, size_needed); - status = AVRC_STS_INTERNAL_ERR; - } - break; - - case AVRC_PDU_GET_ELEMENT_ATTR: /* 0x20 */ - BE_STREAM_TO_UINT8 (p_result->get_elem_attrs.num_attr, p); - size_needed = sizeof(tAVRC_ATTR_ENTRY) * p_result->get_elem_attrs.num_attr; - if (p_buf && (buf_len > size_needed)) - { - p_result->get_elem_attrs.p_attrs = (tAVRC_ATTR_ENTRY *)p_buf; - p_entry = p_result->get_elem_attrs.p_attrs; - p_u8 = p_buf + size_needed; - buf_len -= size_needed; - for(xx=0; xx< p_result->get_elem_attrs.num_attr; xx++) - { - BE_STREAM_TO_UINT32 (p_entry[xx].attr_id, p); - BE_STREAM_TO_UINT16 (p_entry[xx].name.charset_id, p); - BE_STREAM_TO_UINT16 (p_entry[xx].name.str_len, p); - p_entry[xx].name.p_str = p_u8; - if (buf_len > p_entry[xx].name.str_len) - { - BE_STREAM_TO_ARRAY(p, p_u8, p_entry[xx].name.str_len); - p_u8 += p_entry[xx].name.str_len; - buf_len -= p_entry[xx].name.str_len; - } - else - { - AVRC_TRACE_ERROR4("GET_ELEMENT_ATTR not enough room:[%d] len orig/left: %d/%d, orig num_attr:%d", - xx, p_entry[xx].name.str_len, buf_len, p_result->get_elem_attrs.num_attr); - p_entry[xx].name.str_len = buf_len; - BE_STREAM_TO_ARRAY(p, p_u8, p_entry[xx].name.str_len); - p_result->get_elem_attrs.num_attr = xx + 1; - status = AVRC_STS_INTERNAL_ERR; - break; - } - } - } - else - { - AVRC_TRACE_ERROR2("GET_ELEMENT_ATTR not enough room:len: %d needed for struct: %d", buf_len, size_needed); - status = AVRC_STS_INTERNAL_ERR; - } - break; - - case AVRC_PDU_GET_PLAY_STATUS: /* 0x30 */ - BE_STREAM_TO_UINT32 (p_result->get_play_status.song_len, p); - BE_STREAM_TO_UINT32 (p_result->get_play_status.song_pos, p); - BE_STREAM_TO_UINT8 (p_result->get_play_status.play_status, p); - if (len != 9) - status = AVRC_STS_INTERNAL_ERR; - break; - - case AVRC_PDU_REGISTER_NOTIFICATION: /* 0x31 */ - BE_STREAM_TO_UINT8 (p_result->reg_notif.event_id, p); - p_param = &p_result->reg_notif.param; - switch (p_result->reg_notif.event_id) - { - case AVRC_EVT_PLAY_STATUS_CHANGE: /* 0x01 */ - BE_STREAM_TO_UINT8 (p_param->play_status, p); - if ((p_param->play_status > AVRC_PLAYSTATE_REV_SEEK) && - (p_param->play_status != AVRC_PLAYSTATE_ERROR) ) - { - status = AVRC_STS_BAD_PARAM; - } - break; - - case AVRC_EVT_TRACK_CHANGE: /* 0x02 */ - BE_STREAM_TO_ARRAY (p, p_param->track, AVRC_UID_SIZE); - break; - - case AVRC_EVT_TRACK_REACHED_END: /* 0x03 */ - case AVRC_EVT_TRACK_REACHED_START: /* 0x04 */ -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) - case AVRC_EVT_NOW_PLAYING_CHANGE: /* 0x09 */ - case AVRC_EVT_AVAL_PLAYERS_CHANGE: /* 0x0a */ -#endif /* (AVRC_ADV_CTRL_INCLUDED == TRUE) */ - /* these events do not have additional parameters */ - break; - - case AVRC_EVT_PLAY_POS_CHANGED: /* 0x05 */ - BE_STREAM_TO_UINT32 (p_param->play_pos, p); - break; - - case AVRC_EVT_BATTERY_STATUS_CHANGE:/* 0x06 */ - BE_STREAM_TO_UINT8 (p_param->battery_status, p); - if (!AVRC_IS_VALID_BATTERY_STATUS(p_param->battery_status)) - { - status = AVRC_STS_BAD_PARAM; - } - break; - - case AVRC_EVT_SYSTEM_STATUS_CHANGE: /* 0x07 */ - BE_STREAM_TO_UINT8 (p_param->system_status, p); - if (!AVRC_IS_VALID_SYSTEM_STATUS(p_param->system_status)) - { - status = AVRC_STS_BAD_PARAM; - } - break; - - case AVRC_EVT_APP_SETTING_CHANGE: /* 0x08 */ - BE_STREAM_TO_UINT8 (p_param->player_setting.num_attr, p); - if (p_param->player_setting.num_attr > AVRC_MAX_APP_SETTINGS) - p_param->player_setting.num_attr = AVRC_MAX_APP_SETTINGS; - for (xx=0; xx<p_param->player_setting.num_attr; xx++) - { - BE_STREAM_TO_UINT8 (p_param->player_setting.attr_id[xx], p); - BE_STREAM_TO_UINT8 (p_param->player_setting.attr_value[xx], p); - if (!avrc_is_valid_player_attrib_value(p_param->player_setting.attr_id[xx], p_param->player_setting.attr_value[xx])) - { - status = AVRC_STS_BAD_PARAM; - break; - } - } - break; - -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) - case AVRC_EVT_ADDR_PLAYER_CHANGE: /* 0x0b */ - BE_STREAM_TO_UINT16 (p_param->addr_player.player_id, p); - BE_STREAM_TO_UINT16 (p_param->addr_player.uid_counter, p); - break; - - case AVRC_EVT_UIDS_CHANGE: /* 0x0c */ - BE_STREAM_TO_UINT16 (p_param->uid_counter, p); - break; - - case AVRC_EVT_VOLUME_CHANGE: /* 0x0d */ - BE_STREAM_TO_UINT8 (p_param->volume, p); - break; -#endif /* (AVRC_ADV_CTRL_INCLUDED == TRUE) */ - - default: - status = AVRC_STS_BAD_PARAM; - break; - } - break; - - /* case AVRC_PDU_REQUEST_CONTINUATION_RSP: 0x40 */ - /* case AVRC_PDU_ABORT_CONTINUATION_RSP: 0x41 */ - -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) - case AVRC_PDU_SET_ABSOLUTE_VOLUME: /* 0x50 */ - case AVRC_PDU_SET_ADDRESSED_PLAYER: /* 0x60 */ - case AVRC_PDU_PLAY_ITEM: /* 0x74 */ - case AVRC_PDU_ADD_TO_NOW_PLAYING: /* 0x90 */ - BE_STREAM_TO_UINT8 (p_result->volume.volume, p); - if (len != 1) - status = AVRC_STS_INTERNAL_ERR; - break; -#endif /* (AVRC_ADV_CTRL_INCLUDED == TRUE) */ - - default: - status = AVRC_STS_BAD_CMD; - break; - } - - return status; -} - -#if (AVCT_BROWSE_INCLUDED == TRUE) -/******************************************************************************* -** -** Function avrc_pars_browsing_rsp -** -** Description This function parses the commands that go through the -** browsing channel -** -** Returns AVRC_STS_NO_ERROR, if the message in p_data is parsed successfully. -** Otherwise, the error code defined by AVRCP 1.4 -** -*******************************************************************************/ -static tAVRC_STS avrc_pars_browsing_rsp(tAVRC_MSG_BROWSE *p_msg, tAVRC_RESPONSE *p_result, UINT8 *p_buf, UINT16 buf_len) -{ - tAVRC_STS status = AVRC_STS_NO_ERROR; - UINT8 *p = p_msg->p_browse_data; - UINT16 len; - int i, count; - UINT8 *p_left = p_buf; - tAVRC_ITEM *p_item; - tAVRC_ITEM_PLAYER *p_player; - tAVRC_ITEM_FOLDER *p_folder; - tAVRC_ITEM_MEDIA *p_media; - tAVRC_ATTR_ENTRY *p_attrs; - UINT16 item_len; - UINT8 xx; - UINT16 size_needed; - - p_result->pdu = *p++; - BE_STREAM_TO_UINT16 (len, p); - BE_STREAM_TO_UINT8 (status, p); - AVRC_TRACE_DEBUG4("avrc_pars_browsing_rsp() pdu:0x%x, len:%d/0x%x, status:0x%x", p_result->pdu, len, len, status); - if (status != AVRC_STS_NO_ERROR) - return status; - - switch (p_result->pdu) - { - case AVRC_PDU_SET_BROWSED_PLAYER: /* 0x70 */ - BE_STREAM_TO_UINT16 (p_result->br_player.uid_counter, p); - BE_STREAM_TO_UINT32 (p_result->br_player.num_items, p); - BE_STREAM_TO_UINT16 (p_result->br_player.charset_id, p); - BE_STREAM_TO_UINT8 (p_result->br_player.folder_depth, p); - p_result->br_player.p_folders = NULL; - if (p_result->br_player.folder_depth == 0) - return status; - - size_needed = sizeof(tAVRC_NAME) * p_result->br_player.folder_depth; - if (p_buf && (buf_len > size_needed)) - { - p_result->br_player.p_folders = (tAVRC_NAME *)p_buf; - p_left = p_buf + size_needed; - count = p_result->br_player.folder_depth; - buf_len -= size_needed; - for (i=0; i<count; i++) - { - p_result->br_player.p_folders[i].p_str = p_left; - BE_STREAM_TO_UINT16 (p_result->br_player.p_folders[i].str_len, p); - if (buf_len > p_result->br_player.p_folders[i].str_len) - { - BE_STREAM_TO_ARRAY (p, p_result->br_player.p_folders[i].p_str, p_result->br_player.p_folders[i].str_len); - p_left += p_result->br_player.p_folders[i].str_len; - buf_len -= p_result->br_player.p_folders[i].str_len; - } - else - { - AVRC_TRACE_ERROR4("SET_BROWSED_PLAYER not enough room:[%d] len orig/left: %d/%d, orig depth:%d", - i, p_result->br_player.p_folders[i].str_len, buf_len, p_result->br_player.folder_depth); - p_result->br_player.p_folders[i].str_len = buf_len; - BE_STREAM_TO_ARRAY (p, p_result->br_player.p_folders[i].p_str, p_result->br_player.p_folders[i].str_len); - p_result->br_player.folder_depth = i+1; - status = AVRC_STS_INTERNAL_ERR; - break; - } - } - } - else - { - AVRC_TRACE_ERROR2("SET_BROWSED_PLAYER not enough room:len: %d needed for struct: %d", buf_len, size_needed); - status = AVRC_STS_INTERNAL_ERR; - } - break; - - case AVRC_PDU_GET_FOLDER_ITEMS: /* 0x71 */ - BE_STREAM_TO_UINT16 (p_result->get_items.uid_counter, p); - BE_STREAM_TO_UINT16 (p_result->get_items.item_count, p); - p_result->get_items.p_item_list = NULL; - if (p_result->get_items.item_count == 0) - return status; - size_needed = sizeof(tAVRC_ITEM) * p_result->get_items.item_count; - if (p_buf && (buf_len > size_needed)) - { - p_result->get_items.p_item_list = p_item = (tAVRC_ITEM *)p_buf; - p_left = p_buf + size_needed; - count = p_result->get_items.item_count; - buf_len -= size_needed; - for (i=0; i<count; i++) - { - BE_STREAM_TO_UINT8 (p_item[i].item_type, p); - BE_STREAM_TO_UINT16 (item_len, p); - AVRC_TRACE_DEBUG3("[%d] type:%d len left:%d", i, p_item[i].item_type, buf_len); - switch(p_item[i].item_type) - { - case AVRC_ITEM_PLAYER: - p_player = &p_item[i].u.player; - BE_STREAM_TO_UINT16 (p_player->player_id, p); - BE_STREAM_TO_UINT8 (p_player->major_type, p); - BE_STREAM_TO_UINT32 (p_player->sub_type, p); - BE_STREAM_TO_UINT8 (p_player->play_status, p); - BE_STREAM_TO_ARRAY (p, p_player->features, AVRC_FEATURE_MASK_SIZE); - BE_STREAM_TO_UINT16 (p_player->name.charset_id, p); - BE_STREAM_TO_UINT16 (p_player->name.str_len, p); - p_player->name.p_str = p_left; - if (buf_len > p_player->name.str_len) - { - p_left += p_player->name.str_len; - BE_STREAM_TO_ARRAY (p, p_player->name.p_str, p_player->name.str_len); - buf_len -= p_player->name.str_len; - } - else - { - AVRC_TRACE_ERROR4("GET_FOLDER_ITEMS player not enough room:[%d] len orig/left: %d/%d, orig item count:%d", - i, p_player->name.str_len, buf_len, p_result->get_items.item_count); - p_player->name.str_len = buf_len; - BE_STREAM_TO_ARRAY (p, p_player->name.p_str, p_player->name.str_len); - p_result->get_items.item_count = i+1; - return AVRC_STS_INTERNAL_ERR; - } - break; - - case AVRC_ITEM_FOLDER: - p_folder = &p_item[i].u.folder; - BE_STREAM_TO_ARRAY (p, p_folder->uid, AVRC_UID_SIZE); - BE_STREAM_TO_UINT8 (p_folder->type, p); - BE_STREAM_TO_UINT8 (p_folder->playable, p); - BE_STREAM_TO_UINT16 (p_folder->name.charset_id, p); - BE_STREAM_TO_UINT16 (p_folder->name.str_len, p); - p_folder->name.p_str = p_left; - if (buf_len > p_folder->name.str_len) - { - p_left += p_folder->name.str_len; - BE_STREAM_TO_ARRAY (p, p_folder->name.p_str, p_folder->name.str_len); - buf_len -= p_folder->name.str_len; - } - else - { - AVRC_TRACE_ERROR4("GET_FOLDER_ITEMS folder not enough room:[%d] len orig/left: %d/%d, orig item count:%d", - i, p_folder->name.str_len, buf_len, p_result->get_items.item_count); - p_folder->name.str_len = buf_len; - BE_STREAM_TO_ARRAY (p, p_folder->name.p_str, p_folder->name.str_len); - p_result->get_items.item_count = i+1; - return AVRC_STS_INTERNAL_ERR; - } - break; - - case AVRC_ITEM_MEDIA: - p_media = &p_item[i].u.media; - BE_STREAM_TO_ARRAY (p, p_media->uid, AVRC_UID_SIZE); - BE_STREAM_TO_UINT8 (p_media->type, p); - BE_STREAM_TO_UINT16 (p_media->name.charset_id, p); - BE_STREAM_TO_UINT16 (p_media->name.str_len, p); - p_media->name.p_str = p_left; - if (buf_len < p_media->name.str_len) - { - AVRC_TRACE_ERROR4("GET_FOLDER_ITEMS media not enough room:[%d] len orig/left: %d/%d, orig item count:%d", - i, p_media->name.str_len, buf_len, p_result->get_items.item_count); - p_media->name.str_len = buf_len; - BE_STREAM_TO_ARRAY (p, p_media->name.p_str, p_media->name.str_len); - p_media->attr_count = 0; - p_media->p_attr_list = NULL; - p_result->get_items.item_count = i+1; - return AVRC_STS_INTERNAL_ERR; - } - p_left += p_media->name.str_len; - buf_len -= p_media->name.str_len; - BE_STREAM_TO_ARRAY (p, p_media->name.p_str, p_media->name.str_len); - BE_STREAM_TO_UINT8 (p_media->attr_count, p); - size_needed = sizeof(tAVRC_ATTR_ENTRY) * p_media->attr_count; - if (buf_len < size_needed) - { - AVRC_TRACE_ERROR4("GET_FOLDER_ITEMS media not enough room:[%d] attr_count orig/left: %d/%d, orig item count:%d", - i, p_media->attr_count, buf_len, p_result->get_items.item_count); - p_media->name.str_len = buf_len; - BE_STREAM_TO_ARRAY (p, p_media->name.p_str, p_media->name.str_len); - p_media->attr_count = 0; - p_media->p_attr_list = NULL; - p_result->get_items.item_count = i+1; - return AVRC_STS_INTERNAL_ERR; - } - p_media->p_attr_list = p_attrs = (tAVRC_ATTR_ENTRY *)p_left; - p_left += size_needed; - buf_len -= size_needed; - for (xx= 0; xx<p_media->attr_count; xx++) - { - BE_STREAM_TO_UINT32 (p_attrs[xx].attr_id, p); - BE_STREAM_TO_UINT16 (p_attrs[xx].name.charset_id, p); - BE_STREAM_TO_UINT16 (p_attrs[xx].name.str_len, p); - p_attrs[xx].name.p_str = p_left; - if (buf_len > p_attrs[xx].name.str_len) - { - p_left += p_attrs[xx].name.str_len; - BE_STREAM_TO_ARRAY (p, p_attrs[xx].name.p_str, p_attrs[xx].name.str_len); - buf_len -= p_attrs[xx].name.str_len; - } - else - { - AVRC_TRACE_ERROR4("GET_FOLDER_ITEMS media not enough room:[%d] attr name len orig/left: %d/%d, orig item count:%d", - i, p_attrs[xx].name.str_len, buf_len, p_result->get_items.item_count); - p_attrs[xx].name.str_len = buf_len; - BE_STREAM_TO_ARRAY (p, p_attrs[xx].name.p_str, p_attrs[xx].name.str_len); - p_media->attr_count = xx+1; - p_result->get_items.item_count = i+1; - return AVRC_STS_INTERNAL_ERR; - } - } - break; - } - } - } - break; - - case AVRC_PDU_CHANGE_PATH: /* 0x72 */ - BE_STREAM_TO_UINT32 (p_result->chg_path.num_items, p); - break; - - case AVRC_PDU_GET_ITEM_ATTRIBUTES: /* 0x73 */ - BE_STREAM_TO_UINT8 (p_result->get_attrs.attr_count, p); - p_result->get_attrs.p_attr_list = p_attrs = NULL; - if (p_result->get_attrs.attr_count == 0) - return status; - - size_needed = sizeof(tAVRC_ATTR_ENTRY) * p_result->get_attrs.attr_count; - if (p_buf && (buf_len > size_needed)) - { - p_result->get_attrs.p_attr_list = p_attrs = (tAVRC_ATTR_ENTRY *)p_left; - p_left += size_needed; - buf_len -= size_needed; - for (xx= 0; xx<p_result->get_attrs.attr_count; xx++) - { - BE_STREAM_TO_UINT32 (p_attrs[xx].attr_id, p); - BE_STREAM_TO_UINT16 (p_attrs[xx].name.charset_id, p); - BE_STREAM_TO_UINT16 (p_attrs[xx].name.str_len, p); - p_attrs[xx].name.p_str = p_left; - if (buf_len > p_attrs[xx].name.str_len) - { - p_left += p_attrs[xx].name.str_len; - BE_STREAM_TO_ARRAY (p, p_attrs[xx].name.p_str, p_attrs[xx].name.str_len); - buf_len -= p_attrs[xx].name.str_len; - } - else - { - AVRC_TRACE_ERROR4("GET_ITEM_ATTRIBUTES not enough room:[%d] len orig/left: %d/%d, orig attr_count:%d", - xx, p_attrs[xx].name.str_len, buf_len, p_result->get_attrs.attr_count); - p_attrs[xx].name.str_len = buf_len; - BE_STREAM_TO_ARRAY (p, p_attrs[xx].name.p_str, p_attrs[xx].name.str_len); - p_result->get_attrs.attr_count = xx+1; - status = AVRC_STS_INTERNAL_ERR; - break; - } - } - } - break; - - case AVRC_PDU_SEARCH: /* 0x80 */ - BE_STREAM_TO_UINT16 (p_result->search.uid_counter, p); - BE_STREAM_TO_UINT32 (p_result->search.num_items, p); - break; - - default: - status = AVRC_STS_BAD_CMD; - break; - } - - return status; -} -#endif /* (AVCT_BROWSE_INCLUDED == TRUE)*/ - -/******************************************************************************* -** -** Function AVRC_ParsResponse -** -** Description This function is a superset of AVRC_ParsMetadata to parse the response. -** -** Returns AVRC_STS_NO_ERROR, if the message in p_data is parsed successfully. -** Otherwise, the error code defined by AVRCP 1.4 -** -*******************************************************************************/ -tAVRC_STS AVRC_ParsResponse (tAVRC_MSG *p_msg, tAVRC_RESPONSE *p_result, UINT8 *p_buf, UINT16 buf_len) -{ - tAVRC_STS status = AVRC_STS_INTERNAL_ERR; - UINT16 id; - - if (p_msg && p_result) - { - switch (p_msg->hdr.opcode) - { - case AVRC_OP_VENDOR: /* 0x00 Vendor-dependent commands */ - status = avrc_pars_vendor_rsp(&p_msg->vendor, p_result, p_buf, buf_len); - break; - - case AVRC_OP_PASS_THRU: /* 0x7C panel subunit opcode */ - status = avrc_pars_pass_thru(&p_msg->pass, &id); - if (status == AVRC_STS_NO_ERROR) - { - p_result->pdu = (UINT8)id; - } - break; - -#if (AVCT_BROWSE_INCLUDED == TRUE) - case AVRC_OP_BROWSE: - status = avrc_pars_browsing_rsp(&p_msg->browse, p_result, p_buf, buf_len); - break; -#endif /* (AVCT_BROWSE_INCLUDED == TRUE) */ - - default: - AVRC_TRACE_ERROR1("AVRC_ParsCommand() unknown opcode:0x%x", p_msg->hdr.opcode); - break; - } - p_result->rsp.opcode = p_msg->hdr.opcode; - p_result->rsp.status = status; - } - return status; -} - - -#endif /* (AVRC_METADATA_INCLUDED == TRUE) */ diff --git a/stack/avrc/avrc_pars_tg.c b/stack/avrc/avrc_pars_tg.c deleted file mode 100644 index 8237655..0000000 --- a/stack/avrc/avrc_pars_tg.c +++ /dev/null @@ -1,452 +0,0 @@ -/***************************************************************************** -** -** Name: avrc_pars_tg.c -** -** Description:Interface to AVRCP parse message functions for the Target Role -** -** Copyright (c) 2008-2008, Broadcom Corp., All Rights Reserved. -** Broadcom Bluetooth Core. Proprietary and confidential. -** -*****************************************************************************/ -#include <string.h> - -#include "gki.h" -#include "avrc_api.h" -#include "avrc_defs.h" -#include "avrc_int.h" - -/***************************************************************************** -** Global data -*****************************************************************************/ -#if (AVRC_METADATA_INCLUDED == TRUE) - -/******************************************************************************* -** -** Function avrc_pars_vendor_cmd -** -** Description This function parses the vendor specific commands defined by -** Bluetooth SIG -** -** Returns AVRC_STS_NO_ERROR, if the message in p_data is parsed successfully. -** Otherwise, the error code defined by AVRCP 1.4 -** -*******************************************************************************/ -static tAVRC_STS avrc_pars_vendor_cmd(tAVRC_MSG_VENDOR *p_msg, tAVRC_COMMAND *p_result, UINT8 *p_buf, UINT16 buf_len) -{ - tAVRC_STS status = AVRC_STS_NO_ERROR; - UINT8 *p = p_msg->p_vendor_data; - UINT16 len; - UINT8 xx, yy; - UINT8 *p_u8; - UINT16 *p_u16; - UINT32 u32, u32_2, *p_u32; - tAVRC_APP_SETTING *p_app_set; - UINT16 size_needed; - - p_result->pdu = *p++; - AVRC_TRACE_DEBUG1("avrc_pars_vendor_cmd() pdu:0x%x", p_result->pdu); - if (!AVRC_IsValidAvcType (p_result->pdu, p_msg->hdr.ctype)) - { - AVRC_TRACE_DEBUG0("avrc_pars_vendor_cmd() detects wrong AV/C type!"); - status = AVRC_STS_BAD_CMD; - } - - p++; /* skip the reserved byte */ - BE_STREAM_TO_UINT16 (len, p); - if ((len+4) != (p_msg->vendor_len)) - { - status = AVRC_STS_INTERNAL_ERR; - } - - if (status != AVRC_STS_NO_ERROR) - return status; - - switch (p_result->pdu) - { - case AVRC_PDU_GET_CAPABILITIES: /* 0x10 */ - p_result->get_caps.capability_id = *p++; - if (!AVRC_IS_VALID_CAP_ID(p_result->get_caps.capability_id)) - status = AVRC_STS_BAD_PARAM; - else if (len != 1) - status = AVRC_STS_INTERNAL_ERR; - break; - - case AVRC_PDU_LIST_PLAYER_APP_ATTR: /* 0x11 */ - /* no additional parameters */ - if (len != 0) - status = AVRC_STS_INTERNAL_ERR; - break; - - case AVRC_PDU_LIST_PLAYER_APP_VALUES: /* 0x12 */ - p_result->list_app_values.attr_id = *p++; - if (!AVRC_IS_VALID_ATTRIBUTE(p_result->list_app_values.attr_id)) - status = AVRC_STS_BAD_PARAM; - else if (len != 1) - status = AVRC_STS_INTERNAL_ERR; - break; - - case AVRC_PDU_GET_CUR_PLAYER_APP_VALUE: /* 0x13 */ - case AVRC_PDU_GET_PLAYER_APP_ATTR_TEXT: /* 0x15 */ - BE_STREAM_TO_UINT8 (p_result->get_cur_app_val.num_attr, p); - if (len != (p_result->get_cur_app_val.num_attr+1)) - { - status = AVRC_STS_INTERNAL_ERR; - break; - } - p_u8 = p_result->get_cur_app_val.attrs; - for (xx=0, yy=0; xx< p_result->get_cur_app_val.num_attr; xx++) - { - /* only report the valid player app attributes */ - if (AVRC_IsValidPlayerAttr(*p)) - p_u8[yy++] = *p; - p++; - } - p_result->get_cur_app_val.num_attr = yy; - if (yy == 0) - { - status = AVRC_STS_BAD_PARAM; - } - break; - - case AVRC_PDU_SET_PLAYER_APP_VALUE: /* 0x14 */ - BE_STREAM_TO_UINT8 (p_result->set_app_val.num_val, p); - size_needed = sizeof(tAVRC_APP_SETTING); - if (p_buf && (len == ((p_result->set_app_val.num_val<<1) + 1))) - { - p_result->set_app_val.p_vals = (tAVRC_APP_SETTING *)p_buf; - p_app_set = p_result->set_app_val.p_vals; - for (xx=0; ((xx< p_result->set_app_val.num_val) && (buf_len > size_needed)); xx++) - { - p_app_set[xx].attr_id = *p++; - p_app_set[xx].attr_val = *p++; - if (!avrc_is_valid_player_attrib_value(p_app_set[xx].attr_id, p_app_set[xx].attr_val)) - status = AVRC_STS_BAD_PARAM; - } - if (xx != p_result->set_app_val.num_val) - { - AVRC_TRACE_ERROR2("AVRC_PDU_SET_PLAYER_APP_VALUE not enough room:%d orig num_val:%d", - xx, p_result->set_app_val.num_val); - p_result->set_app_val.num_val = xx; - } - } - else - { - AVRC_TRACE_ERROR0("AVRC_PDU_SET_PLAYER_APP_VALUE NULL decode buffer or bad len"); - status = AVRC_STS_INTERNAL_ERR; - } - break; - - case AVRC_PDU_GET_PLAYER_APP_VALUE_TEXT:/* 0x16 */ - if (len < 3) - status = AVRC_STS_INTERNAL_ERR; - else - { - BE_STREAM_TO_UINT8 (p_result->get_app_val_txt.attr_id, p); - if (!AVRC_IS_VALID_ATTRIBUTE(p_result->get_app_val_txt.attr_id)) - status = AVRC_STS_BAD_PARAM; - else - { - BE_STREAM_TO_UINT8 (p_result->get_app_val_txt.num_val, p); - if ( (len - 2/* attr_id & num_val */) != p_result->get_app_val_txt.num_val) - status = AVRC_STS_INTERNAL_ERR; - else - { - p_u8 = p_result->get_app_val_txt.vals; - for (xx=0; xx< p_result->get_app_val_txt.num_val; xx++) - { - p_u8[xx] = *p++; - if (!avrc_is_valid_player_attrib_value(p_result->get_app_val_txt.attr_id, p_u8[xx])) - { - status = AVRC_STS_BAD_PARAM; - break; - } - } - } - } - } - break; - - case AVRC_PDU_INFORM_DISPLAY_CHARSET: /* 0x17 */ - if (len < 3) - status = AVRC_STS_INTERNAL_ERR; - else - { - BE_STREAM_TO_UINT8 (p_result->inform_charset.num_id, p); - if ( (len - 1/* num_id */) != p_result->inform_charset.num_id * 2) - status = AVRC_STS_INTERNAL_ERR; - else - { - p_u16 = p_result->inform_charset.charsets; - if (p_result->inform_charset.num_id > AVRC_MAX_CHARSET_SIZE) - p_result->inform_charset.num_id = AVRC_MAX_CHARSET_SIZE; - for (xx=0; xx< p_result->inform_charset.num_id; xx++) - { - BE_STREAM_TO_UINT16 (p_u16[xx], p); - } - } - } - break; - - case AVRC_PDU_INFORM_BATTERY_STAT_OF_CT:/* 0x18 */ - if (len != 1) - status = AVRC_STS_INTERNAL_ERR; - else - { - p_result->inform_battery_status.battery_status = *p++; - if (!AVRC_IS_VALID_BATTERY_STATUS(p_result->inform_battery_status.battery_status)) - status = AVRC_STS_BAD_PARAM; - } - break; - - case AVRC_PDU_GET_ELEMENT_ATTR: /* 0x20 */ - if (len < 9) /* UID/8 and num_attr/1 */ - status = AVRC_STS_INTERNAL_ERR; - else - { - BE_STREAM_TO_UINT32 (u32, p); - BE_STREAM_TO_UINT32 (u32_2, p); - if (u32== 0 && u32_2 == 0) - { - BE_STREAM_TO_UINT8 (p_result->get_elem_attrs.num_attr, p); - if ( (len - 9/* UID/8 and num_attr/1 */) != (p_result->get_elem_attrs.num_attr * 4)) - status = AVRC_STS_INTERNAL_ERR; - else - { - p_u32 = p_result->get_elem_attrs.attrs; - if (p_result->get_elem_attrs.num_attr > AVRC_MAX_ELEM_ATTR_SIZE) - p_result->get_elem_attrs.num_attr = AVRC_MAX_ELEM_ATTR_SIZE; - for (xx=0; xx< p_result->get_elem_attrs.num_attr; xx++) - { - BE_STREAM_TO_UINT32 (p_u32[xx], p); - } - } - } - else - status = AVRC_STS_NOT_FOUND; - } - break; - - case AVRC_PDU_GET_PLAY_STATUS: /* 0x30 */ - /* no additional parameters */ - if (len != 0) - status = AVRC_STS_INTERNAL_ERR; - break; - - case AVRC_PDU_REGISTER_NOTIFICATION: /* 0x31 */ - if (len != 5) - status = AVRC_STS_INTERNAL_ERR; - BE_STREAM_TO_UINT8 (p_result->reg_notif.event_id, p); - BE_STREAM_TO_UINT32 (p_result->reg_notif.param, p); - break; - - /* case AVRC_PDU_REQUEST_CONTINUATION_RSP: 0x40 */ - /* case AVRC_PDU_ABORT_CONTINUATION_RSP: 0x41 */ - -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) - case AVRC_PDU_SET_ABSOLUTE_VOLUME: /* 0x50 */ - if (len != 1) - status = AVRC_STS_INTERNAL_ERR; - p_result->volume.volume = *p++; - break; - - case AVRC_PDU_SET_ADDRESSED_PLAYER: /* 0x60 */ - if (len != 2) - status = AVRC_STS_INTERNAL_ERR; - BE_STREAM_TO_UINT16 (p_result->addr_player.player_id, p); - break; - - case AVRC_PDU_PLAY_ITEM: /* 0x74 */ - case AVRC_PDU_ADD_TO_NOW_PLAYING: /* 0x90 */ - if (len != (AVRC_UID_SIZE + 3)) - status = AVRC_STS_INTERNAL_ERR; - BE_STREAM_TO_UINT8 (p_result->play_item.scope, p); - if (p_result->play_item.scope > AVRC_SCOPE_NOW_PLAYING) - { - status = AVRC_STS_BAD_SCOPE; - } - BE_STREAM_TO_ARRAY (p, p_result->play_item.uid, AVRC_UID_SIZE); - BE_STREAM_TO_UINT16 (p_result->play_item.uid_counter, p); - break; -#endif /* (AVRC_ADV_CTRL_INCLUDED == TRUE) */ - - default: - status = AVRC_STS_BAD_CMD; - break; - } - - return status; -} - -#if (AVCT_BROWSE_INCLUDED == TRUE) -/******************************************************************************* -** -** Function avrc_pars_browsing -** -** Description This function parses the commands that go through the -** browsing channel -** -** Returns AVRC_STS_NO_ERROR, if the message in p_data is parsed successfully. -** Otherwise, the error code defined by AVRCP+1 -** -*******************************************************************************/ -static tAVRC_STS avrc_pars_browsing_cmd(tAVRC_MSG_BROWSE *p_msg, tAVRC_COMMAND *p_result, UINT8 *p_buf, UINT16 buf_len) -{ - tAVRC_STS status = AVRC_STS_NO_ERROR; - UINT8 *p = p_msg->p_browse_data; - UINT16 len; - int i, count; - - p_result->pdu = *p++; - AVRC_TRACE_DEBUG1("avrc_pars_browsing_cmd() pdu:0x%x", p_result->pdu); - BE_STREAM_TO_UINT16 (len, p); - switch (p_result->pdu) - { - case AVRC_PDU_SET_BROWSED_PLAYER: /* 0x70 */ - BE_STREAM_TO_UINT16 (p_result->br_player.player_id, p); - break; - - case AVRC_PDU_GET_FOLDER_ITEMS: /* 0x71 */ - BE_STREAM_TO_UINT8 (p_result->get_items.scope, p); - if (p_result->get_items.scope > AVRC_SCOPE_NOW_PLAYING) - { - status = AVRC_STS_BAD_SCOPE; - } - BE_STREAM_TO_UINT32 (p_result->get_items.start_item, p); - BE_STREAM_TO_UINT32 (p_result->get_items.end_item, p); - if (p_result->get_items.start_item > p_result->get_items.end_item) - { - status = AVRC_STS_BAD_RANGE; - } - BE_STREAM_TO_UINT8 (p_result->get_items.attr_count, p); - p_result->get_items.p_attr_list = NULL; - if (p_result->get_items.attr_count && p_buf && - (p_result->get_items.attr_count != AVRC_FOLDER_ITEM_COUNT_NONE)) - { - p_result->get_items.p_attr_list = (UINT32 *)p_buf; - count = p_result->get_items.attr_count; - if (buf_len < (count<<2)) - p_result->get_items.attr_count = count = (buf_len >> 2); - for (i=0; i<count; i++) - { - BE_STREAM_TO_UINT32 (p_result->get_items.p_attr_list[i], p); - } - } - break; - - case AVRC_PDU_CHANGE_PATH: /* 0x72 */ - BE_STREAM_TO_UINT16 (p_result->chg_path.uid_counter, p); - BE_STREAM_TO_UINT8 (p_result->chg_path.direction, p); - if (p_result->chg_path.direction != AVRC_DIR_UP && p_result->chg_path.direction != AVRC_DIR_DOWN) - { - status = AVRC_STS_BAD_DIR; - } - BE_STREAM_TO_ARRAY (p, p_result->chg_path.folder_uid, AVRC_UID_SIZE); - break; - - case AVRC_PDU_GET_ITEM_ATTRIBUTES: /* 0x73 */ - BE_STREAM_TO_UINT8 (p_result->get_attrs.scope, p); - if (p_result->get_attrs.scope > AVRC_SCOPE_NOW_PLAYING) - { - status = AVRC_STS_BAD_SCOPE; - break; - } - BE_STREAM_TO_ARRAY (p, p_result->get_attrs.uid, AVRC_UID_SIZE); - BE_STREAM_TO_UINT16 (p_result->get_attrs.uid_counter, p); - BE_STREAM_TO_UINT8 (p_result->get_attrs.attr_count, p); - p_result->get_attrs.p_attr_list = NULL; - if (p_result->get_attrs.attr_count && p_buf) - { - p_result->get_attrs.p_attr_list = (UINT32 *)p_buf; - count = p_result->get_attrs.attr_count; - if (buf_len < (count<<2)) - p_result->get_attrs.attr_count = count = (buf_len >> 2); - for (i=0, count=0; i<p_result->get_attrs.attr_count; i++) - { - BE_STREAM_TO_UINT32 (p_result->get_attrs.p_attr_list[count], p); - if (AVRC_IS_VALID_MEDIA_ATTRIBUTE(p_result->get_attrs.p_attr_list[count])) - { - count++; - } - } - - if (p_result->get_attrs.attr_count != count && count == 0) - status = AVRC_STS_BAD_PARAM; - else - p_result->get_attrs.attr_count = count; - } - break; - - case AVRC_PDU_SEARCH: /* 0x80 */ - BE_STREAM_TO_UINT16 (p_result->search.string.charset_id, p); - BE_STREAM_TO_UINT16 (p_result->search.string.str_len, p); - p_result->search.string.p_str = p_buf; - if (p_buf) - { - if (buf_len > p_result->search.string.str_len) - buf_len = p_result->search.string.str_len; - BE_STREAM_TO_ARRAY (p, p_buf, p_result->search.string.str_len); - } - else - { - status = AVRC_STS_INTERNAL_ERR; - } - break; - - default: - status = AVRC_STS_BAD_CMD; - break; - } - return status; -} -#endif /* AVCT_BROWSE_INCLUDED == TRUE*/ - -/******************************************************************************* -** -** Function AVRC_ParsCommand -** -** Description This function is a superset of AVRC_ParsMetadata to parse the command. -** -** Returns AVRC_STS_NO_ERROR, if the message in p_data is parsed successfully. -** Otherwise, the error code defined by AVRCP 1.4 -** -*******************************************************************************/ -tAVRC_STS AVRC_ParsCommand (tAVRC_MSG *p_msg, tAVRC_COMMAND *p_result, UINT8 *p_buf, UINT16 buf_len) -{ - tAVRC_STS status = AVRC_STS_INTERNAL_ERR; - UINT16 id; - - if (p_msg && p_result) - { - switch (p_msg->hdr.opcode) - { - case AVRC_OP_VENDOR: /* 0x00 Vendor-dependent commands */ - status = avrc_pars_vendor_cmd(&p_msg->vendor, p_result, p_buf, buf_len); - break; - - case AVRC_OP_PASS_THRU: /* 0x7C panel subunit opcode */ - status = avrc_pars_pass_thru(&p_msg->pass, &id); - if (status == AVRC_STS_NO_ERROR) - { - p_result->pdu = (UINT8)id; - } - break; - -#if (AVCT_BROWSE_INCLUDED == TRUE) - case AVRC_OP_BROWSE: - status = avrc_pars_browsing_cmd(&p_msg->browse, p_result, p_buf, buf_len); - break; -#endif /*(AVCT_BROWSE_INCLUDED == TRUE)*/ - - default: - AVRC_TRACE_ERROR1("AVRC_ParsCommand() unknown opcode:0x%x", p_msg->hdr.opcode); - break; - } - p_result->cmd.opcode = p_msg->hdr.opcode; - p_result->cmd.status = status; - } - AVRC_TRACE_DEBUG1("AVRC_ParsCommand() return status:0x%x", status); - return status; -} - -#endif /* (AVRC_METADATA_INCLUDED == TRUE) */ - diff --git a/stack/avrc/avrc_sdp.c b/stack/avrc/avrc_sdp.c index ad2024e..c9ad935 100644 --- a/stack/avrc/avrc_sdp.c +++ b/stack/avrc/avrc_sdp.c @@ -25,26 +25,9 @@ tAVRC_CB avrc_cb; const tSDP_PROTOCOL_ELEM avrc_proto_list [] = { {UUID_PROTOCOL_L2CAP, 1, {AVCT_PSM, 0} }, -#if AVRC_ADV_CTRL_INCLUDED == TRUE - {UUID_PROTOCOL_AVCTP, 1, {AVCT_REV_1_3, 0} } -#else -#if AVRC_METADATA_INCLUDED == TRUE - {UUID_PROTOCOL_AVCTP, 1, {AVCT_REV_1_2, 0} } -#else {UUID_PROTOCOL_AVCTP, 1, {AVCT_REV_1_0, 0} } -#endif -#endif }; -#if AVRC_ADV_CTRL_INCLUDED == TRUE -const tSDP_PROTO_LIST_ELEM avrc_add_proto_list [] = -{ - {AVRC_NUM_PROTO_ELEMS, - { - {UUID_PROTOCOL_L2CAP, 1, {AVCT_BR_PSM, 0} }, - {UUID_PROTOCOL_AVCTP, 1, {AVCT_REV_1_3, 0} }}} -}; -#endif /****************************************************************************** @@ -210,30 +193,13 @@ UINT16 AVRC_AddRecord(UINT16 service_uuid, char *p_service_name, /* add service class id list */ class_list[0] = service_uuid; -#if AVRC_ADV_CTRL_INCLUDED == TRUE - if( service_uuid == UUID_SERVCLASS_AV_REMOTE_CONTROL ) - { - class_list[1] = UUID_SERVCLASS_AV_REM_CTRL_CONTROL; - count = 2; - } -#endif result &= SDP_AddServiceClassIdList(sdp_handle, count, class_list); /* add protocol descriptor list */ result &= SDP_AddProtocolList(sdp_handle, AVRC_NUM_PROTO_ELEMS, (tSDP_PROTOCOL_ELEM *)avrc_proto_list); /* add profile descriptor list */ -#if AVRC_ADV_CTRL_INCLUDED == TRUE - result &= SDP_AddProfileDescriptorList(sdp_handle, UUID_SERVCLASS_AV_REMOTE_CONTROL, AVRC_REV_1_4); - /* additional protocol list to include browsing channel */ - result &= SDP_AddAdditionProtoLists( sdp_handle, 1, (tSDP_PROTO_LIST_ELEM *)avrc_add_proto_list); -#else -#if AVRC_METADATA_INCLUDED == TRUE - result &= SDP_AddProfileDescriptorList(sdp_handle, UUID_SERVCLASS_AV_REMOTE_CONTROL, AVRC_REV_1_3); -#else result &= SDP_AddProfileDescriptorList(sdp_handle, UUID_SERVCLASS_AV_REMOTE_CONTROL, AVRC_REV_1_0); -#endif -#endif /* add supported categories */ p = temp; diff --git a/stack/avrc/avrc_utils.c b/stack/avrc/avrc_utils.c deleted file mode 100644 index b9eef9b..0000000 --- a/stack/avrc/avrc_utils.c +++ /dev/null @@ -1,254 +0,0 @@ -/***************************************************************************** -** -** Name: avrc_utils.c -** -** Description: Utility functions to validate AVRC command/response paramaters -** -** Copyright (c) 2003-2008, Broadcom Corp., All Rights Reserved. -** Broadcom Bluetooth Core. Proprietary and confidential. -** -*****************************************************************************/ -#include <string.h> - -#include "gki.h" -#include "avrc_api.h" -#include "avrc_int.h" - - -#if (AVRC_METADATA_INCLUDED == TRUE) - -/************************************************************************** -** -** Function AVRC_IsValidAvcType -** -** Description Check if correct AVC type is specified -** -** Returns returns TRUE if it is valid -** -** -*******************************************************************************/ -BOOLEAN AVRC_IsValidAvcType(UINT8 pdu_id, UINT8 avc_type) -{ - BOOLEAN result=FALSE; - - if (avc_type < AVRC_RSP_NOT_IMPL) /* command msg */ - { - switch (pdu_id) - { - case AVRC_PDU_GET_CAPABILITIES: /* 0x10 */ - case AVRC_PDU_LIST_PLAYER_APP_ATTR: /* 0x11 */ - case AVRC_PDU_LIST_PLAYER_APP_VALUES: /* 0x12 */ - case AVRC_PDU_GET_CUR_PLAYER_APP_VALUE: /* 0x13 */ - case AVRC_PDU_GET_PLAYER_APP_ATTR_TEXT: /* 0x15 */ - case AVRC_PDU_GET_PLAYER_APP_VALUE_TEXT: /* 0x16 */ - case AVRC_PDU_GET_ELEMENT_ATTR: /* 0x20 */ - case AVRC_PDU_GET_PLAY_STATUS: /* 0x30 */ - if (avc_type == AVRC_CMD_STATUS) - result=TRUE; - break; - - case AVRC_PDU_SET_PLAYER_APP_VALUE: /* 0x14 */ - case AVRC_PDU_INFORM_DISPLAY_CHARSET: /* 0x17 */ - case AVRC_PDU_INFORM_BATTERY_STAT_OF_CT: /* 0x18 */ - case AVRC_PDU_REQUEST_CONTINUATION_RSP: /* 0x40 */ - case AVRC_PDU_ABORT_CONTINUATION_RSP: /* 0x41 */ - if (avc_type == AVRC_CMD_CTRL) - result=TRUE; - break; - - case AVRC_PDU_REGISTER_NOTIFICATION: /* 0x31 */ - if (avc_type == AVRC_CMD_NOTIF) - result=TRUE; - break; - -#if (AVRC_ADV_CTRL_INCLUDED == TRUE) - case AVRC_PDU_SET_ABSOLUTE_VOLUME: /* 0x50 */ - case AVRC_PDU_SET_ADDRESSED_PLAYER: /* 0x60 */ - case AVRC_PDU_PLAY_ITEM: /* 0x74 */ - case AVRC_PDU_ADD_TO_NOW_PLAYING: /* 0x90 */ - if (avc_type == AVRC_CMD_CTRL) - result=TRUE; - break; -#endif - } - } - else /* response msg */ - { - if (avc_type >= AVRC_RSP_NOT_IMPL && - avc_type <= AVRC_RSP_INTERIM ) - result=TRUE; - } - - return result; -} - -/******************************************************************************* -** -** Function avrc_is_valid_player_attrib_value -** -** Description Check if the given attrib value is valid for its attribute -** -** -** Returns returns TRUE if it is valid -** -*******************************************************************************/ -BOOLEAN avrc_is_valid_player_attrib_value(UINT8 attrib, UINT8 value) -{ - BOOLEAN result=FALSE; - - switch(attrib) - { - case AVRC_PLAYER_SETTING_EQUALIZER: - if ((value > 0) && - (value <= AVRC_PLAYER_VAL_ON)) - result=TRUE; - break; - - case AVRC_PLAYER_SETTING_REPEAT: - if ((value > 0) && - (value <= AVRC_PLAYER_VAL_GROUP_REPEAT)) - result=TRUE; - break; - - case AVRC_PLAYER_SETTING_SHUFFLE: - case AVRC_PLAYER_SETTING_SCAN: - if ((value > 0) && - (value <= AVRC_PLAYER_VAL_GROUP_SHUFFLE)) - result=TRUE; - break; - } - - if (attrib >= AVRC_PLAYER_SETTING_LOW_MENU_EXT && - attrib <= AVRC_PLAYER_SETTING_HIGH_MENU_EXT) - result = TRUE; - - if (!result) - AVRC_TRACE_ERROR2("avrc_is_valid_player_attrib_value() found not matching attrib(x%x)-value(x%x) pair!", attrib, value); - - return result; -} - -/******************************************************************************* -** -** Function AVRC_IsValidPlayerAttr -** -** Description Check if the given attrib value is a valid one -** -** -** Returns returns TRUE if it is valid -** -*******************************************************************************/ -BOOLEAN AVRC_IsValidPlayerAttr(UINT8 attr) -{ - BOOLEAN result=FALSE; - - if ( (attr >= AVRC_PLAYER_SETTING_EQUALIZER && attr <= AVRC_PLAYER_SETTING_SCAN) || - (attr >= AVRC_PLAYER_SETTING_LOW_MENU_EXT && attr <= AVRC_PLAYER_SETTING_HIGH_MENU_EXT) ) - { - result = TRUE; - } - - return result; -} - - - -/******************************************************************************* -** -** Function avrc_pars_pass_thru -** -** Description This function parses the pass thru commands defined by -** Bluetooth SIG -** -** Returns AVRC_STS_NO_ERROR, if the message in p_data is parsed successfully. -** Otherwise, the error code defined by AVRCP 1.4 -** -*******************************************************************************/ -tAVRC_STS avrc_pars_pass_thru(tAVRC_MSG_PASS *p_msg, UINT16 *p_vendor_unique_id) -{ - UINT8 *p_data; - UINT32 co_id; - UINT16 id; - tAVRC_STS status = AVRC_STS_BAD_CMD; - - if (p_msg->op_id == AVRC_ID_VENDOR && p_msg->pass_len == AVRC_PASS_THRU_GROUP_LEN) - { - p_data = p_msg->p_pass_data; - AVRC_BE_STREAM_TO_CO_ID (co_id, p_data); - if (co_id == AVRC_CO_METADATA) - { - BE_STREAM_TO_UINT16 (id, p_data); - if (AVRC_IS_VALID_GROUP(id)) - { - *p_vendor_unique_id = id; - status = AVRC_STS_NO_ERROR; - } - } - } - return status; -} - -/******************************************************************************* -** -** Function avrc_opcode_from_pdu -** -** Description This function returns the opcode of the given pdu -** -** Returns AVRC_OP_VENDOR, AVRC_OP_PASS_THRU or AVRC_OP_BROWSE -** -*******************************************************************************/ -UINT8 avrc_opcode_from_pdu(UINT8 pdu) -{ - UINT8 opcode = 0; - - switch (pdu) - { -#if (AVCT_BROWSE_INCLUDED == TRUE) - case AVRC_PDU_SET_BROWSED_PLAYER: - case AVRC_PDU_GET_FOLDER_ITEMS: - case AVRC_PDU_CHANGE_PATH: - case AVRC_PDU_GET_ITEM_ATTRIBUTES: - case AVRC_PDU_SEARCH: - case AVRC_PDU_GENERAL_REJECT: - opcode = AVRC_OP_BROWSE; - break; -#endif /* AVCT_BROWSE_INCLUDED */ - - case AVRC_PDU_NEXT_GROUP: - case AVRC_PDU_PREV_GROUP: /* pass thru */ - opcode = AVRC_OP_PASS_THRU; - break; - - default: /* vendor */ - opcode = AVRC_OP_VENDOR; - break; - } - - return opcode; -} - -/******************************************************************************* -** -** Function avrc_is_valid_opcode -** -** Description This function returns the opcode of the given pdu -** -** Returns AVRC_OP_VENDOR, AVRC_OP_PASS_THRU or AVRC_OP_BROWSE -** -*******************************************************************************/ -BOOLEAN avrc_is_valid_opcode(UINT8 opcode) -{ - BOOLEAN is_valid = FALSE; - switch (opcode) - { - case AVRC_OP_BROWSE: - case AVRC_OP_PASS_THRU: - case AVRC_OP_VENDOR: - is_valid = TRUE; - break; - } - return is_valid; -} - -#endif /* (AVRC_METADATA_INCLUDED == TRUE) */ - |