On Mon, May 28, 2012 at 8:16 AM, Luiz Augusto von Dentz <luiz.dentz@xxxxxxxxx> wrote: > From: Luiz Augusto von Dentz <luiz.von.dentz@xxxxxxxxx> > > The spec says: > > "A registered notification gets changed on receiving CHANGED event > notification. For a new notification additional NOTIFY command is > expected to be sent." > --- > v2: Fix check to do logical AND not OR > > audio/avrcp.c | 9 ++++++++- > 1 files changed, 8 insertions(+), 1 deletions(-) > > diff --git a/audio/avrcp.c b/audio/avrcp.c > index 131490f..a040099 100644 > --- a/audio/avrcp.c > +++ b/audio/avrcp.c > @@ -177,6 +177,8 @@ static uint32_t company_ids[] = { > IEEEID_BTSIG, > }; > > +static void register_volume_notification(struct avrcp_player *player); > + > static sdp_record_t *avrcp_ct_record(void) > { > sdp_list_t *svclass_id, *pfseq, *apseq, *root; > @@ -1148,13 +1150,18 @@ static gboolean avrcp_handle_volume_changed(struct avctp *session, > struct avrcp_header *pdu = (void *) operands; > uint8_t volume; > > - if (code == AVC_CTYPE_REJECTED || code == AVC_CTYPE_NOT_IMPLEMENTED) > + if (code != AVC_CTYPE_INTERIM && code != AVC_CTYPE_CHANGED) > return FALSE; > > volume = pdu->params[1] & 0x7F; > > player->cb->set_volume(volume, player->dev, player->user_data); > > + if (code == AVC_CTYPE_CHANGED) { > + register_volume_notification(player); > + return FALSE; > + } > + > return TRUE; > } Ack. Lucas De Marchi -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html