Re: [PATCH v2 2/2] android/gatt: Add support for client listen command

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Łukasz,

On Monday 14 of April 2014 11:57:52 Lukasz Rymanowski wrote:
> This patch adds support for gatt client listen which start/stop
> advertising
> ---
>  android/gatt.c | 64 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
>  1 file changed, 62 insertions(+), 2 deletions(-)
> 
> diff --git a/android/gatt.c b/android/gatt.c
> index 53131d4..2e2b45e 100644
> --- a/android/gatt.c
> +++ b/android/gatt.c
> @@ -130,6 +130,8 @@ static struct queue *conn_list = NULL;		/* Connected devices */
>  static struct queue *conn_wait_queue = NULL;	/* Devs waiting to connect */
>  static struct queue *disc_dev_list = NULL;	/* Disconnected devices */
>  
> +static struct queue *listen_clients = NULL;
> +
>  static void bt_le_discovery_stop_cb(void);
>  
>  static void android2uuid(const uint8_t *uuid, bt_uuid_t *dst)
> @@ -1279,12 +1281,63 @@ reply:
>  	put_device_on_disc_list(dev);
>  }
>  
> +static void send_client_listen_notify(int32_t id, int32_t status)
> +{
> +	struct hal_ev_gatt_client_listen ev;
> +
> +	/* Server if because of typo in android headers */
> +	ev.server_if = id;
> +	ev.status = status;
> +
> +	ipc_send_notif(hal_ipc, HAL_SERVICE_ID_GATT,
> +						HAL_EV_GATT_CLIENT_LISTEN,
> +						sizeof(ev), &ev);
> +	queue_remove(listen_clients, INT_TO_PTR(id));
> +}
> +
> +static void set_advertising_cb(uint8_t status, void *user_data)
> +{
> +	int32_t client_id = PTR_TO_INT(user_data);
> +
> +	send_client_listen_notify(client_id, status);
> +}
> +
>  static void handle_client_listen(const void *buf, uint16_t len)
>  {
> +	const struct hal_cmd_gatt_client_listen *cmd = buf;
> +	uint8_t status;
> +
>  	DBG("");
>  
> +	if (queue_find(listen_clients, match_by_value,
> +						INT_TO_PTR(cmd->client_if))) {
> +
> +		status = HAL_STATUS_SUCCESS;
> +		goto reply;
> +	}
> +
> +	if (!queue_push_tail(listen_clients, INT_TO_PTR(cmd->client_if))) {
> +		error("gatt: Could not put client on listen queue");
> +		status = HAL_STATUS_FAILED;
> +		goto reply;
> +	}
> +
> +	if (!bt_le_set_advertising(cmd->start, set_advertising_cb,
> +						INT_TO_PTR(cmd->client_if))) {
> +		error("gatt: Could not set advertising");
> +		status = HAL_STATUS_FAILED;
> +		goto reply;
> +	}
> +
> +	status = HAL_STATUS_SUCCESS;
> +
> +reply:
>  	ipc_send_rsp(hal_ipc, HAL_SERVICE_ID_GATT, HAL_OP_GATT_CLIENT_LISTEN,
> -							HAL_STATUS_FAILED);
> +							status);
> +
> +	if (status != HAL_STATUS_SUCCESS)
> +		send_client_listen_notify(cmd->client_if, GATT_FAILURE);
> +
>  }
>  
>  static void handle_client_refresh(const void *buf, uint16_t len)
> @@ -3008,9 +3061,10 @@ bool bt_gatt_register(struct ipc *ipc, const bdaddr_t *addr)
>  	gatt_clients = queue_new();
>  	gatt_servers = queue_new();
>  	disc_dev_list = queue_new();
> +	listen_clients = queue_new();
>  
>  	if (!conn_list || !conn_wait_queue || !gatt_clients || !gatt_servers ||
> -							!disc_dev_list) {
> +					!disc_dev_list || !listen_clients) {
>  		error("gatt: Failed to allocate memory for queues");
>  
>  		queue_destroy(gatt_servers, NULL);
> @@ -3028,6 +3082,9 @@ bool bt_gatt_register(struct ipc *ipc, const bdaddr_t *addr)
>  		queue_destroy(disc_dev_list, NULL);
>  		disc_dev_list = NULL;
>  
> +		queue_destroy(listen_clients, NULL);
> +		listen_clients = NULL;
> +
>  		return false;
>  	}
>  
> @@ -3062,4 +3119,7 @@ void bt_gatt_unregister(void)
>  
>  	queue_destroy(disc_dev_list, destroy_device);
>  	disc_dev_list = NULL;
> +
> +	queue_destroy(listen_clients, NULL);
> +	listen_clients = NULL;
>  }
> 

I think we should keep 'listening' clients on list and do reference counting
here i.e. stop advertising only when last client has stopped listening.

-- 
Best regards, 
Szymon Janc
--
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




[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux