4 * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
6 * Contact: Hocheol Seo <hocheol.seo@samsung.com>
7 * Girishashok Joshi <girish.joshi@samsung.com>
8 * Chanyeol Park <chanyeol.park@samsung.com>
10 * Licensed under the Apache License, Version 2.0 (the "License");
11 * you may not use this file except in compliance with the License.
12 * You may obtain a copy of the License at
14 * http://www.apache.org/licenses/LICENSE-2.0
16 * Unless required by applicable law or agreed to in writing, software
17 * distributed under the License is distributed on an "AS IS" BASIS,
18 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19 * See the License for the specific language governing permissions and
20 * limitations under the License.
31 #include <net_connection.h>
32 #include <dbus/dbus-glib-lowlevel.h>
33 #include <dbus/dbus-glib.h>
34 #include <dbus/dbus.h>
40 #include <net_connection.h>
42 #include <eventsystem.h>
45 #include <eventsystem.h>
48 #include "bluetooth-api.h"
49 #include "bt-service-common.h"
50 #include "bt-service-agent.h"
52 static GDBusConnection *system_conn;
53 static GDBusConnection *session_conn;
54 static GDBusProxy *manager_proxy;
55 static GDBusProxy *adapter_proxy;
56 static void *net_conn;
58 static GDBusProxy *adapter_properties_proxy;
60 static GDBusConnection *system_gconn = NULL;
62 GDBusConnection *_bt_gdbus_init_system_gconn(void)
66 if (!g_thread_supported()) {
70 // dbus_g_thread_init();
74 if (system_gconn != NULL)
77 system_gconn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
80 BT_ERR("Unable to connect to dbus: %s", error->message);
81 g_clear_error(&error);
87 GDBusConnection *_bt_gdbus_get_system_gconn(void)
89 GDBusConnection *local_system_gconn = NULL;
92 if (system_gconn == NULL) {
93 system_gconn = _bt_gdbus_init_system_gconn();
94 } else if (g_dbus_connection_is_closed(system_gconn)){
96 local_system_gconn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
98 if (!local_system_gconn) {
99 BT_ERR("Unable to connect to dbus: %s", error->message);
100 g_clear_error(&error);
103 system_gconn = local_system_gconn;
109 static GDBusProxy *__bt_init_manager_proxy(void)
115 if (system_conn == NULL) {
116 system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
117 retv_if(system_conn == NULL, NULL);
120 proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE,
122 BT_MANAGER_PATH, BT_MANAGER_INTERFACE, NULL, NULL);
124 retv_if(proxy == NULL, NULL);
126 manager_proxy = proxy;
131 static GDBusProxy *__bt_init_adapter_proxy(void)
133 GDBusProxy *manager_proxy;
135 char *adapter_path = NULL;
139 if (system_conn == NULL) {
140 system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
141 retv_if(system_conn == NULL, NULL);
144 manager_proxy = _bt_get_manager_proxy();
145 retv_if(manager_proxy == NULL, NULL);
147 adapter_path = _bt_get_adapter_path();
148 retv_if(adapter_path == NULL, NULL);
150 proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE,
152 adapter_path, BT_ADAPTER_INTERFACE, NULL, NULL);
154 g_free(adapter_path);
156 retv_if(proxy == NULL, NULL);
158 adapter_proxy = proxy;
163 static GDBusProxy *__bt_init_adapter_properties_proxy(void)
165 GDBusProxy *manager_proxy;
167 char *adapter_path = NULL;
171 if (system_conn == NULL) {
172 system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
173 retv_if(system_conn == NULL, NULL);
176 manager_proxy = _bt_get_manager_proxy();
177 retv_if(manager_proxy == NULL, NULL);
179 adapter_path = _bt_get_adapter_path();
180 retv_if(adapter_path == NULL, NULL);
182 proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE,
184 adapter_path, BT_PROPERTIES_INTERFACE, NULL, NULL);
186 g_free(adapter_path);
188 retv_if(proxy == NULL, NULL);
190 adapter_properties_proxy = proxy;
195 GDBusConnection *__bt_init_system_gconn(void)
199 if (system_conn == NULL)
200 system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
205 GDBusConnection *__bt_init_session_conn(void)
207 if (session_conn == NULL)
208 session_conn =g_bus_get_sync(G_BUS_TYPE_SESSION, NULL, NULL);
213 GDBusConnection *_bt_get_session_gconn(void)
215 return (session_conn) ? session_conn : __bt_init_session_conn();
218 GDBusConnection *_bt_get_system_gconn(void)
220 return (system_conn) ? system_conn : __bt_init_system_gconn();
223 GDBusConnection *_bt_get_system_conn(void)
225 GDBusConnection *g_conn;
227 if (system_conn == NULL) {
228 g_conn = __bt_init_system_gconn();
230 g_conn = system_conn;
233 retv_if(g_conn == NULL, NULL);
238 GDBusProxy *_bt_get_manager_proxy(void)
241 const gchar *path = g_dbus_proxy_get_object_path(manager_proxy);
243 BT_ERR("Already proxy released hence creating new proxy");
244 return __bt_init_manager_proxy();
246 return manager_proxy;
248 return __bt_init_manager_proxy();
251 static void *__bt_init_net_conn(void)
254 connection_h connection = NULL;
256 if (net_conn == NULL) {
257 result = connection_create(&connection);
259 if (result != CONNECTION_ERROR_NONE ||
260 connection == NULL) {
261 BT_DBG("connection_create() failed: %d", result);
265 net_conn = connection;
270 void *_bt_get_net_conn(void)
272 return (net_conn) ? net_conn : __bt_init_net_conn();
275 GDBusProxy *_bt_get_adapter_proxy(void)
278 const char *path = g_dbus_proxy_get_object_path(adapter_proxy);
280 BT_ERR("Already proxy released hence creating new proxy");
281 return __bt_init_adapter_proxy();
284 return adapter_proxy;
286 return __bt_init_adapter_proxy();
290 GDBusProxy *_bt_get_adapter_properties_proxy(void)
292 return (adapter_properties_proxy) ? adapter_properties_proxy :
293 __bt_init_adapter_properties_proxy();
296 static char *__bt_extract_adapter_path(GVariantIter *iter)
298 char *object_path = NULL;
299 GVariantIter *interface_iter;
300 GVariantIter *svc_iter;
301 char *interface_str = NULL;
303 /* Parse the signature: oa{sa{sv}}} */
304 while (g_variant_iter_loop(iter, "{&oa{sa{sv}}}", &object_path,
307 if (object_path == NULL)
310 while (g_variant_iter_loop(interface_iter, "{sa{sv}}",
311 &interface_str, &svc_iter)) {
312 if (g_strcmp0(interface_str, "org.bluez.Adapter1") != 0)
315 BT_DBG("Object Path: %s", object_path);
316 g_free(interface_str);
317 g_variant_iter_free(svc_iter);
318 g_variant_iter_free(interface_iter);
319 return g_strdup(object_path);
325 char *_bt_get_adapter_path(void)
327 GDBusConnection *conn;
328 GDBusProxy *manager_proxy;
329 GVariant *result = NULL;
330 GVariantIter *iter = NULL;
331 char *adapter_path = NULL;
333 conn = _bt_get_system_conn();
334 retv_if(conn == NULL, NULL);
336 manager_proxy = _bt_get_manager_proxy();
337 retv_if(manager_proxy == NULL, NULL);
339 result = g_dbus_proxy_call_sync(manager_proxy, "GetManagedObjects",
341 G_DBUS_CALL_FLAGS_NONE,
346 BT_ERR("Can't get managed objects");
350 /* signature of GetManagedObjects: a{oa{sa{sv}}} */
351 g_variant_get(result, "(a{oa{sa{sv}}})", &iter);
353 adapter_path = __bt_extract_adapter_path(iter);
354 g_variant_iter_free(iter);
355 g_variant_unref(result);
359 void _bt_deinit_bluez_proxy(void)
362 g_object_unref(manager_proxy);
363 manager_proxy = NULL;
367 g_object_unref(adapter_proxy);
368 adapter_proxy = NULL;
370 if (adapter_properties_proxy) {
371 g_object_unref(adapter_properties_proxy);
372 adapter_properties_proxy = NULL;
376 void _bt_deinit_proxys(void)
379 _bt_deinit_bluez_proxy();
382 g_object_unref(system_conn);
387 g_object_unref(session_conn);
392 ret = connection_destroy(net_conn);
395 BT_ERR("connection_destroy failed : %d", ret);
399 void _bt_convert_device_path_to_address(const char *device_path,
400 char *device_address)
402 char address[BT_ADDRESS_STRING_SIZE] = { 0 };
405 ret_if(device_path == NULL);
406 ret_if(device_address == NULL);
408 dev_addr = strstr(device_path, "dev_");
409 if (dev_addr != NULL) {
412 g_strlcpy(address, dev_addr, sizeof(address));
414 while ((pos = strchr(address, '_')) != NULL) {
418 g_strlcpy(device_address, address, BT_ADDRESS_STRING_SIZE);
423 void _bt_convert_addr_string_to_type(unsigned char *addr,
429 ret_if(address == NULL);
430 ret_if(addr == NULL);
432 for (i = 0; i < BT_ADDRESS_LENGTH_MAX; i++) {
433 addr[i] = strtol(address, &ptr, 16);
434 if (ptr[0] != '\0') {
443 void _bt_convert_addr_type_to_string(char *address,
446 ret_if(address == NULL);
447 ret_if(addr == NULL);
449 snprintf(address, BT_ADDRESS_STRING_SIZE,
450 "%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X",
451 addr[0], addr[1], addr[2],
452 addr[3], addr[4], addr[5]);
455 void _bt_print_device_address_t(const bluetooth_device_address_t *addr)
457 BT_DBG("%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X\n", addr->addr[0], addr->addr[1], addr->addr[2],
458 addr->addr[3], addr->addr[4], addr->addr[5]);
461 void _bt_divide_device_class(bluetooth_device_class_t *device_class,
464 ret_if(device_class == NULL);
466 device_class->major_class = (unsigned short)(cod & 0x00001F00) >> 8;
467 device_class->minor_class = (unsigned short)((cod & 0x000000FC));
468 device_class->service_class = (unsigned long)((cod & 0x00FF0000));
470 if (cod & 0x002000) {
471 device_class->service_class |=
472 BLUETOOTH_DEVICE_SERVICE_CLASS_LIMITED_DISCOVERABLE_MODE;
476 void _bt_free_device_info(bt_remote_dev_info_t *dev_info)
480 ret_if(dev_info == NULL);
482 g_free(dev_info->address);
483 g_free(dev_info->name);
484 g_free(dev_info->manufacturer_data);
486 if (dev_info->uuids) {
487 for (i = 0; i < dev_info->uuid_count && dev_info->uuids[i]; i++)
488 g_free(dev_info->uuids[i]);
490 g_free(dev_info->uuids);
496 void _bt_free_le_device_info(bt_remote_le_dev_info_t *le_dev_info)
498 ret_if(le_dev_info == NULL);
500 g_free(le_dev_info->adv_data);
504 int _bt_copy_utf8_string(char *dest, const char *src, unsigned int length)
511 if (dest == NULL || src == NULL)
512 return BLUETOOTH_ERROR_INVALID_PARAM;
514 BT_DBG("+src : %s", src);
515 BT_DBG("+dest : %s", dest);
518 while (*p != '\0' && i < length) {
519 next = g_utf8_next_char(p);
522 while (count > 0 && ((i + count) < length)) {
529 return BLUETOOTH_ERROR_NONE;
532 gboolean _bt_utf8_validate(char *name)
536 glong items_written = 0;
538 if (FALSE == g_utf8_validate(name, -1, NULL))
541 u16 = g_utf8_to_utf16(name, -1, NULL, &items_written, NULL);
547 if (items_written != g_utf8_strlen(name, -1))
554 int _bt_register_osp_server_in_agent(int type, char *uuid, char *path, int fd)
557 if (!_bt_agent_register_osp_server( type, uuid, path, fd))
558 return BLUETOOTH_ERROR_INTERNAL;
560 return BLUETOOTH_ERROR_NONE;
563 int _bt_unregister_osp_server_in_agent(int type, char *uuid)
566 if (!_bt_agent_unregister_osp_server( type, uuid))
567 return BLUETOOTH_ERROR_INTERNAL;
569 return BLUETOOTH_ERROR_NONE;
572 int _bt_set_socket_non_blocking(int socket_fd)
574 /* Set Nonblocking */
577 arg = fcntl(socket_fd, F_GETFL);
582 if (arg & O_NONBLOCK) {
583 BT_ERR("Already Non-blocking \n");
588 if (fcntl(socket_fd, F_SETFL, arg) < 0)
591 return BLUETOOTH_ERROR_NONE;
594 int _bt_set_non_blocking_tty(int sk)
596 struct termios ti = {0,};
599 err = _bt_set_socket_non_blocking(sk);
602 BT_ERR("Error in set non blocking!\n");
606 tcflush(sk, TCIOFLUSH);
608 /* Switch tty to RAW mode */
610 tcsetattr(sk, TCSANOW, &ti);
612 return BLUETOOTH_ERROR_NONE;
615 static char *__bt_extract_device_path(GVariantIter *iter, char *address)
617 char *object_path = NULL;
618 char device_address[BT_ADDRESS_STRING_SIZE] = { 0 };
620 /* Parse the signature: oa{sa{sv}}} */
621 while (g_variant_iter_loop(iter, "{&oa{sa{sv}}}", &object_path,
623 retv_if(object_path == NULL, NULL);
624 _bt_convert_device_path_to_address(object_path, device_address);
625 if (g_strcmp0(address, device_address) == 0) {
626 return g_strdup(object_path);
632 char *_bt_get_device_object_path(char *address)
634 char *object_path = NULL;
635 GDBusConnection *conn;
636 GDBusProxy *manager_proxy;
637 GVariant *result = NULL;
638 GVariantIter *iter = NULL;
640 conn = _bt_get_system_conn();
641 retv_if(conn == NULL, NULL);
643 manager_proxy = _bt_get_manager_proxy();
644 retv_if(manager_proxy == NULL, NULL);
646 result = g_dbus_proxy_call_sync(manager_proxy, "GetManagedObjects",
648 G_DBUS_CALL_FLAGS_NONE,
653 BT_ERR("Can't get managed objects");
657 /* signature of GetManagedObjects: a{oa{sa{sv}}} */
658 g_variant_get(result, "(a{oa{sa{sv}}})", &iter);
659 object_path = __bt_extract_device_path(iter, address);
660 g_variant_iter_free(iter);
661 g_variant_unref(result);
665 char *_bt_get_profile_uuid128(bt_profile_type_t profile_type)
667 switch(profile_type) {
668 case BT_PROFILE_CONN_RFCOMM:
669 return strdup(RFCOMM_UUID_STR);
670 case BT_PROFILE_CONN_A2DP:
671 return strdup(A2DP_SINK_UUID);
672 case BT_PROFILE_CONN_A2DP_SINK:
673 return strdup(A2DP_SOURCE_UUID);
674 case BT_PROFILE_CONN_HSP:
675 return strdup(HFP_HS_UUID);
676 case BT_PROFILE_CONN_HID:
677 return strdup(HID_UUID);
678 case BT_PROFILE_CONN_NAP:
679 return strdup(NAP_UUID);
680 case BT_PROFILE_CONN_HFG:
681 return strdup(HFP_AG_UUID);
682 case BT_PROFILE_CONN_GATT:
683 case BT_PROFILE_CONN_ALL: /* NULL UUID will connect to both the audio profiles*/
689 char *_bt_convert_error_to_string(int error)
692 case BLUETOOTH_ERROR_CANCEL:
694 case BLUETOOTH_ERROR_INVALID_PARAM:
695 return "INVALID_PARAMETER";
696 case BLUETOOTH_ERROR_INVALID_DATA:
697 return "INVALID DATA";
698 case BLUETOOTH_ERROR_MEMORY_ALLOCATION:
699 case BLUETOOTH_ERROR_OUT_OF_MEMORY:
700 return "OUT_OF_MEMORY";
701 case BLUETOOTH_ERROR_TIMEOUT:
703 case BLUETOOTH_ERROR_NO_RESOURCES:
704 return "NO_RESOURCES";
705 case BLUETOOTH_ERROR_INTERNAL:
707 case BLUETOOTH_ERROR_NOT_SUPPORT:
708 return "NOT_SUPPORT";
709 case BLUETOOTH_ERROR_DEVICE_NOT_ENABLED:
710 return "NOT_ENABLED";
711 case BLUETOOTH_ERROR_DEVICE_ALREADY_ENABLED:
712 return "ALREADY_ENABLED";
713 case BLUETOOTH_ERROR_DEVICE_BUSY:
714 return "DEVICE_BUSY";
715 case BLUETOOTH_ERROR_ACCESS_DENIED:
716 return "ACCESS_DENIED";
717 case BLUETOOTH_ERROR_MAX_CLIENT:
719 case BLUETOOTH_ERROR_NOT_FOUND:
721 case BLUETOOTH_ERROR_SERVICE_SEARCH_ERROR:
722 return "SERVICE_SEARCH_ERROR";
723 case BLUETOOTH_ERROR_PARING_FAILED:
724 return "PARING_FAILED";
725 case BLUETOOTH_ERROR_NOT_PAIRED:
727 case BLUETOOTH_ERROR_SERVICE_NOT_FOUND:
728 return "SERVICE_NOT_FOUND";
729 case BLUETOOTH_ERROR_NOT_CONNECTED:
730 return "NOT_CONNECTED";
731 case BLUETOOTH_ERROR_ALREADY_CONNECT:
732 return "ALREADY_CONNECT";
733 case BLUETOOTH_ERROR_CONNECTION_BUSY:
734 return "CONNECTION_BUSY";
735 case BLUETOOTH_ERROR_CONNECTION_ERROR:
736 return "CONNECTION_ERROR";
737 case BLUETOOTH_ERROR_MAX_CONNECTION:
738 return "MAX_CONNECTION";
739 case BLUETOOTH_ERROR_NOT_IN_OPERATION:
740 return "NOT_IN_OPERATION";
741 case BLUETOOTH_ERROR_CANCEL_BY_USER:
742 return "CANCEL_BY_USER";
743 case BLUETOOTH_ERROR_REGISTRATION_FAILED:
744 return "REGISTRATION_FAILED";
745 case BLUETOOTH_ERROR_IN_PROGRESS:
746 return "IN_PROGRESS";
747 case BLUETOOTH_ERROR_AUTHENTICATION_FAILED:
748 return "AUTHENTICATION_FAILED";
749 case BLUETOOTH_ERROR_HOST_DOWN:
751 case BLUETOOTH_ERROR_END_OF_DEVICE_LIST:
752 return "END_OF_DEVICE_LIST";
753 case BLUETOOTH_ERROR_AGENT_ALREADY_EXIST:
754 return "AGENT_ALREADY_EXIST";
755 case BLUETOOTH_ERROR_AGENT_DOES_NOT_EXIST:
756 return "AGENT_DOES_NOT_EXIST";
757 case BLUETOOTH_ERROR_ALREADY_INITIALIZED:
758 return "ALREADY_INITIALIZED";
759 case BLUETOOTH_ERROR_PERMISSION_DEINED:
760 return "PERMISSION_DEINED";
761 case BLUETOOTH_ERROR_ALREADY_DEACTIVATED:
762 return "ALREADY_DEACTIVATED";
763 case BLUETOOTH_ERROR_NOT_INITIALIZED:
764 return "NOT_INITIALIZED";
770 char * _bt_convert_disc_reason_to_string(int reason)
776 return "Connection terminated by local host";
778 return "Remote user terminated connection";
785 void _bt_logging_connection(gboolean connect, int addr_type)
787 static int le_conn = 0;
788 static int le_disc = 0;
789 static int edr_conn = 0;
790 static int edr_disc = 0;
804 BT_INFO("[PM] Number of LE conn: %d disc: %d, Number of BR/EDR conn: %d disc: %d",
805 le_conn, le_disc, edr_conn, edr_disc);
808 int _bt_eventsystem_set_value(const char *event, const char *key, const char *value)
815 bundle_add_str(b, key, value);
817 ret = eventsystem_request_sending_system_event(event, b);
819 BT_DBG("request_sending_system_event result: %d", ret);
826 void _bt_swap_byte_ordering(char *data, int data_len)
831 ret_if(data == NULL);
832 /* Swap to opposite endian */
833 for (i = 0, j = data_len - 1; i < data_len; i++, j--) {
840 int _bt_byte_arr_cmp(const char *data1, const char *data2, int data_len)
844 retv_if(data1 == NULL, -1);
845 retv_if(data2 == NULL, -1);
846 for (i = 0; i < data_len; i++) {
847 if (data1[i] != data2[i])
848 return data1[i] - data2[i];
852 int _bt_byte_arr_cmp_with_mask(const char *data1, const char *data2,
853 const char *mask, int data_len)
858 retv_if(data1 == NULL, -1);
859 retv_if(data2 == NULL, -1);
860 retv_if(mask == NULL, -1);
861 for (i = 0; i < data_len; i++) {
862 a = data1[i] & mask[i];
863 b = data2[i] & mask[i];