[prev in list] [next in list] [prev in thread] [next in thread] 

List:       linux-bluetooth
Subject:    Re: [RFCv2 09/14] android: sdp: Reuse BlueZ SDP server in Android
From:       Szymon Janc <szymon.janc () tieto ! com>
Date:       2013-10-03 11:23:02
Message-ID: 12556011.okBRc3D5Dz () uw000953
[Download RAW message or body]

Hi Andrei,

> From: Andrei Emeltchenko <andrei.emeltchenko@intel.com>
> 
> Reuse existing SDP server code in Android GPL daemon.
> ---
>  Makefile.android     |    7 +++++--
>  android/Android.mk   |    7 +++++++
>  android/bt_adapter.c |    5 ++++-
>  android/main.c       |   29 +++++++++++++++++++++++++++++
>  android/main.h       |   25 +++++++++++++++++++++++++
>  5 files changed, 70 insertions(+), 3 deletions(-)
>  create mode 100644 android/main.h
> 
> diff --git a/Makefile.android b/Makefile.android
> index 3e6fec0..bf82928 100644
> --- a/Makefile.android
> +++ b/Makefile.android
> @@ -3,7 +3,10 @@ if ANDROID_DAEMON
>  noinst_PROGRAMS += android/bluezd
>  
>  android_bluezd_SOURCES = android/main.c src/log.c \
> +				src/sdpd-database.c src/sdpd-server.c \
> +				src/sdpd-service.c src/sdpd-request.c \
>  				src/shared/util.h src/shared/util.c \
> -				src/shared/mgmt.h src/shared/mgmt.c
> -android_bluezd_LDADD = @GLIB_LIBS@
> +				src/shared/mgmt.h src/shared/mgmt.c \
> +				android/bt_adapter.h android/bt_adapter.c
> +android_bluezd_LDADD = lib/libbluetooth-internal.la @GLIB_LIBS@
>  endif
> diff --git a/android/Android.mk b/android/Android.mk
> index 11ac204..b0a531f 100644
> --- a/android/Android.mk
> +++ b/android/Android.mk
> @@ -11,6 +11,11 @@ LOCAL_SRC_FILES := \
>  	main.c \
>  	../src/shared/mgmt.c \
>  	../src/shared/util.c \
> +	bt_adapter.c \
> +	../src/sdpd-database.c \
> +	../src/sdpd-service.c \
> +	../src/sdpd-request.c \
> +	../src/sdpd-server.c \
>  
>  LOCAL_C_INCLUDES := \
>  	$(call include-path-for, glib) \
> @@ -19,6 +24,7 @@ LOCAL_C_INCLUDES := \
>  LOCAL_C_INCLUDES += \
>  	$(LOCAL_PATH)/../ \
>  	$(LOCAL_PATH)/../src \
> +	$(LOCAL_PATH)/../lib \
>  
>  LOCAL_CFLAGS := -DVERSION=\"$(BLUEZ_VERSION)\"
>  
> @@ -30,6 +36,7 @@ LOCAL_CFLAGS += -DSOCK_CLOEXEC=02000000 -DSOCK_NONBLOCK=04000
>  
>  LOCAL_SHARED_LIBRARIES := \
>  	libglib \
> +	libbluetooth \
>  
>  LOCAL_MODULE := bluezd
>  
> diff --git a/android/bt_adapter.c b/android/bt_adapter.c
> index e21d50c..5016243 100644
> --- a/android/bt_adapter.c
> +++ b/android/bt_adapter.c
> @@ -23,6 +23,7 @@
>  
>  #include "bt_adapter.h"
>  #include "log.h"
> +#include "main.h"
>  #include "src/shared/mgmt.h"
>  
>  struct bt_adapter *bt_adapter_new(uint16_t index, struct mgmt *mgmt_if)
> @@ -45,7 +46,7 @@ void adapter_start(struct bt_adapter *adapter)
>  
>  	/* TODO: CB: report scan mode */
>  
> -	/* TODO: SDP start here */
> +	sdp_start();

Why not just start it when daemon starts? Just like in original daemon?

>  
>  	/* TODO: CB: report state on */
>  }
> @@ -53,4 +54,6 @@ void adapter_start(struct bt_adapter *adapter)
>  void adapter_stop(struct bt_adapter *adapter)
>  {
>  	DBG("disabled %u", adapter->dev_id);
> +
> +	sdp_stop();
>  }
> diff --git a/android/main.c b/android/main.c
> index 4792919..db435f9 100644
> --- a/android/main.c
> +++ b/android/main.c
> @@ -36,6 +36,8 @@
>  
>  #include "log.h"
>  #include "hcid.h"
> +#include "sdpd.h"
> +#include "main.h"
>  
>  #include "lib/bluetooth.h"
>  #include "lib/mgmt.h"
> @@ -43,12 +45,39 @@
>  
>  #define SHUTDOWN_GRACE_SECONDS 10
>  
> +struct main_opts main_opts;
> +
>  static GMainLoop *event_loop;
>  static struct mgmt *mgmt_if = NULL;
>  
>  static uint8_t mgmt_version = 0;
>  static uint8_t mgmt_revision = 0;
>  
> +GList *adapter_list = NULL;
> +struct bt_adapter *default_adapter = NULL;
> +
> +int sdp_start(void)
> +{
> +	DBG("");
> +
> +	/* TODO: add logic */
> +
> +	/* sdpd-server use these settings */
> +	memset(&main_opts, 0, sizeof(main_opts));
> +
> +	/* Use params: mtu = 0, flags = 0 */
> +	return start_sdp_server(0, 0);
> +}
> +
> +void sdp_stop(void)
> +{
> +	DBG("");
> +
> +	/* TODO: add logic */
> +
> +	stop_sdp_server();
> +}
> +
>  void btd_exit(void)
>  {
>  	g_main_loop_quit(event_loop);
> diff --git a/android/main.h b/android/main.h
> new file mode 100644
> index 0000000..6ecad14
> --- /dev/null
> +++ b/android/main.h
> @@ -0,0 +1,25 @@
> +/*
> + *
> + *  BlueZ - Bluetooth protocol stack for Linux
> + *
> + *  Copyright (C) 2013  Intel Corporation. All rights reserved.
> + *
> + *
> + *  This program is free software; you can redistribute it and/or modify
> + *  it under the terms of the GNU General Public License as published by
> + *  the Free Software Foundation; either version 2 of the License, or
> + *  (at your option) any later version.
> + *
> + *  This program is distributed in the hope that it will be useful,
> + *  but WITHOUT ANY WARRANTY; without even the implied warranty of
> + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> + *  GNU General Public License for more details.
> + *
> + *  You should have received a copy of the GNU General Public License
> + *  along with this program; if not, write to the Free Software
> + *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
> + *
> + */
> +
> +int sdp_start(void);
> +void sdp_stop(void);
> 

-- 
BR
Szymon Janc


--
To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic