Enhance debug message
[platform/core/connectivity/bluetooth-frwk.git] / bt-service / bt-service-common.c
1 /*
2  * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *              http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16  */
17
18 #include <stdio.h>
19 #include <string.h>
20 #include <glib.h>
21 #include <dlog.h>
22 #include <fcntl.h>
23 #include <errno.h>
24 #include <termios.h>
25 #include <net_connection.h>
26 #include <dbus/dbus.h>
27 #include <glib.h>
28 #include <dlog.h>
29 #include <fcntl.h>
30 #include <errno.h>
31 #include <termios.h>
32 #include <net_connection.h>
33 #include <bundle.h>
34 #include <eventsystem.h>
35
36 #include "bluetooth-api.h"
37 #include "bt-service-common.h"
38 #include "bt-service-agent.h"
39
40 static GDBusConnection *system_conn;
41 static GDBusConnection *session_conn;
42 static GDBusProxy *manager_proxy;
43 static GDBusProxy *adapter_proxy;
44 static void *net_conn;
45
46 static GDBusProxy *adapter_properties_proxy;
47
48 GDBusConnection *_bt_gdbus_init_system_gconn(void)
49 {
50         GError *error = NULL;
51
52         dbus_threads_init_default();
53
54         if (system_conn != NULL)
55                 return system_conn;
56
57         system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
58
59         if (!system_conn) {
60                 BT_ERR("Unable to connect to dbus: %s", error->message);
61                 g_clear_error(&error);
62         }
63
64         return system_conn;
65 }
66
67 GDBusConnection *_bt_gdbus_get_system_gconn(void)
68 {
69         GDBusConnection *local_system_gconn = NULL;
70         GError *error = NULL;
71
72         if (system_conn == NULL) {
73                 system_conn = _bt_gdbus_init_system_gconn();
74         } else if (g_dbus_connection_is_closed(system_conn)) {
75                 local_system_gconn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
76
77                 if (!local_system_gconn) {
78                         BT_ERR("Unable to connect to dbus: %s", error->message);
79                         g_clear_error(&error);
80                 }
81
82                 system_conn = local_system_gconn;
83         }
84
85         return system_conn;
86 }
87
88 GDBusConnection *_bt_gdbus_init_session_gconn(void)
89 {
90         GError *error = NULL;
91
92         if (!g_thread_supported())
93                 g_thread_init(NULL);
94
95         dbus_threads_init_default();
96
97         if (session_conn != NULL)
98                 return session_conn;
99
100         session_conn = g_bus_get_sync(G_BUS_TYPE_SESSION, NULL, &error);
101
102         if (!session_conn) {
103                 BT_ERR("Unable to connect to dbus: %s", error->message);
104                 g_clear_error(&error);
105         }
106
107         return session_conn;
108 }
109
110 GDBusConnection *_bt_gdbus_get_session_gconn(void)
111 {
112         GDBusConnection *local_session_gconn = NULL;
113         GError *error = NULL;
114
115         if (session_conn == NULL) {
116                 session_conn = _bt_gdbus_init_session_gconn();
117         } else if (g_dbus_connection_is_closed(session_conn)) {
118                 local_session_gconn = g_bus_get_sync(G_BUS_TYPE_SESSION, NULL, &error);
119
120                 if (!local_session_gconn) {
121                         BT_ERR("Unable to connect to dbus: %s", error->message);
122                         g_clear_error(&error);
123                 }
124
125                 session_conn = local_session_gconn;
126         }
127
128         return session_conn;
129 }
130
131 static GDBusProxy *__bt_init_manager_proxy(void)
132 {
133         GDBusConnection *g_conn;
134         GDBusProxy *proxy;
135
136         dbus_threads_init_default();
137
138         g_conn = _bt_gdbus_get_system_gconn();
139         retv_if(g_conn == NULL, NULL);
140
141         proxy = g_dbus_proxy_new_sync(g_conn, G_DBUS_PROXY_FLAGS_NONE,
142                                                                 NULL, BT_BLUEZ_NAME,
143                                                                 BT_MANAGER_PATH, BT_MANAGER_INTERFACE,  NULL, NULL);
144
145         if (!proxy) {
146                 BT_ERR("Unable to get proxy");
147                 return NULL;
148         }
149
150         manager_proxy = proxy;
151
152         return proxy;
153 }
154
155 static GDBusProxy *__bt_init_adapter_proxy(void)
156 {
157         GDBusConnection *g_conn;
158         GDBusProxy *manager_proxy;
159         GDBusProxy *proxy;
160         char *adapter_path = NULL;
161
162         dbus_threads_init_default();
163
164         g_conn = _bt_gdbus_get_system_gconn();
165         retv_if(g_conn == NULL, NULL);
166
167         manager_proxy = _bt_get_manager_proxy();
168         retv_if(manager_proxy == NULL, NULL);
169
170         adapter_path = _bt_get_adapter_path();
171         retv_if(adapter_path == NULL, NULL);
172
173         proxy = g_dbus_proxy_new_sync(g_conn, G_DBUS_PROXY_FLAGS_NONE,
174                                                                 NULL, BT_BLUEZ_NAME,
175                                                                 adapter_path, BT_ADAPTER_INTERFACE,  NULL, NULL);
176
177         g_free(adapter_path);
178
179         retv_if(proxy == NULL, NULL);
180
181         adapter_proxy = proxy;
182
183         return proxy;
184 }
185
186 static GDBusProxy *__bt_init_adapter_properties_proxy(void)
187 {
188         GDBusConnection *g_conn;
189         GDBusProxy *manager_proxy;
190         GDBusProxy *proxy;
191         char *adapter_path = NULL;
192
193         dbus_threads_init_default();
194
195         g_conn = _bt_gdbus_get_system_gconn();
196         retv_if(g_conn == NULL, NULL);
197
198         manager_proxy = _bt_get_manager_proxy();
199         retv_if(manager_proxy == NULL, NULL);
200
201         adapter_path = _bt_get_adapter_path();
202         retv_if(adapter_path == NULL, NULL);
203
204         proxy = g_dbus_proxy_new_sync(g_conn, G_DBUS_PROXY_FLAGS_NONE,
205                                                                         NULL, BT_BLUEZ_NAME,
206                                                                         adapter_path, BT_PROPERTIES_INTERFACE,  NULL, NULL);
207
208         g_free(adapter_path);
209
210         retv_if(proxy == NULL, NULL);
211
212         adapter_properties_proxy = proxy;
213
214         return proxy;
215 }
216
217 GDBusProxy *_bt_get_manager_proxy(void)
218 {
219         if (manager_proxy) {
220                 const gchar *path =  g_dbus_proxy_get_object_path(manager_proxy);
221                 if (path == NULL) {
222                         BT_ERR("Already proxy released hence creating new proxy");
223                         return  __bt_init_manager_proxy();
224                 }
225                 return manager_proxy;
226         }
227         return  __bt_init_manager_proxy();
228 }
229
230 static void *__bt_init_net_conn(void)
231 {
232         int result;
233         connection_h connection = NULL;
234
235         if (net_conn == NULL) {
236                 result = connection_create(&connection);
237
238         if (result != CONNECTION_ERROR_NONE ||
239                                         connection == NULL) {
240                 BT_DBG("connection_create() failed: %d", result);
241                 net_conn = NULL;
242                 return NULL;
243         }
244                 net_conn = connection;
245         }
246         return net_conn;
247 }
248
249 void *_bt_get_net_conn(void)
250 {
251         return (net_conn) ? net_conn : __bt_init_net_conn();
252 }
253
254 GDBusProxy *_bt_get_adapter_proxy(void)
255 {
256         if (adapter_proxy) {
257                 const char *path =  g_dbus_proxy_get_object_path(adapter_proxy);
258                 if (path == NULL) {
259                         BT_ERR("Already proxy released hence creating new proxy");
260                         return  __bt_init_adapter_proxy();
261                 }
262
263                 return adapter_proxy;
264         }
265         return  __bt_init_adapter_proxy();
266
267 }
268
269 GDBusProxy *_bt_get_adapter_properties_proxy(void)
270 {
271         return (adapter_properties_proxy) ? adapter_properties_proxy :
272                                         __bt_init_adapter_properties_proxy();
273 }
274
275 static char *__bt_extract_adapter_path(GVariantIter *iter)
276 {
277         char *object_path = NULL;
278         GVariantIter *interface_iter;
279         GVariantIter *svc_iter;
280         char *interface_str = NULL;
281
282         /* Parse the signature: oa{sa{sv}}} */
283         while (g_variant_iter_loop(iter, "{&oa{sa{sv}}}", &object_path,
284                         &interface_iter)) {
285
286                 if (object_path == NULL)
287                         continue;
288
289                 while (g_variant_iter_loop(interface_iter, "{&sa{sv}}",
290                                 &interface_str, &svc_iter)) {
291                         if (g_strcmp0(interface_str, "org.bluez.Adapter1") != 0)
292                                 continue;
293
294                         BT_DBG("Object Path: %s", object_path);
295                         g_variant_iter_free(svc_iter);
296                         g_variant_iter_free(interface_iter);
297                         return g_strdup(object_path);
298                 }
299         }
300         return NULL;
301 }
302
303 char *_bt_get_adapter_path(void)
304 {
305         GDBusConnection *conn;
306         GDBusProxy *manager_proxy;
307         GVariant *result = NULL;
308         GVariantIter *iter = NULL;
309         char *adapter_path = NULL;
310
311         conn = _bt_gdbus_get_system_gconn();
312         retv_if(conn == NULL, NULL);
313
314         manager_proxy = _bt_get_manager_proxy();
315         retv_if(manager_proxy == NULL, NULL);
316
317         result = g_dbus_proxy_call_sync(manager_proxy, "GetManagedObjects",
318                                 NULL,
319                                 G_DBUS_CALL_FLAGS_NONE,
320                                 -1,
321                                 NULL,
322                                 NULL);
323         if (!result) {
324                 BT_ERR("Can't get managed objects");
325                 return NULL;
326         }
327
328         /* signature of GetManagedObjects:  a{oa{sa{sv}}} */
329         g_variant_get(result, "(a{oa{sa{sv}}})", &iter);
330
331         adapter_path = __bt_extract_adapter_path(iter);
332         g_variant_iter_free(iter);
333         g_variant_unref(result);
334         return adapter_path;
335 }
336
337 void _bt_deinit_bluez_proxy(void)
338 {
339         if (manager_proxy) {
340                 g_object_unref(manager_proxy);
341                 manager_proxy = NULL;
342         }
343
344         if (adapter_proxy) {
345                 g_object_unref(adapter_proxy);
346                 adapter_proxy = NULL;
347         }
348         if (adapter_properties_proxy) {
349                 g_object_unref(adapter_properties_proxy);
350                 adapter_properties_proxy = NULL;
351         }
352 }
353
354 void _bt_deinit_proxys(void)
355 {
356         int ret;
357         _bt_deinit_bluez_proxy();
358
359         if (system_conn) {
360                 g_object_unref(system_conn);
361                 system_conn = NULL;
362         }
363
364         if (session_conn) {
365                 g_object_unref(session_conn);
366                 session_conn = NULL;
367         }
368
369         if (net_conn) {
370                 ret = connection_destroy(net_conn);
371                 net_conn = NULL;
372                 if (ret != 0)
373                         BT_ERR("connection_destroy failed : %d", ret);
374         }
375 }
376
377 void _bt_convert_device_path_to_address(const char *device_path,
378                                                 char *device_address)
379 {
380         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
381         char *dev_addr;
382
383         ret_if(device_path == NULL);
384         ret_if(device_address == NULL);
385
386         dev_addr = strstr(device_path, "dev_");
387         if (dev_addr != NULL) {
388                 char *pos = NULL;
389                 dev_addr += 4;
390                 g_strlcpy(address, dev_addr, sizeof(address));
391
392                 while ((pos = strchr(address, '_')) != NULL)
393                         *pos = ':';
394
395                 g_strlcpy(device_address, address, BT_ADDRESS_STRING_SIZE);
396         }
397 }
398
399
400 void _bt_convert_addr_string_to_type(unsigned char *addr,
401                                         const char *address)
402 {
403         int i;
404         char *ptr = NULL;
405
406         ret_if(address == NULL);
407         ret_if(addr == NULL);
408
409         for (i = 0; i < BT_ADDRESS_LENGTH_MAX; i++) {
410                 addr[i] = strtol(address, &ptr, 16);
411                 if (ptr[0] != '\0') {
412                         if (ptr[0] != ':')
413                                 return;
414
415                 address = ptr + 1;
416                 }
417         }
418 }
419
420 void _bt_convert_addr_string_to_secure_string(char *addr,
421                                         const char *address)
422 {
423         int len;
424
425         ret_if(address == NULL);
426         ret_if(addr == NULL);
427
428         len = strlen(address);
429         ret_if(len != BT_ADDRESS_STRING_SIZE - 1);
430
431         strncpy(addr, address, len);
432         addr[len] = '\0';
433
434         addr[len-7] = 'X';
435         addr[len-8] = 'X';
436         addr[len-10] = 'X';
437         addr[len-11] = 'X';
438         addr[len-13] = 'X';
439         addr[len-14] = 'X';
440         addr[len-16] = 'X';
441         addr[len-17] = 'X';
442
443         return;
444 }
445
446 void _bt_convert_addr_type_to_string(char *address,
447                                 unsigned char *addr)
448 {
449         ret_if(address == NULL);
450         ret_if(addr == NULL);
451
452         snprintf(address, BT_ADDRESS_STRING_SIZE,
453                         "%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X",
454                         addr[0], addr[1], addr[2],
455                         addr[3], addr[4], addr[5]);
456 }
457
458 void _bt_print_device_address_t(const bluetooth_device_address_t *addr)
459 {
460         BT_DBG("%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X\n", addr->addr[0], addr->addr[1], addr->addr[2],
461                                 addr->addr[3], addr->addr[4], addr->addr[5]);
462 }
463
464 void _bt_divide_device_class(bluetooth_device_class_t *device_class,
465                                 unsigned int cod)
466 {
467         ret_if(device_class == NULL);
468
469         device_class->major_class = (unsigned short)(cod & 0x00001F00) >> 8;
470         device_class->minor_class = (unsigned short)((cod & 0x000000FC));
471         device_class->service_class = (unsigned long)((cod & 0x00FF0000));
472
473         if (cod & 0x002000) {
474                 device_class->service_class |=
475                 BLUETOOTH_DEVICE_SERVICE_CLASS_LIMITED_DISCOVERABLE_MODE;
476         }
477 }
478
479 void _bt_free_device_info(bt_remote_dev_info_t *dev_info)
480 {
481         int i;
482
483         ret_if(dev_info == NULL);
484
485         g_free(dev_info->address);
486         g_free(dev_info->name);
487         g_free(dev_info->manufacturer_data);
488
489         if (dev_info->uuids) {
490                 for (i = 0; i < dev_info->uuid_count && dev_info->uuids[i]; i++)
491                         g_free(dev_info->uuids[i]);
492
493                 g_free(dev_info->uuids);
494         }
495
496         g_free(dev_info);
497 }
498
499 void _bt_free_le_device_info(bt_remote_le_dev_info_t *le_dev_info)
500 {
501         ret_if(le_dev_info == NULL);
502
503         g_free(le_dev_info->adv_data);
504         g_free(le_dev_info);
505 }
506
507 int _bt_copy_utf8_string(char *dest, const char *src, unsigned int length)
508 {
509         int i;
510         const char *p = src;
511         char *next;
512         int count;
513
514         if (dest == NULL || src == NULL)
515                 return BLUETOOTH_ERROR_INVALID_PARAM;
516
517         BT_DBG("+src : %s", src);
518         BT_DBG("+dest : %s", dest);
519
520         i = 0;
521         while (*p != '\0' && i < length) {
522                 next = g_utf8_next_char(p);
523                 count = next - p;
524
525                 while (count > 0 && ((i + count) < length)) {
526                         dest[i++] = *p;
527                         p++;
528                         count--;
529                 }
530                 p = next;
531         }
532         return BLUETOOTH_ERROR_NONE;
533 }
534
535 gboolean _bt_utf8_validate(char *name)
536 {
537         BT_DBG("+");
538         gunichar2 *u16;
539         glong items_written = 0;
540
541         if (FALSE == g_utf8_validate(name, -1, NULL))
542                 return FALSE;
543
544         u16 = g_utf8_to_utf16(name, -1, NULL, &items_written, NULL);
545         if (u16 == NULL)
546                 return FALSE;
547
548         g_free(u16);
549
550         if (items_written != g_utf8_strlen(name, -1))
551                 return FALSE;
552
553         BT_DBG("-");
554         return TRUE;
555 }
556
557 int _bt_register_osp_server_in_agent(int type, char *uuid, char *path, int fd)
558 {
559         BT_DBG("+");
560         if (!_bt_agent_register_osp_server(type, uuid, path, fd))
561                 return BLUETOOTH_ERROR_INTERNAL;
562
563         return BLUETOOTH_ERROR_NONE;
564 }
565
566 int _bt_unregister_osp_server_in_agent(int type, char *uuid)
567 {
568         BT_DBG("+");
569         if (!_bt_agent_unregister_osp_server(type, uuid))
570                 return BLUETOOTH_ERROR_INTERNAL;
571
572         return BLUETOOTH_ERROR_NONE;
573 }
574
575 int _bt_set_socket_non_blocking(int socket_fd)
576 {
577         /* Set Nonblocking */
578         long arg;
579
580         arg = fcntl(socket_fd, F_GETFL);
581
582         if (arg < 0)
583                 return -errno;
584
585         if (arg & O_NONBLOCK)
586                 BT_ERR("Already Non-blocking \n");
587
588         arg |= O_NONBLOCK;
589
590         if (fcntl(socket_fd, F_SETFL, arg) < 0)
591                 return -errno;
592
593         return BLUETOOTH_ERROR_NONE;
594 }
595
596 int _bt_set_non_blocking_tty(int sk)
597 {
598         struct termios ti = {0,};
599         int err;
600
601         err = _bt_set_socket_non_blocking(sk);
602
603         if (err < 0) {
604                 BT_ERR("Error in set non blocking!\n");
605                 return err;
606         }
607
608         tcflush(sk, TCIOFLUSH);
609
610         /* Switch tty to RAW mode */
611         cfmakeraw(&ti);
612         tcsetattr(sk, TCSANOW, &ti);
613
614         return BLUETOOTH_ERROR_NONE;
615 }
616
617 static char *__bt_extract_device_path(GVariantIter *iter, char *address)
618 {
619         char *object_path = NULL;
620         char device_address[BT_ADDRESS_STRING_SIZE] = { 0 };
621
622         /* Parse the signature: oa{sa{sv}}} */
623         while (g_variant_iter_loop(iter, "{&oa{sa{sv}}}", &object_path,
624                         NULL)) {
625                 if (!object_path) {
626                         BT_ERR("Unable to get object path");
627                         return NULL;
628                 }
629                 _bt_convert_device_path_to_address(object_path, device_address);
630                 if (g_strcmp0(address, device_address) == 0)
631                         return g_strdup(object_path);
632
633         }
634
635         BT_ERR("Unable to get object path");
636         return NULL;
637 }
638
639 char *_bt_get_device_object_path(char *address)
640 {
641         char *object_path = NULL;
642         GDBusConnection *conn;
643         GDBusProxy *manager_proxy;
644         GVariant *result = NULL;
645         GVariantIter *iter = NULL;
646
647         conn = _bt_gdbus_get_system_gconn();
648         retv_if(conn == NULL, NULL);
649
650         manager_proxy = _bt_get_manager_proxy();
651         retv_if(manager_proxy == NULL, NULL);
652
653         result = g_dbus_proxy_call_sync(manager_proxy, "GetManagedObjects",
654                                 NULL,
655                                 G_DBUS_CALL_FLAGS_NONE,
656                                 -1,
657                                 NULL,
658                                 NULL);
659         if (!result) {
660                 BT_ERR("Can't get managed objects");
661                 return NULL;
662         }
663
664         /* signature of GetManagedObjects:  a{oa{sa{sv}}} */
665         g_variant_get(result, "(a{oa{sa{sv}}})", &iter);
666         object_path = __bt_extract_device_path(iter, address);
667         g_variant_iter_free(iter);
668         g_variant_unref(result);
669         return object_path;
670 }
671
672 char *_bt_get_profile_uuid128(bt_profile_type_t profile_type)
673 {
674         switch (profile_type) {
675         case BT_PROFILE_CONN_RFCOMM:
676                 return strdup(RFCOMM_UUID_STR);
677         case BT_PROFILE_CONN_A2DP:
678                 return strdup(A2DP_SINK_UUID);
679         case BT_PROFILE_CONN_A2DP_SINK:
680                 return strdup(A2DP_SOURCE_UUID);
681         case BT_PROFILE_CONN_HSP:
682                 return strdup(HFP_HS_UUID);
683         case BT_PROFILE_CONN_HID:
684                 return strdup(HID_UUID);
685         case BT_PROFILE_CONN_NAP:
686                 return strdup(NAP_UUID);
687         case BT_PROFILE_CONN_HFG:
688                 return strdup(HFP_AG_UUID);
689         case BT_PROFILE_CONN_PBAP:
690                 return strdup(PBAP_UUID);
691         case BT_PROFILE_CONN_GATT:
692         case BT_PROFILE_CONN_ALL: /* NULL UUID will connect to both the audio profiles*/
693         default:
694                 return NULL;
695         };
696 }
697
698 const char *_bt_convert_uuid_to_string(const char *uuid)
699 {
700 #define SHORT_UUID_COUNT        199
701 #define LONG_UUID_COUNT         17
702
703         if (!uuid)
704                 return NULL;
705
706         int offset = 0;
707         int uuid_len = 4;
708         typedef struct {
709                 const char *uuid;
710                 const char *specification_name;
711         } uuid_name_s;
712         static uuid_name_s short_uuid_name[SHORT_UUID_COUNT] = {
713                 // List should be sorted by UUID
714                 /* BT Classic Services */
715                 {"1101", "Serial Port Service"},
716                 {"1102", "LAN Access Using PPP Service"},
717                 {"1103", "Dialup Networking Service"},
718                 {"1104", "IrMCSync Service"},
719                 {"1105", "OBEX Object Push Service"},
720                 {"1106", "OBEX File Transfer Service"},
721                 {"1107", "IrMC Sync Command Service"},
722                 {"1108", "Headset Service"},
723                 {"1109", "Cordless Telephony Service"},
724                 {"110A", "Audio Source Service"},
725                 {"110B", "Audio Sink Service"},
726                 {"110C", "AV Remote Control Target Service"},
727                 {"110D", "Advanced Audio Distribution Profile"},
728                 {"110E", "AV Remote Control Service"},
729                 {"110F", "Video Conferencing Service"},
730                 {"1110", "Intercom Service"},
731                 {"1111", "Fax Service"},
732                 {"1112", "Headset Audio Gateway Service"},
733                 {"1113", "WAP Service"},
734                 {"1114", "WAP Client Service"},
735                 {"1115", "PANU Service"},
736                 {"1116", "NAP Service"},
737                 {"1117", "GN Service"},
738                 {"1118", "Direct Printing Service"},
739                 {"1119", "Reference Printing Service"},
740                 {"111A", "Basic Imaging Profile"},
741                 {"111B", "Imaging Responder Service"},
742                 {"111C", "Imaging Automatic Archive Service"},
743                 {"111D", "Imaging Reference Objects Service"},
744                 {"111E", "Handsfree Service"},
745                 {"111F", "Handsfree Audio Gateway Service"},
746                 {"1120", "Direct Printing Reference Objects Service"},
747                 {"1121", "Reflected UI Service"},
748                 {"1122", "Basic Printing Profile"},
749                 {"1123", "Printing Status Service"},
750                 {"1124", "Human Interface Device Service"},
751                 {"1125", "Hardcopy Cable Replacement Profile"},
752                 {"1126", "HCR Print Service"},
753                 {"1127", "HCR Scan Service"},
754                 {"112D", "SIM Access Service"},
755                 {"112E", "Phonebook Access PCE Service"},
756                 {"112F", "Phonebook Access PSE Service"},
757                 {"1130", "Phonebook Access Profile"},
758                 {"1132", "Message Access Server Service"},
759                 {"1133", "Message Notification Server Service"},
760                 {"1134", "Message Access Profile"},
761                 {"1200", "PnP Information Service"},
762                 {"1201", "Generic Networking Service"},
763                 {"1202", "Generic File Transfer Service"},
764                 {"1203", "Generic Audio Service"},
765                 {"1204", "Generic Telephony Service"},
766                 {"1205", "UPnP Service"},
767                 {"1206", "UPnP Ip Service"},
768                 {"1303", "Video Source Service"},
769                 {"1304", "Video Sink Service"},
770                 {"1305", "Video Distribution Profile"},
771                 {"1400", "Health Device Profile"},
772                 {"1401", "HDP Source Service"},
773                 {"1402", "HDP Sink Service"},
774
775                 /* GATT Services */
776                 {"1800", "Generic Access"},
777                 {"1801", "Generic Attribute"},
778                 {"1802", "Immediate Alert"},
779                 {"1803", "Link Loss"},
780                 {"1804", "Tx Power"},
781                 {"1805", "Current Time Service"},
782                 {"1806", "Reference Time Update Service"},
783                 {"1807", "Next DST Change Service"},
784                 {"1808", "Glucose"},
785                 {"1809", "Health Thermometer"},
786                 {"180A", "Device Information"},
787                 {"180D", "Heart Rate"},
788                 {"180F", "Battery Service"},
789                 {"1810", "Blood Pressure"},
790                 {"1811", "Alert Notification Service"},
791                 {"1812", "Human Interface Device"},
792                 {"1813", "Scan Parameters"},
793                 {"1814", "Running Speed and Cadence"},
794                 {"1815", "Automation IO"},
795                 {"1816", "Cycling Speed and Cadence"},
796                 {"1818", "Cycling Power"},
797                 {"1819", "Location and Navigation"},
798                 {"181A", "Environmental Sensing"},
799                 {"181B", "Body Composition"},
800                 {"181C", "User Data"},
801                 {"181D", "Weight Scale"},
802                 {"181E", "Bond Management"},
803                 {"181F", "Continuous Glucose Monitoring"},
804                 {"1820", "Internet Protocol Support Service"},
805                 {"1821", "Indoor Positioning"},
806                 {"1822", "Pulse Oximeter Service"},
807                 {"1823", "HTTP Proxy"},
808                 {"1824", "Transport Discovery"},
809                 {"1825", "Object Transfer Service"},
810                 {"1826", "Fitness Machine"},
811                 {"1827", "Mesh Provisioning Service"},
812                 {"1828", "Mesh Proxy Service"},
813                 {"1829", "Reconnection Configuration"},
814                 {"183A", "Insulin Delivery"},
815
816                 /* GATT Declarations */
817                 {"2800", "Primary Service Declaration"},
818                 {"2801", "Secondary Service Declaration"},
819                 {"2802", "Include Declaration"},
820                 {"2803", "Characteristic Declaration"},
821
822                 /* GATT Descriptors */
823                 {"2900", "Characteristic Extended Properties"},
824                 {"2901", "Characteristic User Description"},
825                 {"2902", "Client Characteristic Configuration"},
826                 {"2903", "Server Characteristic Configuration"},
827                 {"2904", "Characteristic Format"},
828                 {"2905", "Characteristic Aggregate Formate"},
829                 {"2906", "Valid Range"},
830                 {"2907", "External Report Reference"},
831                 {"2908", "Report Reference"},
832
833                 /* GATT Characteristics */
834                 {"2A00", "Device Name"},
835                 {"2A01", "Appearance"},
836                 {"2A02", "Peripheral Privacy Flag"},
837                 {"2A03", "Reconnection Address"},
838                 {"2A04", "Peripheral Preferred Connection Parameters"},
839                 {"2A05", "Service Changed"},
840                 {"2A06", "Alert Level"},
841                 {"2A07", "Tx Power Level"},
842                 {"2A08", "Date Time"},
843                 {"2A09", "Day of Week"},
844                 {"2A0A", "Day Date Time"},
845                 {"2A11", "Time with DST"},
846                 {"2A12", "Time Accuracy"},
847                 {"2A13", "Time Source"},
848                 {"2A14", "Reference Time Information"},
849                 {"2A16", "Time Update Control Point"},
850                 {"2A17", "Time Update State"},
851                 {"2A18", "Glucose Measurement"},
852                 {"2A19", "Battery Level"},
853                 {"2A1C", "Temperature Measurement"},
854                 {"2A1D", "Temperature Type"},
855                 {"2A1E", "Intermediate Temperature"},
856                 {"2A21", "Measurement Interval"},
857                 {"2A23", "System ID"},
858                 {"2A24", "Model Number String"},
859                 {"2A25", "Serial Number String"},
860                 {"2A26", "Firmware Revision String"},
861                 {"2A27", "Hardware Revision String"},
862                 {"2A28", "Software Revision String"},
863                 {"2A29", "Manufacturer Name String"},
864                 {"2A2A", "IEEE 11073-20601 Regulatory Certification Data List"},
865                 {"2A2B", "Current Time"},
866                 {"2A34", "Glucose Measurement Context"},
867                 {"2A35", "Blood Pressure Measurement"},
868                 {"2A37", "Heart Rate Measurement"},
869                 {"2A38", "Body Sensor Location"},
870                 {"2A39", "Heart Rate Control Point"},
871                 {"2A3F", "Alert Status"},
872                 {"2A46", "New Alert"},
873                 {"2A49", "Blood Pressure Feature"},
874                 {"2A4A", "HID Information"},
875                 {"2A4C", "HID Control Point"},
876                 {"2A50", "PnP ID"},
877                 {"2A51", "Glucose Feature"},
878                 {"2A52", "Record Access Control Point"},
879                 {"2A53", "RSC Measurement"},
880                 {"2A54", "RSC Feature"},
881                 {"2A55", "SC Control Point"},
882                 {"2A56", "Digital"},
883                 {"2A58", "Analog"},
884                 {"2A5A", "Aggregate"},
885                 {"2A5B", "CSC Measurement"},
886                 {"2A5C", "CSC Feature"},
887                 {"2A5D", "Sensor Location"},
888                 {"2A63", "Cycling Power Measurement"},
889                 {"2A64", "Cycling Power Vector"},
890                 {"2A65", "Cycling Power Feature"},
891                 {"2A66", "Cycling Power Control Point"},
892                 {"2A67", "Location and Speed"},
893                 {"2A68", "Navigation"},
894                 {"2A6D", "Pressure"},
895                 {"2A6E", "Temperature"},
896                 {"2A8E", "Height"},
897                 {"2A90", "Last Name"},
898                 {"2A91", "Maximum Recommended Heart Rate"},
899                 {"2A92", "Resting Heart Rate"},
900                 {"2A98", "Weight"},
901                 {"2A9B", "Body Composition Feature"},
902                 {"2A9C", "Body Composition Measurement"},
903                 {"2A9D", "Weight Measurement"},
904                 {"2AA2", "Language"},
905                 {"2AA4", "Bond Management Control Point"},
906                 {"2AA5", "Bond Management Features"},
907                 {"2AA6", "Central Address Resolution"},
908                 {"2AAD", "Indoor Positioning Configuration"},
909                 {"2AB5", "Location Name"},
910                 {"2AB6", "URI"},
911                 {"2ABC", "TDS Control Point"},
912                 {"2AC9", "Resolvable Private Address Only"},
913                 {"2ACC", "Fitness Machine Feature"},
914                 {"2ACE", "Cross Trainer Data"},
915                 {"2AD3", "Training Status"},
916                 {"2AD7", "Supported Heart Rate Range"},
917                 {"2AD9", "Fitness Machine Control Point"},
918                 {"2ADA", "Fitness Machine Status"},
919                 {"2B1D", "RC Feature"},
920                 {"2B1E", "RC Settings"},
921                 {"2B1F", "Reconnection Configuration Control Point"},
922         };
923         static uuid_name_s long_uuid_name[LONG_UUID_COUNT] = {
924                 // List should be sorted by UUID
925                 /* Custom uuids */
926                 {"1AB7C24D-185A-45B9-90D4-F7AB1A71949A", "Samsung Health Service"},
927                 {"22EAC6E9-24D6-4BB5-BE44-B36ACE7C7BFB", "Data Source"},
928                 {"2F7CABCE-808D-411F-9A0C-BB92BA96C102", "Entity Update"},
929                 {"32D1955A-E5AA-4A96-9A49-08538DA8B8F6", "Samsung Gear Fit Manager Service"},
930                 {"69D1D8F3-45E1-49A8-9821-9BBDFDAAD9D9", "Control Point"},
931                 {"7905F431-B5CE-4E99-A40F-4B1E122D00D0", "Apple Notification Center Service"},
932                 {"89D3502B-0F36-433A-8EF4-C502AD55F8DC", "Apple Media Service"},
933                 {"9A3F68E0-86CE-11E5-A309-0002A5D5C51B", "Samsung Gear Manager Service"},
934                 {"9B3C81D8-57B1-4A8A-B8DF-0E56F7CA51C2", "Remote Command"},
935                 {"9FBF120D-6301-42D9-8C58-25E699A21DBD", "Notifications Source"},
936                 {"A49EB41E-CB06-495C-9F4F-BB80A90CDF00", "Samsung Gear Manager Service"},
937                 {"ADE3D529-C784-4F63-A987-EB69F70EE816", "IoT OIC Service"},
938                 {"C2051EE0-804D-4D50-A12C-15E243852100", "Notifications Source"},
939                 {"C2F2CC0F-C085-4DD4-BE5A-ACA3074BBC72", "Control Point"},
940                 {"C6B2F38C-23AB-46D8-A6AB-A3A870BBD5D7", "Entity Attribute"},
941                 {"CECE518B-28D7-4171-92D5-76A1E249A3B9", "Notifications Source"},
942                 {"FE53FF98-B259-4337-B56A-0EC9F82C6BAD", "Control Point"},
943         };
944         const uuid_name_s *uuid_name = short_uuid_name;
945         static const char *unknown_name = "Unknown";
946         int start = 0;
947         int end = SHORT_UUID_COUNT - 1;
948         int p;
949         int ret;
950
951         if (strlen(uuid) == 36) {
952                 if (!g_ascii_strncasecmp(uuid + 9, "0000-1000-8000-00805F9B34FB", 27))
953                         offset = 4;
954                 else {
955                         offset = 0;
956                         uuid_len = 36;
957                         end = LONG_UUID_COUNT - 1;
958                         uuid_name = long_uuid_name;
959                 }
960         } else if (strlen(uuid) >= 8)
961                 offset = 4;
962
963         while (start <= end) {
964                 p = start + (end - start) / 2;
965                 ret = g_ascii_strncasecmp(uuid + offset, uuid_name[p].uuid, uuid_len);
966                 if (ret == 0)
967                         return uuid_name[p].specification_name;
968                 else if (ret < 0)
969                         end = p - 1;
970                 else
971                         start = p + 1;
972         }
973
974         return unknown_name;
975 }
976
977 const char *_bt_convert_error_to_string(int error)
978 {
979         switch (error) {
980         case BLUETOOTH_ERROR_CANCEL:
981                 return "CANCELLED";
982         case BLUETOOTH_ERROR_INVALID_PARAM:
983                 return "INVALID_PARAMETER";
984         case BLUETOOTH_ERROR_INVALID_DATA:
985                 return "INVALID DATA";
986         case BLUETOOTH_ERROR_MEMORY_ALLOCATION:
987         case BLUETOOTH_ERROR_OUT_OF_MEMORY:
988                 return "OUT_OF_MEMORY";
989         case BLUETOOTH_ERROR_TIMEOUT:
990                 return "TIMEOUT";
991         case BLUETOOTH_ERROR_NO_RESOURCES:
992                 return "NO_RESOURCES";
993         case BLUETOOTH_ERROR_INTERNAL:
994                 return "INTERNAL";
995         case BLUETOOTH_ERROR_NOT_SUPPORT:
996                 return "NOT_SUPPORT";
997         case BLUETOOTH_ERROR_DEVICE_NOT_ENABLED:
998                 return "NOT_ENABLED";
999         case BLUETOOTH_ERROR_DEVICE_ALREADY_ENABLED:
1000                 return "ALREADY_ENABLED";
1001         case BLUETOOTH_ERROR_DEVICE_BUSY:
1002                 return "DEVICE_BUSY";
1003         case BLUETOOTH_ERROR_ACCESS_DENIED:
1004                 return "ACCESS_DENIED";
1005         case BLUETOOTH_ERROR_MAX_CLIENT:
1006                 return "MAX_CLIENT";
1007         case BLUETOOTH_ERROR_NOT_FOUND:
1008                 return "NOT_FOUND";
1009         case BLUETOOTH_ERROR_SERVICE_SEARCH_ERROR:
1010                 return "SERVICE_SEARCH_ERROR";
1011         case BLUETOOTH_ERROR_PARING_FAILED:
1012                 return "PARING_FAILED";
1013         case BLUETOOTH_ERROR_NOT_PAIRED:
1014                 return "NOT_PAIRED";
1015         case BLUETOOTH_ERROR_SERVICE_NOT_FOUND:
1016                 return "SERVICE_NOT_FOUND";
1017         case BLUETOOTH_ERROR_NOT_CONNECTED:
1018                 return "NOT_CONNECTED";
1019         case BLUETOOTH_ERROR_ALREADY_CONNECT:
1020                 return "ALREADY_CONNECT";
1021         case BLUETOOTH_ERROR_CONNECTION_BUSY:
1022                 return "CONNECTION_BUSY";
1023         case BLUETOOTH_ERROR_CONNECTION_ERROR:
1024                 return "CONNECTION_ERROR";
1025         case BLUETOOTH_ERROR_MAX_CONNECTION:
1026                 return "MAX_CONNECTION";
1027         case BLUETOOTH_ERROR_NOT_IN_OPERATION:
1028                 return "NOT_IN_OPERATION";
1029         case BLUETOOTH_ERROR_CANCEL_BY_USER:
1030                 return "CANCEL_BY_USER";
1031         case BLUETOOTH_ERROR_REGISTRATION_FAILED:
1032                 return "REGISTRATION_FAILED";
1033         case BLUETOOTH_ERROR_IN_PROGRESS:
1034                 return "IN_PROGRESS";
1035         case BLUETOOTH_ERROR_AUTHENTICATION_FAILED:
1036                 return "AUTHENTICATION_FAILED";
1037         case BLUETOOTH_ERROR_HOST_DOWN:
1038                 return "HOST_DOWN";
1039         case BLUETOOTH_ERROR_END_OF_DEVICE_LIST:
1040                 return "END_OF_DEVICE_LIST";
1041         case BLUETOOTH_ERROR_AGENT_ALREADY_EXIST:
1042                 return "AGENT_ALREADY_EXIST";
1043         case BLUETOOTH_ERROR_AGENT_DOES_NOT_EXIST:
1044                 return "AGENT_DOES_NOT_EXIST";
1045         case BLUETOOTH_ERROR_ALREADY_INITIALIZED:
1046                 return "ALREADY_INITIALIZED";
1047         case BLUETOOTH_ERROR_PERMISSION_DEINED:
1048                 return "PERMISSION_DEINED";
1049         case BLUETOOTH_ERROR_ALREADY_DEACTIVATED:
1050                 return "ALREADY_DEACTIVATED";
1051         case BLUETOOTH_ERROR_NOT_INITIALIZED:
1052                 return "NOT_INITIALIZED";
1053         case BLUETOOTH_ERROR_AUTHENTICATION_REJECTED:
1054                 return "AUTHENTICATION REJECTED";
1055         case BLUETOOTH_ERROR_AUTHORIZATION_REJECTED:
1056                 return "AUTHORIZATION REJECTED";
1057         default:
1058                 return "UNKNOWN";
1059         }
1060 }
1061
1062 const char *_bt_convert_disc_reason_to_string(int reason)
1063 {
1064         switch (reason) {
1065         case (int)BLUETOOTH_ERROR_PAGE_TIMEOUT:
1066                 return "Page timeout";
1067         case (int)BLUETOOTH_ERROR_AUTH_FAILURE:
1068                 return "Authentication Failure";
1069         case (int)BLUETOOTH_ERROR_PIN_OR_KEY_MISSING:
1070                 return "PIN or Key missing";
1071         case (int)BLUETOOTH_ERROR_CONNECTION_TIMEOUT:
1072                 return "Link loss";
1073         case (int)BLUETOOTH_ERROR_CONNECTION_REJECTED_DUE_TO_SECURITY_REASONS:
1074                 return "Connection rejected due to security reasons";
1075         case (int)BLUETOOTH_ERROR_REMOTE_USER_TERM:
1076         case (int)BLUETOOTH_ERROR_REMOTE_LOW_RESOURCES:
1077         case (int)BLUETOOTH_ERROR_REMOTE_POWER_OFF:
1078                 return "Remote user terminated connection";
1079         case (int)BLUETOOTH_ERROR_LOCAL_HOST_TERM:
1080                 return "Connection terminated by local host";
1081         case (int)BLUETOOTH_ERROR_REPEATED_ATTEMPTS:
1082                 return "Repeated attempts";
1083         case (int)BLUETOOTH_ERROR_LMP_RESPONSE_TIMEOUT:
1084                 return "LMP response timeout";
1085         case (int)BLUETOOTH_ERROR_LMP_TRANSACTION_COLLISION:
1086                 return "LMP transaction collision";
1087         case (int)BLUETOOTH_ERROR_INSTANT_PASSED:
1088                 return "Instant passed";
1089         case (int)BLUETOOTH_ERROR_INSUFFICIENT_SECURITY:
1090                 return "Insufficient security";
1091         case (int)BLUETOOTH_ERROR_CONNECTION_TERMINATED_DUE_TO_MIC_FAILURE:
1092                 return "Connection terminated due to MIC failure";
1093         case (int)BLUETOOTH_ERROR_CONNECTION_FAILED_TO_BE_ESTABLISHED:
1094                 return "Connection failed to be established";
1095         default:
1096                 return "Unknown";
1097         }
1098 }
1099
1100 const char *_bt_convert_profile_state_to_string(bt_profile_state_t state)
1101 {
1102         switch (state) {
1103         case BT_PROFILE_STATE_UNAVAILABLE:
1104                 return "UNAVAILABLE";
1105         case BT_PROFILE_STATE_DISCONNECTED:
1106                 return "DISCONNECTED";
1107         case BT_PROFILE_STATE_CONNECTING:
1108                 return "CONNECTING";
1109         case BT_PROFILE_STATE_CONNECTED:
1110                 return "CONNECTED";
1111         case BT_PROFILE_STATE_DISCONNECTING:
1112                 return "DISCONNECTING";
1113         }
1114
1115         return NULL;
1116 }
1117
1118 const char *_bt_convert_service_function_to_string(int function)
1119 {
1120         int i;
1121
1122         typedef struct {
1123                 int function;
1124                 const char *function_name;
1125         } bt_function_name_t;
1126
1127         const bt_function_name_t bt_functions[] = {
1128                 {BT_CHECK_ADAPTER, "BT_CHECK_ADAPTER"},
1129                 {BT_ENABLE_ADAPTER, "BT_ENABLE_ADAPTER"},
1130                 {BT_DISABLE_ADAPTER, "BT_DISABLE_ADAPTER"},
1131                 {BT_RECOVER_ADAPTER, "BT_RECOVER_ADAPTER"},
1132                 {BT_SET_DISCOVERABLE_TIME, "BT_SET_DISCOVERABLE_TIME"},
1133                 {BT_GET_DISCOVERABLE_TIME, "BT_GET_DISCOVERABLE_TIME"},
1134                 {BT_IGNORE_AUTO_PAIRING, "BT_IGNORE_AUTO_PAIRING"},
1135                 {BT_GET_LOCAL_ADDRESS, "BT_GET_LOCAL_ADDRESS"},
1136                 {BT_GET_LOCAL_VERSION, "BT_GET_LOCAL_VERSION"},
1137                 {BT_GET_LOCAL_NAME, "BT_GET_LOCAL_NAME"},
1138                 {BT_SET_LOCAL_NAME, "BT_SET_LOCAL_NAME"},
1139                 {BT_IS_SERVICE_USED, "BT_IS_SERVICE_USED"},
1140                 {BT_GET_DISCOVERABLE_MODE, "BT_GET_DISCOVERABLE_MODE"},
1141                 {BT_SET_DISCOVERABLE_MODE, "BT_SET_DISCOVERABLE_MODE"},
1142                 {BT_START_DISCOVERY, "BT_START_DISCOVERY"},
1143                 {BT_START_CUSTOM_DISCOVERY, "BT_START_CUSTOM_DISCOVERY"},
1144                 {BT_CANCEL_DISCOVERY, "BT_CANCEL_DISCOVERY"},
1145                 {BT_START_LE_DISCOVERY, "BT_START_LE_DISCOVERY"},
1146                 {BT_STOP_LE_DISCOVERY, "BT_STOP_LE_DISCOVERY"},
1147                 {BT_IS_DISCOVERYING, "BT_IS_DISCOVERYING"},
1148                 {BT_IS_LE_DISCOVERYING, "BT_IS_LE_DISCOVERYING"},
1149                 {BT_ENABLE_RSSI, "BT_ENABLE_RSSI"},
1150                 {BT_GET_RSSI, "BT_GET_RSSI"},
1151                 {BT_IS_CONNECTABLE, "BT_IS_CONNECTABLE"},
1152                 {BT_SET_CONNECTABLE, "BT_SET_CONNECTABLE"},
1153                 {BT_GET_BONDED_DEVICES, "BT_GET_BONDED_DEVICES"},
1154                 {BT_RESET_ADAPTER, "BT_RESET_ADAPTER"},
1155                 {BT_SET_ADVERTISING, "BT_SET_ADVERTISING"},
1156                 {BT_SET_CUSTOM_ADVERTISING, "BT_SET_CUSTOM_ADVERTISING"},
1157                 {BT_SET_ADVERTISING_PARAMETERS, "BT_SET_ADVERTISING_PARAMETERS"},
1158                 {BT_GET_ADVERTISING_DATA, "BT_GET_ADVERTISING_DATA"},
1159                 {BT_SET_ADVERTISING_DATA, "BT_SET_ADVERTISING_DATA"},
1160                 {BT_SET_SCAN_PARAMETERS, "BT_SET_SCAN_PARAMETERS"},
1161                 {BT_GET_SCAN_RESPONSE_DATA, "BT_GET_SCAN_RESPONSE_DATA"},
1162                 {BT_SET_SCAN_RESPONSE_DATA, "BT_SET_SCAN_RESPONSE_DATA"},
1163                 {BT_IS_ADVERTISING, "BT_IS_ADVERTISING"},
1164                 {BT_SET_MANUFACTURER_DATA, "BT_SET_MANUFACTURER_DATA"},
1165                 {BT_LE_CONN_UPDATE, "BT_LE_CONN_UPDATE"},
1166                 {BT_LE_READ_MAXIMUM_DATA_LENGTH, "BT_LE_READ_MAXIMUM_DATA_LENGTH"},
1167                 {BT_LE_WRITE_HOST_SUGGESTED_DATA_LENGTH, "BT_LE_WRITE_HOST_SUGGESTED_DATA_LENGTH"},
1168                 {BT_LE_READ_HOST_SUGGESTED_DATA_LENGTH, "BT_LE_READ_HOST_SUGGESTED_DATA_LENGTH"},
1169                 {BT_LE_SET_DATA_LENGTH, "BT_LE_SET_DATA_LENGTH"},
1170                 {BT_ADD_WHITE_LIST, "BT_ADD_WHITE_LIST"},
1171                 {BT_REMOVE_WHITE_LIST, "BT_REMOVE_WHITE_LIST"},
1172                 {BT_CLEAR_WHITE_LIST, "BT_CLEAR_WHITE_LIST"},
1173                 {BT_REGISTER_SCAN_FILTER, "BT_REGISTER_SCAN_FILTER"},
1174                 {BT_UNREGISTER_SCAN_FILTER, "BT_UNREGISTER_SCAN_FILTER"},
1175                 {BT_UNREGISTER_ALL_SCAN_FILTERS, "BT_UNREGISTER_ALL_SCAN_FILTERS"},
1176                 {BT_IS_SCAN_FILTER_SUPPORTED, "BT_IS_SCAN_FILTER_SUPPORTED"},
1177                 {BT_GET_PROFILE_CONNECTED_DEVICES, "BT_GET_PROFILE_CONNECTED_DEVICES"},
1178                 {BT_ENABLE_FORCE_HCI_DUMP, "BT_ENABLE_FORCE_HCI_DUMP"},
1179                 {BT_SET_PASSKEY_NOTIFICATION, "BT_SET_PASSKEY_NOTIFICATION"},
1180                 {BT_DISCONNECT_DEVICE, "BT_DISCONNECT_DEVICE"},
1181                 {BT_BOND_DEVICE, "BT_BOND_DEVICE"},
1182                 {BT_BOND_DEVICE_BY_TYPE, "BT_BOND_DEVICE_BY_TYPE"},
1183                 {BT_CANCEL_BONDING, "BT_CANCEL_BONDING"},
1184                 {BT_PASSKEY_REPLY, "BT_PASSKEY_REPLY"},
1185                 {BT_PASSKEY_CONFIRMATION_REPLY, "BT_PASSKEY_CONFIRMATION_REPLY"},
1186                 {BT_UNBOND_DEVICE, "BT_UNBOND_DEVICE"},
1187                 {BT_SEARCH_SERVICE, "BT_SEARCH_SERVICE"},
1188                 {BT_CANCEL_SEARCH_SERVICE, "BT_CANCEL_SEARCH_SERVICE"},
1189                 {BT_GET_BONDED_DEVICE, "BT_GET_BONDED_DEVICE"},
1190                 {BT_GET_IS_ALIAS_SET, "BT_GET_IS_ALIAS_SET"},
1191                 {BT_SET_ALIAS, "BT_SET_ALIAS"},
1192                 {BT_SET_AUTHORIZATION, "BT_SET_AUTHORIZATION"},
1193                 {BT_UNSET_AUTHORIZATION, "BT_UNSET_AUTHORIZATION"},
1194                 {BT_IS_DEVICE_CONNECTED, "BT_IS_DEVICE_CONNECTED"},
1195                 {BT_GET_CONNECTED_LINK_TYPE, "BT_GET_CONNECTED_LINK_TYPE"},
1196                 {BT_SET_PIN_CODE, "BT_SET_PIN_CODE"},
1197                 {BT_UNSET_PIN_CODE, "BT_UNSET_PIN_CODE"},
1198                 {BT_UPDATE_LE_CONNECTION_MODE, "BT_UPDATE_LE_CONNECTION_MODE"},
1199                 {BT_SET_PROFILE_TRUSTED, "BT_SET_PROFILE_TRUSTED"},
1200                 {BT_GET_PROFILE_TRUSTED, "BT_GET_PROFILE_TRUSTED"},
1201                 {BT_HID_CONNECT, "BT_HID_CONNECT"},
1202                 {BT_HID_DISCONNECT, "BT_HID_DISCONNECT"},
1203                 {BT_HID_DEVICE_ACTIVATE, "BT_HID_DEVICE_ACTIVATE"},
1204                 {BT_HID_DEVICE_DEACTIVATE, "BT_HID_DEVICE_DEACTIVATE"},
1205                 {BT_HID_DEVICE_CONNECT, "BT_HID_DEVICE_CONNECT"},
1206                 {BT_HID_DEVICE_DISCONNECT, "BT_HID_DEVICE_DISCONNECT"},
1207                 {BT_HID_DEVICE_SEND_MOUSE_EVENT, "BT_HID_DEVICE_SEND_MOUSE_EVENT"},
1208                 {BT_HID_DEVICE_SEND_KEY_EVENT, "BT_HID_DEVICE_SEND_KEY_EVENT"},
1209                 {BT_HID_DEVICE_SEND_CUSTOM_EVENT, "BT_HID_DEVICE_SEND_CUSTOM_EVENT"},
1210                 {BT_HID_DEVICE_SEND_REPLY_TO_REPORT, "BT_HID_DEVICE_SEND_REPLY_TO_REPORT"},
1211                 {BT_HID_ENABLE_BARCODE_FEATURE, "BT_HID_ENABLE_BARCODE_FEATURE"},
1212                 {BT_NETWORK_ACTIVATE, "BT_NETWORK_ACTIVATE"},
1213                 {BT_NETWORK_DEACTIVATE, "BT_NETWORK_DEACTIVATE"},
1214                 {BT_NETWORK_CONNECT, "BT_NETWORK_CONNECT"},
1215                 {BT_NETWORK_DISCONNECT, "BT_NETWORK_DISCONNECT"},
1216                 {BT_NETWORK_SERVER_DISCONNECT, "BT_NETWORK_SERVER_DISCONNECT"},
1217                 {BT_AUDIO_CONNECT, "BT_AUDIO_CONNECT"},
1218                 {BT_AUDIO_DISCONNECT, "BT_AUDIO_DISCONNECT"},
1219                 {BT_AG_CONNECT, "BT_AG_CONNECT"},
1220                 {BT_AG_DISCONNECT, "BT_AG_DISCONNECT"},
1221                 {BT_AV_CONNECT, "BT_AV_CONNECT"},
1222                 {BT_AV_DISCONNECT, "BT_AV_DISCONNECT"},
1223                 {BT_AV_SOURCE_CONNECT, "BT_AV_SOURCE_CONNECT"},
1224                 {BT_AV_SOURCE_DISCONNECT, "BT_AV_SOURCE_DISCONNECT"},
1225                 {BT_HF_CONNECT, "BT_HF_CONNECT"},
1226                 {BT_HF_DISCONNECT, "BT_HF_DISCONNECT"},
1227                 {BT_GET_SPEAKER_GAIN, "BT_GET_SPEAKER_GAIN"},
1228                 {BT_SET_SPEAKER_GAIN, "BT_SET_SPEAKER_GAIN"},
1229                 {BT_SET_CONTENT_PROTECT, "BT_SET_CONTENT_PROTECT"},
1230                 {BT_OOB_READ_LOCAL_DATA, "BT_OOB_READ_LOCAL_DATA"},
1231                 {BT_OOB_ADD_REMOTE_DATA, "BT_OOB_ADD_REMOTE_DATA"},
1232                 {BT_OOB_REMOVE_REMOTE_DATA, "BT_OOB_REMOVE_REMOTE_DATA"},
1233                 {BT_AVRCP_SET_TRACK_INFO, "BT_AVRCP_SET_TRACK_INFO"},
1234                 {BT_AVRCP_SET_PROPERTY, "BT_AVRCP_SET_PROPERTY"},
1235                 {BT_AVRCP_SET_PROPERTIES, "BT_AVRCP_SET_PROPERTIES"},
1236                 {BT_AVRCP_CONTROL_CONNECT, "BT_AVRCP_CONTROL_CONNECT"},
1237                 {BT_AVRCP_CONTROL_DISCONNECT, "BT_AVRCP_CONTROL_DISCONNECT"},
1238                 {BT_AVRCP_TARGET_CONNECT, "BT_AVRCP_TARGET_CONNECT"},
1239                 {BT_AVRCP_TARGET_DISCONNECT, "BT_AVRCP_TARGET_DISCONNECT"},
1240                 {BT_AVRCP_HANDLE_CONTROL, "BT_AVRCP_HANDLE_CONTROL"},
1241                 {BT_AVRCP_CONTROL_SET_PROPERTY, "BT_AVRCP_CONTROL_SET_PROPERTY"},
1242                 {BT_AVRCP_CONTROL_GET_PROPERTY, "BT_AVRCP_CONTROL_GET_PROPERTY"},
1243                 {BT_AVRCP_GET_TRACK_INFO, "BT_AVRCP_GET_TRACK_INFO"},
1244                 {BT_OPP_PUSH_FILES, "BT_OPP_PUSH_FILES"},
1245                 {BT_OPP_CANCEL_PUSH, "BT_OBT_OPP_IS_PUSHING_FILESPP_CANCEL_PUSH"},
1246                 {BT_OPP_IS_PUSHING_FILES, "BT_OPP_IS_PUSHING_FILES"},
1247                 {BT_OPP_GET_TRANSFER_PROGRESS, "BT_OPP_GET_TRANSFER_PROGRESS"},
1248                 {BT_MAP_CREATE_SESSION, "BT_MAP_CREATE_SESSION"},
1249                 {BT_MAP_DESTROY_SESSION, "BT_MAP_DESTROY_SESSION"},
1250                 {BT_MAP_SET_FOLDER, "BT_MAP_SET_FOLDER"},
1251                 {BT_MAP_LIST_FOLDERS, "BT_MAP_LIST_FOLDERS"},
1252                 {BT_MAP_LIST_FILTER_FIELDS, "BT_MAP_LIST_FILTER_FIELDS"},
1253                 {BT_MAP_LIST_MESSAGES, "BT_MAP_LIST_MESSAGES"},
1254                 {BT_MAP_UPDATE_INBOX, "BT_MAP_UPDATE_INBOX"},
1255                 {BT_MAP_PUSH_MESSAGE, "BT_MAP_PUSH_MESSAGE"},
1256                 {BT_MAP_GET_MESSAGE, "BT_MAP_GET_MESSAGE"},
1257                 {BT_OBEX_SERVER_ALLOCATE, "BT_OBEX_SERVER_ALLOCATE"},
1258                 {BT_OBEX_SERVER_DEALLOCATE, "BT_OBEX_SERVER_DEALLOCATE"},
1259                 {BT_OBEX_SERVER_IS_ACTIVATED, "BT_OBEX_SERVER_IS_ACTIVATED"},
1260                 {BT_OBEX_SERVER_ACCEPT_CONNECTION, "BT_OBEX_SERVER_ACCEPT_CONNECTION"},
1261                 {BT_OBEX_SERVER_REJECT_CONNECTION, "BT_OBEX_SERVER_REJECT_CONNECTION"},
1262                 {BT_OBEX_SERVER_ACCEPT_FILE, "BT_OBEX_SERVER_ACCEPT_FILE"},
1263                 {BT_OBEX_SERVER_REJECT_FILE, "BT_OBEX_SERVER_REJECT_FILE"},
1264                 {BT_OBEX_SERVER_SET_PATH, "BT_OBEX_SERVER_SET_PATH"},
1265                 {BT_OBEX_SERVER_SET_ROOT, "BT_OBEX_SERVER_SET_ROOT"},
1266                 {BT_OBEX_SERVER_CANCEL_TRANSFER, "BT_OBEX_SERVER_CANCEL_TRANSFER"},
1267                 {BT_OBEX_SERVER_CANCEL_ALL_TRANSFERS, "BT_OBEX_SERVER_CANCEL_ALL_TRANSFERS"},
1268                 {BT_OBEX_SERVER_IS_RECEIVING, "BT_OBEX_SERVER_IS_RECEIVING"},
1269                 {BT_RFCOMM_CLIENT_CONNECT, "BT_RFCOMM_CLIENT_CONNECT"},
1270                 {BT_RFCOMM_CLIENT_CANCEL_CONNECT, "BT_RFCOMM_CLIENT_CANCEL_CONNECT"},
1271                 {BT_RFCOMM_CLIENT_IS_CONNECTED, "BT_RFCOMM_CLIENT_IS_CONNECTED"},
1272                 {BT_RFCOMM_SOCKET_DISCONNECT, "BT_RFCOMM_SOCKET_DISCONNECT"},
1273                 {BT_RFCOMM_SOCKET_WRITE, "BT_RFCOMM_SOCKET_WRITE"},
1274                 {BT_RFCOMM_CREATE_SOCKET, "BT_RFCOMM_CREATE_SOCKET"},
1275                 {BT_RFCOMM_REMOVE_SOCKET, "BT_RFCOMM_REMOVE_SOCKET"},
1276                 {BT_RFCOMM_LISTEN, "BT_RFCOMM_LISTEN"},
1277                 {BT_RFCOMM_IS_UUID_AVAILABLE, "BT_RFCOMM_IS_UUID_AVAILABLE"},
1278                 {BT_RFCOMM_ACCEPT_CONNECTION, "BT_RFCOMM_ACCEPT_CONNECTION"},
1279                 {BT_RFCOMM_REJECT_CONNECTION, "BT_RFCOMM_REJECT_CONNECTION"},
1280                 {BT_RFCOMM_CREATE_SOCKET_EX, "BT_RFCOMM_CREATE_SOCKET_EX"},
1281                 {BT_RFCOMM_REMOVE_SOCKET_EX, "BT_RFCOMM_REMOVE_SOCKET_EX"},
1282                 {BT_PBAP_CONNECT, "BT_PBAP_CONNECT"},
1283                 {BT_PBAP_DISCONNECT, "BT_PBAP_DISCONNECT"},
1284                 {BT_PBAP_GET_PHONEBOOK_SIZE, "BT_PBAP_GET_PHONEBOOK_SIZE"},
1285                 {BT_PBAP_GET_PHONEBOOK, "BT_PBAP_GET_PHONEBOOK"},
1286                 {BT_PBAP_GET_LIST, "BT_PBAP_GET_LIST"},
1287                 {BT_PBAP_PULL_VCARD, "BT_PBAP_PULL_VCARD"},
1288                 {BT_PBAP_PHONEBOOK_SEARCH, "BT_PBAP_PHONEBOOK_SEARCH"},
1289                 {BT_ENABLE_ADAPTER_LE, "BT_ENABLE_ADAPTER_LE"},
1290                 {BT_DISABLE_ADAPTER_LE, "BT_DISABLE_ADAPTER_LE"},
1291                 {BT_CONNECT_LE, "BT_CONNECT_LE"},
1292                 {BT_DISCONNECT_LE, "BT_DISCONNECT_LE"},
1293                 {BT_SET_LE_PRIVACY, "BT_SET_LE_PRIVACY"},
1294                 {BT_REQ_ATT_MTU, "BT_REQ_ATT_MTU"},
1295                 {BT_GET_ATT_MTU, "BT_GET_ATT_MTU"},
1296                 {BT_GET_DEVICE_IDA, "BT_GET_DEVICE_IDA"},
1297                 {BT_SET_LE_STATIC_RANDOM_ADDRESS, "BT_SET_LE_STATIC_RANDOM_ADDRESS"},
1298                 {BT_HDP_CONNECT, "BT_HDP_CONNECT"},
1299                 {BT_HDP_DISCONNECT, "BT_HDP_DISCONNECT"},
1300                 {BT_HDP_SEND_DATA, "BT_HDP_SEND_DATA"},
1301                 {BT_HDP_REGISTER_SINK_APP, "BT_HDP_REGISTER_SINK_APP"},
1302                 {BT_HDP_UNREGISTER_SINK_APP, "BT_HDP_UNREGISTER_SINK_APP"},
1303                 {BT_GATT_GET_PRIMARY_SERVICES, "BT_GATT_GET_PRIMARY_SERVICES"},
1304                 {BT_GATT_DISCOVER_CHARACTERISTICS, "BT_GATT_DISCOVER_CHARACTERISTICS"},
1305                 {BT_GATT_SET_PROPERTY_REQUEST, "BT_GATT_SET_PROPERTY_REQUEST"},
1306                 {BT_GATT_READ_CHARACTERISTIC, "BT_GATT_READ_CHARACTERISTIC"},
1307                 {BT_GATT_DISCOVER_CHARACTERISTICS_DESCRIPTOR, "BT_GATT_DISCOVER_CHARACTERISTICS_DESCRIPTOR"},
1308                 {BT_GATT_REGISTER_APPLICATION, "BT_GATT_REGISTER_APPLICATION"},
1309                 {BT_GATT_REGISTER_SERVICE, "BT_GATT_REGISTER_SERVICE"},
1310                 {BT_GATT_SEND_RESPONSE, "BT_GATT_SEND_RESPONSE"},
1311                 {BT_LE_IPSP_INIT, "BT_LE_IPSP_INIT"},
1312                 {BT_LE_IPSP_DEINIT, "BT_LE_IPSP_DEINIT"},
1313                 {BT_LE_IPSP_CONNECT, "BT_LE_IPSP_CONNECT"},
1314                 {BT_LE_IPSP_DISCONNECT, "BT_LE_IPSP_DISCONNECT"},
1315                 {BT_DPM_SET_ALLOW_BT_MODE, "BT_DPM_SET_ALLOW_BT_MODE"},
1316                 {BT_DPM_GET_ALLOW_BT_MODE, "BT_DPM_GET_ALLOW_BT_MODE"},
1317                 {BT_DPM_SET_DEVICE_RESTRITION, "BT_DPM_SET_DEVICE_RESTRITION"},
1318                 {BT_DPM_GET_DEVICE_RESTRITION, "BT_DPM_GET_DEVICE_RESTRITION"},
1319                 {BT_DPM_SET_UUID_RESTRITION, "BT_DPM_SET_UUID_RESTRITION"},
1320                 {BT_DPM_GET_UUID_RESTRITION, "BT_DPM_GET_UUID_RESTRITION"},
1321                 {BT_DPM_ADD_DEVICES_BLACKLIST, "BT_DPM_ADD_DEVICES_BLACKLIST"},
1322                 {BT_DPM_ADD_DEVICES_WHITELIST, "BT_DPM_ADD_DEVICES_WHITELIST"},
1323                 {BT_DPM_ADD_UUIDS_BLACKLIST, "BT_DPM_ADD_UUIDS_BLACKLIST"},
1324                 {BT_DPM_ADD_UUIDS_WHITELIST, "BT_DPM_ADD_UUIDS_WHITELIST"},
1325                 {BT_DPM_CLEAR_DEVICES_BLACKLIST, "BT_DPM_CLEAR_DEVICES_BLACKLIST"},
1326                 {BT_DPM_CLEAR_DEVICES_WHITELIST, "BT_DPM_CLEAR_DEVICES_WHITELIST"},
1327                 {BT_DPM_CLEAR_UUIDS_BLACKLIST, "BT_DPM_CLEAR_UUIDS_BLACKLIST"},
1328                 {BT_DPM_CLEAR_UUIDS_WHITELIST, "BT_DPM_CLEAR_UUIDS_WHITELIST"},
1329                 {BT_DPM_REMOVE_DEVICE_BLACKLIST, "BT_DPM_REMOVE_DEVICE_BLACKLIST"},
1330                 {BT_DPM_REMOVE_DEVICE_WHITELIST, "BT_DPM_REMOVE_DEVICE_WHITELIST"},
1331                 {BT_DPM_REMOVE_UUID_BLACKLIST, "BT_DPM_REMOVE_UUID_BLACKLIST"},
1332                 {BT_DPM_REMOVE_UUID_WHITELIST, "BT_DPM_REMOVE_UUID_WHITELIST"},
1333                 {BT_DPM_GET_DEVICES_BLACKLIST, "BT_DPM_GET_DEVICES_BLACKLIST"},
1334                 {BT_DPM_GET_DEVICES_WHITELIST, "BT_DPM_GET_DEVICES_WHITELIST"},
1335                 {BT_DPM_GET_UUIDS_BLACKLIST, "BT_DPM_GET_UUIDS_BLACKLIST"},
1336                 {BT_DPM_GET_UUIDS_WHITELIST, "BT_DPM_GET_UUIDS_WHITELIST"},
1337                 {BT_DPM_SET_ALLOW_OUTGOING_CALL, "BT_DPM_SET_ALLOW_OUTGOING_CALL"},
1338                 {BT_DPM_GET_ALLOW_OUTGOING_CALL, "BT_DPM_GET_ALLOW_OUTGOING_CALL"},
1339                 {BT_DPM_SET_PAIRING_STATE, "BT_DPM_SET_PAIRING_STATE"},
1340                 {BT_DPM_GET_PAIRING_STATE, "BT_DPM_GET_PAIRING_STATE"},
1341                 {BT_DPM_SET_PROFILE_STATE, "BT_DPM_SET_PROFILE_STATE"},
1342                 {BT_DPM_GET_PROFILE_STATE, "BT_DPM_GET_PROFILE_STATE"},
1343                 {BT_DPM_SET_DESKROP_CONNECTIVITY_STATE, "BT_DPM_SET_DESKROP_CONNECTIVITY_STATE"},
1344                 {BT_DPM_GET_DESKROP_CONNECTIVITY_STATE, "BT_DPM_GET_DESKROP_CONNECTIVITY_STATE"},
1345                 {BT_DPM_SET_DISCOVERABLE_STATE, "BT_DPM_SET_DISCOVERABLE_STATE"},
1346                 {BT_DPM_GET_DISCOVERABLE_STATE, "BT_DPM_GET_DISCOVERABLE_STATE"},
1347                 {BT_DPM_SET_LIMITED_DISCOVERABLE_STATE, "BT_DPM_SET_LIMITED_DISCOVERABLE_STATE"},
1348                 {BT_DPM_GET_LIMITED_DISCOVERABLE_STATE, "BT_DPM_GET_LIMITED_DISCOVERABLE_STATE"},
1349                 {BT_DPM_SET_DATA_TRANSFER_STATE, "BT_DPM_SET_DATA_TRANSFER_STATE"},
1350                 {BT_DPM_GET_DATA_TRANSFER_STATE, "BT_DPM_GET_DATA_TRANSFER_STATE"},
1351                 {BT_PXP_MONITOR_SET_PROPERTY, "BT_PXP_MONITOR_SET_PROPERTY"},
1352                 {BT_PXP_MONITOR_GET_PROPERTY, "BT_PXP_MONITOR_GET_PROPERTY"},
1353                 {BT_PXP_MONITOR_GET_SUPPORTED_SERIVCES, "BT_PXP_MONITOR_GET_SUPPORTED_SERIVCES"},
1354                 {BT_PXP_REPORTER_REGISTER, "BT_PXP_REPORTER_REGISTER"},
1355                 {BT_PXP_REPORTER_UNREGISTER, "BT_PXP_REPORTER_UNREGISTER"},
1356                 {BT_PXP_REPORTER_GET_PROPERTY, "BT_PXP_REPORTER_GET_PROPERTY"},
1357                 {BT_TDS_PROVIDER_REGISTER, "BT_TDS_PROVIDER_REGISTER"},
1358                 {BT_TDS_PROVIDER_UNREGISTER, "BT_TDS_PROVIDER_UNREGISTER"},
1359                 {BT_TDS_PROVIDER_SET_MANUF_DATA, "BT_TDS_PROVIDER_SET_MANUF_DATA"},
1360                 {BT_TDS_PROVIDER_CREATE, "BT_TDS_PROVIDER_CREATE"},
1361                 {BT_TDS_PROVIDER_DESTROY, "BT_TDS_PROVIDER_DESTROY"},
1362                 {BT_TDS_PROVIDER_SET_TRANSPORT_DATA, "BT_TDS_PROVIDER_SET_TRANSPORT_DATA"},
1363                 {BT_TDS_SEND_ACTIVATION_RESPONSE, "BT_TDS_SEND_ACTIVATION_RESPONSE"},
1364                 {BT_TDS_READ_TRANSPORT_DATA, "BT_TDS_READ_TRANSPORT_DATA"},
1365                 {BT_TDS_ENABLE_CONTROL_POINT, "BT_TDS_ENABLE_CONTROL_POINT"},
1366                 {BT_TDS_ACTIVATE_CONTROL_POINT, "BT_TDS_ACTIVATE_CONTROL_POINT"},
1367                 {-1, ""},
1368         };
1369
1370         for (i = 0; bt_functions[i].function != -1; i++) {
1371                 if (bt_functions[i].function == function)
1372                         return bt_functions[i].function_name;
1373         }
1374
1375         return NULL;
1376 }
1377
1378 void _bt_logging_connection(gboolean connect, int addr_type)
1379 {
1380         static int le_conn = 0;
1381         static int le_disc = 0;
1382         static int edr_conn = 0;
1383         static int edr_disc = 0;
1384
1385         if (connect) {
1386                 if (addr_type)
1387                         le_conn++;
1388                 else
1389                         edr_conn++;
1390         } else {
1391                 if (addr_type)
1392                         le_disc++;
1393                 else
1394                         edr_disc++;
1395         }
1396
1397         BT_INFO("[PM] Number of LE conn: %d disc: %d, Number of BR/EDR conn: %d disc: %d",
1398                         le_conn, le_disc, edr_conn, edr_disc);
1399 }
1400
1401 void _bt_swap_byte_ordering(char *data, int data_len)
1402 {
1403         char temp;
1404         int i, j;
1405         int half = data_len / 2;
1406
1407         ret_if(data == NULL);
1408         /* Swap to opposite endian */
1409         for (i = 0, j = data_len - 1; i < half; i++, j--) {
1410                 temp = data[i];
1411                 data[i] = data[j];
1412                 data[j] = temp;
1413         }
1414 }
1415
1416 int _bt_byte_arr_cmp(const char *data1, const char *data2, int data_len)
1417 {
1418         int i;
1419
1420         retv_if(data1 == NULL, -1);
1421         retv_if(data2 == NULL, -1);
1422         for (i = 0; i < data_len; i++) {
1423                 if (data1[i] != data2[i])
1424                         return data1[i] - data2[i];
1425                 }
1426         return 0;
1427 }
1428 int _bt_byte_arr_cmp_with_mask(const char *data1, const char *data2,
1429         const char *mask, int data_len)
1430 {
1431         int i;
1432         char a, b;
1433
1434         retv_if(data1 == NULL, -1);
1435         retv_if(data2 == NULL, -1);
1436         retv_if(mask == NULL, -1);
1437         for (i = 0; i < data_len; i++) {
1438                 a = data1[i] & mask[i];
1439                 b = data2[i] & mask[i];
1440                 if (a != b)
1441                         return (int)(a - b);
1442                 }
1443         return 0;
1444 }
1445
1446 int _bt_eventsystem_set_value(const char *event, const char *key, const char *value)
1447 {
1448         int ret = ES_R_OK;
1449 /* Send event system event in bt-core process because bt-service's permission is not system in now */
1450
1451 #if 0
1452         bundle *b = NULL;
1453
1454         b = bundle_create();
1455
1456         bundle_add_str(b, key, value);
1457
1458         ret = eventsystem_send_system_event(event, b);
1459
1460         BT_DBG("eventsystem_send_system_event result: %d", ret);
1461
1462         bundle_free(b);
1463 #endif
1464         return ret;
1465 }
1466
1467 void __bt_get_auth_info(GVariant *reply, char *auth_info)
1468 {
1469         int cursor;
1470         GVariant *tmp_value;
1471         char *manufacturer_data = NULL;
1472         int manufacturer_data_len;
1473         gboolean is_alias_set;
1474         GVariantIter *value_iter;
1475         guint8 m_value;
1476         int i = 0;
1477
1478         tmp_value = g_variant_lookup_value(reply, "IsAliasSet",
1479                                                                 G_VARIANT_TYPE_BOOLEAN);
1480         if (tmp_value) {
1481                 is_alias_set = g_variant_get_boolean(tmp_value);
1482                 g_variant_unref(tmp_value);
1483         } else {
1484                 is_alias_set = FALSE;
1485         }
1486         if (is_alias_set == FALSE) {
1487                 tmp_value = g_variant_lookup_value(reply, "LegacyManufacturerDataLen",
1488                                                                 G_VARIANT_TYPE_UINT16);
1489                 if (tmp_value) {
1490                         manufacturer_data_len = g_variant_get_uint16(tmp_value);
1491                         if (manufacturer_data_len >
1492                                         BLUETOOTH_MANUFACTURER_DATA_LENGTH_MAX) {
1493                                 BT_ERR("manufacturer_data_len is too long");
1494                                 manufacturer_data_len = BLUETOOTH_MANUFACTURER_DATA_LENGTH_MAX;
1495                         }
1496                         g_variant_unref(tmp_value);
1497                 } else
1498                         manufacturer_data_len = 0;
1499
1500                 tmp_value = g_variant_lookup_value(reply, "LegacyManufacturerData",
1501                                                                 G_VARIANT_TYPE_ARRAY);
1502                 if (tmp_value) {
1503                         if ((manufacturer_data_len == 0) ||
1504                                         manufacturer_data_len != g_variant_get_size(tmp_value)) {
1505                                 BT_ERR("manufacturer data length doesn't match");
1506                                 manufacturer_data_len = 0;
1507                                 manufacturer_data = NULL;
1508                         } else {
1509                                 manufacturer_data = g_malloc0(manufacturer_data_len);
1510                                 g_variant_get(tmp_value, "ay", &value_iter);
1511                                 while (g_variant_iter_loop(value_iter, "y", &m_value))
1512                                         manufacturer_data[i++] = m_value;
1513                         }
1514                         g_variant_unref(tmp_value);
1515                 } else {
1516                         BT_INFO("manufacture data is not a G_VARIANT_TYPE_ARRAY ");
1517                         manufacturer_data_len = 0;
1518                         manufacturer_data = NULL;
1519                 }
1520                 /*minimum Size of the samsung specific manufacturer data is greater than 30 */
1521                 if (manufacturer_data_len < 30) {
1522                         g_free(manufacturer_data);
1523                         return;
1524                 }
1525                 if (manufacturer_data[0] != 0x00 || manufacturer_data[1] != 0x75) {
1526                         BT_DBG("This is not a samsung specific manufaturer data");
1527                         g_free(manufacturer_data);
1528                         return;
1529                 }
1530
1531                 /* 2  samsung (0x00 0x75) + 1 (control and version) + 1 (service ID) +
1532                 1 (discovery version) + 1 (associated service ID)
1533                 2 (Proxamity and locality) + 2 (Device type and icon) */
1534
1535                 cursor = 10;
1536
1537                 memcpy(auth_info, &(manufacturer_data[cursor]), 5);
1538         }
1539          g_free(manufacturer_data);
1540 }
1541
1542 int _bt_convert_gerror(GError *g_error)
1543 {
1544         int ret = BLUETOOTH_ERROR_INTERNAL;
1545         gchar *str;
1546
1547         if (!g_dbus_error_strip_remote_error(g_error))
1548                 return ret;
1549
1550         str = g_error->message;
1551
1552         if (g_strcmp0(str, "Connection refused") == 0)
1553                 ret = BLUETOOTH_ERROR_AUTHENTICATION_REJECTED;
1554         else if (g_strcmp0(str, "Connection timed out") == 0)
1555                 ret = BLUETOOTH_ERROR_TIMEOUT;
1556         else if (g_strcmp0(str, "In Progress") == 0)
1557                 ret = BLUETOOTH_ERROR_IN_PROGRESS;
1558
1559         return ret;
1560 }