Hi Andrei, > From: Andrei Emeltchenko <andrei.emeltchenko@xxxxxxxxx> > > 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@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html