summaryrefslogtreecommitdiff
path: root/android/avrcp-lib.c
diff options
context:
space:
mode:
authorLuiz Augusto von Dentz <luiz.von.dentz@intel.com>2014-04-29 17:42:50 +0300
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>2014-10-06 16:01:49 +0300
commit13e9c11ba55be944720929ca782f7711a52dd549 (patch)
tree966019d91645c843f012b7cc32a8ad35ee8466ee /android/avrcp-lib.c
parent5b6f61a06c81a2d4c3c1dca9b58f2036f91d72df (diff)
downloadbluez-13e9c11ba55be944720929ca782f7711a52dd549.tar.gz
android/avrcp-lib: Add ListPlayerValues structs
Diffstat (limited to 'android/avrcp-lib.c')
-rw-r--r--android/avrcp-lib.c34
1 files changed, 27 insertions, 7 deletions
diff --git a/android/avrcp-lib.c b/android/avrcp-lib.c
index 587c6ee46..29b2935a2 100644
--- a/android/avrcp-lib.c
+++ b/android/avrcp-lib.c
@@ -98,6 +98,15 @@ struct list_attributes_rsp {
uint8_t params[0];
} __attribute__ ((packed));
+struct list_values_req {
+ uint8_t attr;
+} __attribute__ ((packed));
+
+struct list_values_rsp {
+ uint8_t number;
+ uint8_t params[0];
+} __attribute__ ((packed));
+
struct avrcp_control_handler {
uint8_t id;
uint8_t code;
@@ -560,20 +569,22 @@ static ssize_t list_values(struct avrcp *session, uint8_t transaction,
void *user_data)
{
struct avrcp_player *player = user_data;
+ struct list_values_req *req;
DBG("");
- if (!params || params_len != 1)
+ if (!params || params_len != sizeof(*req))
return -EINVAL;
- if (params[0] > AVRCP_ATTRIBUTE_LAST ||
- params[0] == AVRCP_ATTRIBUTE_ILEGAL)
+ req = (void *) params;
+ if (req->attr > AVRCP_ATTRIBUTE_LAST ||
+ req->attr == AVRCP_ATTRIBUTE_ILEGAL)
return -EINVAL;
if (!player->ind || !player->ind->list_values)
return -ENOSYS;
- return player->ind->list_values(session, transaction, params[0],
+ return player->ind->list_values(session, transaction, req->attr,
player->user_data);
}
@@ -1737,6 +1748,7 @@ static gboolean list_values_rsp(struct avctp *conn,
struct avrcp *session = user_data;
struct avrcp_player *player = session->player;
struct avrcp_header *pdu;
+ struct list_values_rsp *rsp;
uint8_t number = 0;
uint8_t *values = NULL;
int err;
@@ -1757,9 +1769,17 @@ static gboolean list_values_rsp(struct avctp *conn,
goto done;
}
- number = pdu->params[0];
- if (number > 0)
- values = &pdu->params[1];
+ if (pdu->params_len < sizeof(*rsp)) {
+ err = -EPROTO;
+ goto done;
+ }
+
+ rsp = (void *) pdu->params;
+
+ if (rsp->number > 0) {
+ number = rsp->number;
+ values = rsp->params;
+ }
err = 0;