Linux bluetooth development
 help / color / mirror / Atom feed
From: Andrei Emeltchenko <Andrei.Emeltchenko.news@gmail.com>
To: linux-bluetooth@vger.kernel.org
Subject: Re: [PATCHv1 12/15] android: Implement read_info_complete callback
Date: Mon, 7 Oct 2013 15:26:25 +0300	[thread overview]
Message-ID: <20131007122623.GG2804@aemeltch-MOBL1> (raw)
In-Reply-To: <1381131496-9417-13-git-send-email-Andrei.Emeltchenko.news@gmail.com>

On Mon, Oct 07, 2013 at 10:38:13AM +0300, Andrei Emeltchenko wrote:
> From: Andrei Emeltchenko <andrei.emeltchenko@intel.com>
> 
> Handle read info complete callback from mgmt interface.
> ---
>  android/main.c |  102 +++++++++++++++++++++++++++++++++++++++++++++++++-------
>  1 file changed, 90 insertions(+), 12 deletions(-)
> 
> diff --git a/android/main.c b/android/main.c
> index dab54ce..3a63eb9 100644
> --- a/android/main.c
> +++ b/android/main.c
> @@ -54,6 +54,7 @@
>  #include "log.h"
>  #include "hcid.h"
>  #include "sdpd.h"
> +#include "bt_adapter.h"
>  
>  #include "lib/bluetooth.h"
>  #include "lib/mgmt.h"
> @@ -69,6 +70,8 @@ static struct mgmt *mgmt_if = NULL;
>  static uint8_t mgmt_version = 0;
>  static uint8_t mgmt_revision = 0;
>  
> +struct bt_adapter *default_adapter = NULL;
> +
>  static int sdp_start(void)
>  {
>  	DBG("");
> @@ -118,34 +121,109 @@ static GOptionEntry options[] = {
>  	{ NULL }
>  };
>  
> -static void read_info_complete(uint8_t status, uint16_t length,
> +static void load_link_keys_complete(uint8_t status, uint16_t length,
>  					const void *param, void *user_data)
>  {
> -	/* TODO: Store Controller information */
> -
> -	/**
> -	 * Register all event notification handlers for controller.
> -	 *
> -	 * The handlers are registered after a succcesful read of the
> -	 * controller info. From now on they can track updates and
> -	 * notifications.
> -	 */
> +	DBG("status %u", status);
>  }
>  
> +static void load_link_keys(struct bt_adapter *adapter, GSList *keys)
> +{
> +	struct mgmt_cp_load_link_keys *cp;
> +	uint16_t key_len = g_slist_length(keys);
> +	struct mgmt_link_key_info *key;
> +	uint16_t len;
> +
> +	DBG("");
> +
> +	len = sizeof(*cp) + key_len * sizeof(*key);
> +	cp = malloc(len);
> +	if (cp == NULL) {
> +		error("%s: Not enough memory for link keys loading", __func__);
> +		return;
> +	}
> +
> +	cp->debug_keys = 0;
> +	cp->key_count = htobs(key_len);
> +
> +	mgmt_send(adapter->mgmt, MGMT_OP_LOAD_LINK_KEYS, adapter->dev_id, len,
> +				cp, load_link_keys_complete, adapter, NULL);
> +
> +	free(cp);
> +}
> +
> +static void read_info_complete(uint8_t status, uint16_t length,
> +					const void *param, void *user_data)
> +{
> +	const struct mgmt_rp_read_info *rp = param;
> +
> +	DBG("");
> +
> +	if (status != MGMT_STATUS_SUCCESS) {
> +		error("Failed to read info for index %u: %s (0x%02x)",
> +			default_adapter->dev_id, mgmt_errstr(status), status);
> +		goto failed;
> +	}
> +
> +	if (length < sizeof(*rp)) {
> +		error("Too small read info complete response");
> +		goto failed;
> +	}
> +
> +	if (bacmp(&rp->bdaddr, BDADDR_ANY) == 0) {
> +		error("No Bluetooth address for index %u",
> +						default_adapter->dev_id);
> +		goto failed;
> +	}
> +
> +	/* Store adapter information */
> +	bacpy(&default_adapter->bdaddr, &rp->bdaddr);
> +	default_adapter->dev_class = rp->dev_class[0] |
> +						(rp->dev_class[1] << 8) |
> +						(rp->dev_class[2] << 16);
> +	default_adapter->name = g_strdup((const char *) rp->name);
> +	default_adapter->short_name = g_strdup((const char *) rp->short_name);
> +
> +	default_adapter->supported_settings = btohs(rp->supported_settings);
> +	default_adapter->current_settings = btohs(rp->current_settings);
> +
> +	/* TODO: Register all event notification handlers */
> +
> +	if (default_adapter->current_settings & MGMT_SETTING_POWERED)
> +		adapter_start(default_adapter);
> +
> +	/* dummy link keys loading */
> +	load_link_keys(default_adapter, NULL);
> +
> +	return;
> +
> +failed:
> +	default_adapter = NULL;
> +}
>  
>  static void mgmt_index_added_event(uint16_t index, uint16_t length,
>  					const void *param, void *user_data)
>  {
>  	info("%s: index %u", __func__, index);
>  
> +	if (default_adapter == NULL) {

sorry, this should be != NULL

I will send updated version soon.

Best regards 
Andrei Emeltchenko 


  reply	other threads:[~2013-10-07 12:26 UTC|newest]

Thread overview: 91+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-10-07  7:38 [PATCHv1 00/15] Basic code for Android BlueZ Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 01/15] android: Supress missing initializers warnings Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 02/15] android: Add Adapter Bluetooth HAL template Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 03/15] android: Add Socket " Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 04/15] android: Enable Socket interface Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 05/15] android: Start Android Bluetooth daemon Andrei Emeltchenko
2013-10-07 12:09   ` Szymon Janc
2013-10-07  7:38 ` [PATCHv1 06/15] android: Add basic mgmt initialization sequence Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 07/15] android: Create HAL API header skeleton Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 08/15] android: Add adapter and device struct for BlueZ daemon Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 09/15] android: Add Android Makefile for libbluetooth Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 10/15] android: sdp: Reuse BlueZ SDP server in Android Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 11/15] android: Add cap to bind to port < 1024 Andrei Emeltchenko
2013-10-07 12:14   ` Szymon Janc
2013-10-07  7:38 ` [PATCHv1 12/15] android: Implement read_info_complete callback Andrei Emeltchenko
2013-10-07 12:26   ` Andrei Emeltchenko [this message]
2013-10-07  7:38 ` [PATCHv1 13/15] android: Handle mgmt changed events Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 14/15] android: Add makefile for hciconfig Andrei Emeltchenko
2013-10-07  7:38 ` [PATCHv1 15/15] android: Add makefile for hcitool Andrei Emeltchenko
2013-10-08 10:33 ` [PATCHv2 00/15] Basic code for Android BlueZ Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 01/15] android: Supress missing initializers warnings Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 02/15] android: Add Adapter Bluetooth HAL template Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 03/15] android: Add Socket " Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 04/15] android: Enable Socket interface Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 05/15] android: Start Android Bluetooth daemon Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 06/15] android: Add basic mgmt initialization sequence Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 07/15] android: Create HAL API header skeleton Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 08/15] android: Add adapter and device struct for BlueZ daemon Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 09/15] android: Add Android Makefile for libbluetooth Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 10/15] android: sdp: Reuse BlueZ SDP server in Android Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 11/15] android: Add cap to bind to port < 1024 Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 12/15] android: Implement read_info_complete callback Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 13/15] android: Handle mgmt changed events Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 14/15] android: Add makefile for hciconfig Andrei Emeltchenko
2013-10-08 10:33   ` [PATCHv2 15/15] android: Add makefile for hcitool Andrei Emeltchenko
2013-10-08 14:51 ` [PATCHv3 00/15] Basic code for Android BlueZ Andrei Emeltchenko
2013-10-08 14:51   ` [PATCHv3 01/15] android: Supress missing initializers warnings Andrei Emeltchenko
2013-10-09 19:11     ` Marcel Holtmann
2013-10-09 22:55       ` Lucas De Marchi
2013-10-10  6:58       ` Andrei Emeltchenko
2013-10-10  7:35         ` Marcel Holtmann
2013-10-10  8:07           ` Andrei Emeltchenko
2013-10-10  8:10             ` Marcel Holtmann
2013-10-10  8:16               ` Andrei Emeltchenko
2013-10-08 14:51   ` [PATCHv3 02/15] android: Add Adapter Bluetooth HAL template Andrei Emeltchenko
2013-10-08 14:51   ` [PATCHv3 03/15] android: Add Socket " Andrei Emeltchenko
2013-10-09 19:14     ` Marcel Holtmann
2013-10-10  6:56       ` Andrei Emeltchenko
2013-10-10  7:33         ` Marcel Holtmann
2013-10-08 14:51   ` [PATCHv3 04/15] android: Enable Socket interface Andrei Emeltchenko
2013-10-09 19:15     ` Marcel Holtmann
2013-10-08 14:51   ` [PATCHv3 05/15] android: Start Android Bluetooth daemon Andrei Emeltchenko
2013-10-09 19:19     ` Marcel Holtmann
2013-10-08 14:51   ` [PATCHv3 06/15] android: Add basic mgmt initialization sequence Andrei Emeltchenko
2013-10-09 19:30     ` Marcel Holtmann
2013-10-10  9:59       ` Andrei Emeltchenko
2013-10-10 12:38         ` Marcel Holtmann
2013-10-08 14:51   ` [PATCHv3 07/15] android: Create HAL API header skeleton Andrei Emeltchenko
2013-10-09 19:34     ` Marcel Holtmann
2013-10-10 12:29       ` Andrei Emeltchenko
2013-10-10 12:35         ` Marcel Holtmann
2013-10-10 12:48           ` Andrei Emeltchenko
2013-10-10 13:02             ` Marcel Holtmann
2013-10-08 14:51   ` [PATCHv3 08/15] android: Add adapter and device struct for BlueZ daemon Andrei Emeltchenko
2013-10-09 19:39     ` Marcel Holtmann
2013-10-10 12:36       ` Andrei Emeltchenko
2013-10-10 12:40         ` Marcel Holtmann
2013-10-10  9:07     ` Marcin Kraglak
2013-10-10 12:30       ` Andrei Emeltchenko
2013-10-10 13:18         ` Marcin Kraglak
2013-10-10 13:27           ` Andrei Emeltchenko
2013-10-08 14:51   ` [PATCHv3 09/15] android: Add Android Makefile for libbluetooth Andrei Emeltchenko
2013-10-09 19:43     ` Marcel Holtmann
2013-10-10 12:43       ` Andrei Emeltchenko
2013-10-10 12:45         ` Marcel Holtmann
2013-10-10 12:52           ` Andrei Emeltchenko
2013-10-08 14:51   ` [PATCHv3 10/15] android: sdp: Reuse BlueZ SDP server in Android Andrei Emeltchenko
2013-10-09 19:45     ` Marcel Holtmann
2013-10-08 14:51   ` [PATCHv3 11/15] android: Add cap to bind to port < 1024 Andrei Emeltchenko
2013-10-09 19:48     ` Marcel Holtmann
2013-10-10 13:01       ` Andrei Emeltchenko
2013-10-08 14:51   ` [PATCHv3 12/15] android: Implement read_info_complete callback Andrei Emeltchenko
2013-10-09 19:54     ` Marcel Holtmann
2013-10-08 14:51   ` [PATCHv3 13/15] android: Handle mgmt changed events Andrei Emeltchenko
2013-10-09 19:58     ` Marcel Holtmann
2013-10-08 14:51   ` [PATCHv3 14/15] android: Add makefile for hciconfig Andrei Emeltchenko
2013-10-09 19:59     ` Marcel Holtmann
2013-10-14 11:51       ` Andrei Emeltchenko
2013-10-14 12:06         ` Marcel Holtmann
2013-10-14 13:39           ` Michal Labedzki
2013-10-08 14:51   ` [PATCHv3 15/15] android: Add makefile for hcitool Andrei Emeltchenko

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=20131007122623.GG2804@aemeltch-MOBL1 \
    --to=andrei.emeltchenko.news@gmail.com \
    --cc=linux-bluetooth@vger.kernel.org \
    /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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox