diff --git a/android/avrcp-lib.c b/android/avrcp-lib.c
index 123d6fb..60d494f 100644
--- a/android/avrcp-lib.c
+++ b/android/avrcp-lib.c
player->user_data);
}
+static ssize_t set_addressed(struct avrcp *session, uint8_t transaction,
+ uint16_t params_len, uint8_t *params,
+ void *user_data)
+{
+ struct avrcp_player *player = user_data;
+ uint16_t id;
+
+ DBG("");
+
+ if (!params || params_len != 2)
+ return -EINVAL;
+
+ if (!player->ind || !player->ind->set_addressed)
+ return -ENOSYS;
+
+ id = bt_get_be16(params);
+
+ return player->ind->set_addressed(session, transaction, id,
+ player->user_data);
+}
+
static const struct avrcp_control_handler player_handlers[] = {
{ AVRCP_GET_CAPABILITIES,
AVC_CTYPE_STATUS, AVC_CTYPE_STABLE,
{ AVRCP_REGISTER_NOTIFICATION,
AVC_CTYPE_NOTIFY, AVC_CTYPE_INTERIM,
register_notification },
+ { AVRCP_SET_ADDRESSED_PLAYER,
+ AVC_CTYPE_CONTROL, AVC_CTYPE_STABLE,
+ set_addressed },
{ },
};
diff --git a/android/avrcp-lib.h b/android/avrcp-lib.h
index 256576d..54bdf4f 100644
--- a/android/avrcp-lib.h
+++ b/android/avrcp-lib.h
int (*register_notification) (struct avrcp *session,
uint8_t transaction, uint8_t event,
uint32_t interval, void *user_data);
+ int (*set_addressed) (struct avrcp *session, uint8_t transaction,
+ uint16_t id, void *user_data);
};
struct avrcp_control_cfm {