Return-Path: MIME-Version: 1.0 In-Reply-To: <1338203808-15142-1-git-send-email-luiz.dentz@gmail.com> References: <1338203808-15142-1-git-send-email-luiz.dentz@gmail.com> From: Lucas De Marchi Date: Mon, 28 May 2012 12:16:35 -0300 Message-ID: Subject: Re: [PATCH BlueZ v2] AVRCP: Fix not registering to VolumeChanged event again when notified To: Luiz Augusto von Dentz Cc: linux-bluetooth@vger.kernel.org Content-Type: text/plain; charset=ISO-8859-1 Sender: linux-bluetooth-owner@vger.kernel.org List-ID: On Mon, May 28, 2012 at 8:16 AM, Luiz Augusto von Dentz wrote: > From: Luiz Augusto von Dentz > > 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