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