All of lore.kernel.org
 help / color / mirror / Atom feed
From: Szymon Janc <szymon.janc@gmail.com>
To: Marcin Kraglak <marcin.kraglak@tieto.com>
Cc: linux-bluetooth@vger.kernel.org
Subject: Re: [PATCHv2 11/11] android/gatt: Add deregister_for_notification implementation
Date: Thu, 27 Mar 2014 23:50:36 +0100	[thread overview]
Message-ID: <12465754.7v2VELycOU@athlon> (raw)
In-Reply-To: <1395954789-32459-11-git-send-email-marcin.kraglak@tieto.com>

Hi Marcin,

On Thursday 27 March 2014 22:13:09 Marcin Kraglak wrote:
> This will unregister handlers for notification and indications
> and remove notification_data from client's list.
> ---
>  android/gatt.c | 52 +++++++++++++++++++++++++++++++++++++++++++++++++++-
>  1 file changed, 51 insertions(+), 1 deletion(-)
> 
> diff --git a/android/gatt.c b/android/gatt.c
> index d004e35..384dccf 100644
> --- a/android/gatt.c
> +++ b/android/gatt.c
> @@ -1573,11 +1573,61 @@ failed:
>  static void handle_client_deregister_for_notification(const void *buf,
>  								uint16_t len)
>  {
> +	const struct hal_cmd_gatt_client_deregister_for_notification *cmd = buf;
> +	struct notification_data *notification, notif;
> +	struct gatt_client *client;
> +	struct gatt_device *dev;
> +	int32_t conn_id = 0;
> +	char addr_str[18];
> +	uint8_t status;
> +	bdaddr_t addr;
> +
>  	DBG("");
> 
> +	client = queue_find(gatt_clients, match_client_by_id,
> +						INT_TO_PTR(cmd->client_if));
> +	if (!client) {
> +		error("gatt: couldn't deregister: client not registered");
> +		status = HAL_STATUS_FAILED;
> +		goto failed;
> +	}
> +
> +	android2bdaddr((bdaddr_t *)&cmd->bdaddr, &addr);

Casting is not needed here.

> +	ba2str(&addr, addr_str);
> +
> +	dev = queue_find(conn_list, match_dev_by_bdaddr, &addr);
> +	if (!dev) {
> +		error("gatt: couldn't deregister: device %s not found",
> +								addr_str);
> +		status = HAL_STATUS_FAILED;
> +		goto failed;
> +	}
> +
> +	conn_id = dev->conn_id;
> +	memcpy(&notif.ch, &cmd->char_id, sizeof(notif.ch));
> +	memcpy(&notif.service, &cmd->srvc_id, sizeof(notif.service));
> +	notif.dev = dev;
> +
> +	notification = queue_find(client->notifications,
> +						match_notification, &notif);
> +

Do we need to check that? Wouldn't g_attrib_unregister() failed if id is 
invalid?

And empty line is not needed here.

> +	if (!notification) {
> +		error("gatt: couldn't deregister: notification not registered");
> +		status = HAL_STATUS_FAILED;
> +		goto failed;
> +	}
> +
> +	unregister_notification(notification);
> +
> +	status = HAL_STATUS_SUCCESS;
> +
> +failed:
> +	client_register_for_notif_cb(conn_id, 0, status, &cmd->srvc_id,
> +								&cmd->char_id);
> +
>  	ipc_send_rsp(hal_ipc, HAL_SERVICE_ID_GATT,
>  				HAL_OP_GATT_CLIENT_DEREGISTER_FOR_NOTIFICATION,
> -				HAL_STATUS_FAILED);
> +				status);
>  }
> 
>  static void handle_client_read_remote_rssi(const void *buf, uint16_t len)

-- 
Szymon K. Janc
szymon.janc@gmail.com

  reply	other threads:[~2014-03-27 22:50 UTC|newest]

Thread overview: 21+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-03-27 21:12 [PATCHv2 01/11] android/gatt: Add helper for getting device by conn_id Marcin Kraglak
2014-03-27 21:13 ` [PATCHv2 02/11] android/gatt: Add helper to get client by id Marcin Kraglak
2014-03-27 21:49   ` Szymon Janc
2014-03-27 21:13 ` [PATCHv2 03/11] android/gatt: Service error when client cannot be created Marcin Kraglak
2014-03-27 21:46   ` Szymon Janc
2014-03-27 21:13 ` [PATCHv2 04/11] android/gatt: Add initial implementation of get_included_service Marcin Kraglak
2014-03-27 21:57   ` Szymon Janc
2014-03-27 21:13 ` [PATCHv2 05/11] android/gatt: Add get_included_data struct and callback Marcin Kraglak
2014-03-27 21:13 ` [PATCHv2 06/11] android/gatt: Add implementation of get_included_cb Marcin Kraglak
2014-03-27 22:04   ` Szymon Janc
2014-03-27 21:13 ` [PATCHv2 07/11] android/gatt: Add notifications list to gatt_client Marcin Kraglak
2014-03-27 22:10   ` Szymon Janc
2014-03-27 21:13 ` [PATCHv2 08/11] android/gatt: Add initial implementation of register_for_notification Marcin Kraglak
2014-03-27 22:20   ` Szymon Janc
2014-03-27 21:13 ` [PATCHv2 09/11] android/gatt: Add client_register_for_notif_cb function Marcin Kraglak
2014-03-27 22:25   ` Szymon Janc
2014-03-27 21:13 ` [PATCHv2 10/11] android/gatt: Add handler for ATT_OP_HANDLE_NOTIFY and ATT_OP_HANDLE_IND Marcin Kraglak
2014-03-27 22:32   ` Szymon Janc
2014-03-27 21:13 ` [PATCHv2 11/11] android/gatt: Add deregister_for_notification implementation Marcin Kraglak
2014-03-27 22:50   ` Szymon Janc [this message]
2014-03-27 21:33 ` [PATCHv2 01/11] android/gatt: Add helper for getting device by conn_id Szymon Janc

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=12465754.7v2VELycOU@athlon \
    --to=szymon.janc@gmail.com \
    --cc=linux-bluetooth@vger.kernel.org \
    --cc=marcin.kraglak@tieto.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.