Fix infinite callback issue in EOF status
[platform/core/connectivity/bluetooth-frwk.git] / bt-api / bt-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 <string.h>
19 #include <fcntl.h>
20 #include <unistd.h>
21 #include <sys/types.h>
22 #include <stdlib.h>
23 #include <sys/socket.h>
24 #include<stdio.h>
25
26 #include <gio/gunixfdlist.h>
27
28
29 #include "bluetooth-api.h"
30 #include "bluetooth-audio-api.h"
31 #include "bluetooth-hid-api.h"
32 #include "bluetooth-media-control.h"
33 #include "bt-internal-types.h"
34 #include "bluetooth-ipsp-api.h"
35
36 #ifndef GATT_DIRECT
37 #include "bluetooth-gatt-server-api.h"
38 #endif
39
40 #include "bluetooth-gatt-client-api.h"
41 #include "bluetooth-mesh-api.h"
42
43 #include "bt-common.h"
44 #include "bt-request-sender.h"
45 #include "bt-event-handler.h"
46 #include "bt-dpm.h"
47
48 static bt_user_info_t user_info[BT_MAX_USER_INFO];
49 static GDBusConnection *system_shared_conn = NULL;
50 static GDBusConnection *system_common_conn = NULL;
51
52 static guint bus_id;
53
54 static gboolean bt_enabled = FALSE;
55
56 #define DBUS_TIMEOUT 20 * 1000 /* 20 Seconds */
57
58 #if 0 // Remain this code for private connection in later.
59 static GDBusConnection *g_bus_get_private_conn(void)
60 {
61         GError *error = NULL;
62         char *address;
63         GDBusConnection *private_gconn = NULL;
64
65         address = g_dbus_address_get_for_bus_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
66         if (address == NULL) {
67                 if (error) {
68                         BT_ERR("Failed to get bus address: %s", error->message);
69                         g_clear_error(&error);
70                 }
71                 return NULL;
72         }
73
74         private_gconn = g_dbus_connection_new_for_address_sync(address,
75                                 G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_CLIENT |
76                                 G_DBUS_CONNECTION_FLAGS_MESSAGE_BUS_CONNECTION,
77                                 NULL, /* GDBusAuthObserver */
78                                 NULL,
79                                 &error);
80         g_free(address);
81         if (!private_gconn) {
82                 if (error) {
83                         BT_ERR("Unable to connect to dbus: %s", error->message);
84                         g_clear_error(&error);
85                 }
86                 return NULL;
87         }
88
89         return private_gconn;
90 }
91 #endif
92
93 // TODO: Need to use _bt_get_system_shared_conn in later.
94 GDBusConnection *_bt_get_system_common_conn(void)
95 {
96         if (system_common_conn == NULL) {
97                 GError *error = NULL;
98                 if (access(CONTAINER_FILE, F_OK) == 0)
99                         system_common_conn = g_dbus_connection_new_for_address_sync(
100                                         DBUS_HOST_SYSTEM_BUS_ADDRESS,
101                                         G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_CLIENT | G_DBUS_CONNECTION_FLAGS_MESSAGE_BUS_CONNECTION,
102                                         NULL, NULL, &error);
103                 else
104                         system_common_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
105                 if (error) {
106                         BT_ERR("GDBus connection Error : %s \n", error->message);
107                         g_clear_error(&error);
108                         return NULL;
109                 }
110         }
111         return system_common_conn;
112 }
113
114 GDBusConnection *_bt_get_system_shared_conn(void)
115 {
116         if (system_shared_conn == NULL) {
117                 GError *error = NULL;
118                 if (access(CONTAINER_FILE, F_OK) == 0)
119                         system_shared_conn = g_dbus_connection_new_for_address_sync(
120                                         DBUS_HOST_SYSTEM_BUS_ADDRESS,
121                                         G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_CLIENT | G_DBUS_CONNECTION_FLAGS_MESSAGE_BUS_CONNECTION,
122                                         NULL, NULL, &error);
123                 else
124                         system_shared_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
125                 if (error) {
126                         BT_ERR("GDBus connection Error : %s \n", error->message);
127                         g_clear_error(&error);
128                         return NULL;
129                 }
130         }
131         return system_shared_conn;
132 }
133
134 void _bt_print_device_address_t(const bluetooth_device_address_t *addr)
135 {
136         BT_DBG("%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X\n", addr->addr[0], addr->addr[1], addr->addr[2],
137                                 addr->addr[3], addr->addr[4], addr->addr[5]);
138 }
139
140 void _bt_set_user_data(int type, void *callback, void *user_data)
141 {
142         user_info[type].cb = callback;
143         user_info[type].user_data = user_data;
144 }
145
146 bt_user_info_t *_bt_get_user_data(int type)
147 {
148         return &user_info[type];
149 }
150
151 int _bt_common_send_rfcomm_rx_details(unsigned int len)
152 {
153         uid_t uid = getuid();
154         pid_t pid = getpid();
155         unsigned int size = len;
156         int ret = BLUETOOTH_ERROR_NONE;
157
158         BT_INFO("+");
159         BT_CHECK_ENABLED(return);
160         BT_INIT_PARAMS();
161         BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
162
163         g_array_append_vals(in_param1, &uid, sizeof(uid_t));
164         g_array_append_vals(in_param2, &pid, sizeof(pid_t));
165         g_array_append_vals(in_param3, &size, sizeof(unsigned int));
166
167         ret = _bt_send_request(BT_BLUEZ_SERVICE, BT_RFCOMM_SEND_RX_DETAILS,
168                 in_param1, in_param2, in_param3, in_param4, &out_param);
169
170         BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
171         BT_INFO("-");
172         return ret;
173 }
174
175 int _bt_common_send_rfcomm_tx_details(unsigned int len)
176 {
177         uid_t uid = getuid();
178         pid_t pid = getpid();
179         unsigned int size = len;
180         int ret = BLUETOOTH_ERROR_NONE;
181
182         BT_INFO("+");
183         BT_CHECK_ENABLED(return);
184         BT_INIT_PARAMS();
185         BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
186
187         g_array_append_vals(in_param1, &uid, sizeof(uid_t));
188         g_array_append_vals(in_param2, &pid, sizeof(pid_t));
189         g_array_append_vals(in_param3, &size, sizeof(unsigned int));
190
191         ret = _bt_send_request(BT_BLUEZ_SERVICE, BT_RFCOMM_SEND_TX_DETAILS,
192                 in_param1, in_param2, in_param3, in_param4, &out_param);
193
194         BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
195         BT_INFO("-");
196         return ret;
197 }
198
199 int _bt_common_send_rfcomm_conn_info(int role, gboolean connected, int socket_fd)
200 {
201         int result = BLUETOOTH_ERROR_NONE;
202
203         if (bluetooth_get_battery_monitor_state() == 0) {
204                 BT_DBG("Battery monitor state is off");
205                 return BLUETOOTH_ERROR_NONE;
206         }
207
208         BT_INIT_PARAMS();
209         BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
210
211         g_array_append_vals(in_param1, &role, sizeof(int));
212         g_array_append_vals(in_param2, &connected, sizeof(gboolean));
213         g_array_append_vals(in_param3, &socket_fd, sizeof(int));
214
215         result = _bt_send_request(BT_BLUEZ_SERVICE, BT_RFCOMM_UPDATE_CONNECTION_INFO,
216                 in_param1, in_param2, in_param3, in_param4, &out_param);
217
218         BT_DBG("result: %x", result);
219
220         BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
221
222         return result;
223 }
224
225 void _bt_common_event_cb(int event, int result, void *param,
226                                         void *callback, void *user_data)
227 {
228         bluetooth_event_param_t bt_event = { 0, };
229         bt_event.event = event;
230         bt_event.result = result;
231         bt_event.param_data = param;
232
233         if (callback)
234                 ((bluetooth_cb_func_ptr)callback)(bt_event.event, &bt_event,
235                                         user_data);
236 }
237
238 void _bt_input_event_cb(int event, int result, void *param,
239                                         void *callback, void *user_data)
240 {
241         hid_event_param_t bt_event = { 0, };
242         bt_event.event = event;
243         bt_event.result = result;
244         bt_event.param_data = param;
245
246         if (callback)
247                 ((hid_cb_func_ptr)callback)(bt_event.event, &bt_event,
248                                         user_data);
249 }
250
251 void _bt_headset_event_cb(int event, int result, void *param,
252                                         void *callback, void *user_data)
253 {
254         bt_audio_event_param_t bt_event = { 0, };
255         bt_event.event = event;
256         bt_event.result = result;
257         bt_event.param_data = param;
258
259         if (callback)
260                 ((bt_audio_func_ptr)callback)(bt_event.event, &bt_event,
261                                         user_data);
262 }
263
264 void _bt_a2dp_source_event_cb(int event, int result, void *param,
265                                         void *callback, void *user_data)
266 {
267         bt_audio_event_param_t bt_event = { 0, };
268         bt_event.event = event;
269         bt_event.result = result;
270         bt_event.param_data = param;
271         if (callback)
272                 ((bt_audio_func_ptr)callback)(bt_event.event, &bt_event,
273                                         user_data);
274 }
275
276 void _bt_hf_event_cb(int event, int result, void *param,
277                                         void *callback, void *user_data)
278 {
279         bt_hf_event_param_t bt_event = { 0, };
280         bt_event.event = event;
281         bt_event.result = result;
282         bt_event.param_data = param;
283
284         if (callback)
285                 ((bt_hf_func_ptr)callback)(bt_event.event, &bt_event,
286                                         user_data);
287 }
288
289
290 void _bt_avrcp_event_cb(int event, int result, void *param,
291                                         void *callback, void *user_data)
292 {
293         media_event_param_t bt_event = { 0, };
294         bt_event.event = event;
295         bt_event.result = result;
296         bt_event.param_data = param;
297
298         if (callback)
299                 ((media_cb_func_ptr)callback)(bt_event.event, &bt_event,
300                                         user_data);
301 }
302
303 void _bt_gatt_client_event_cb(int event, int result, void *param,
304                 void *callback, void *user_data)
305 {
306         BT_DBG("__bt_gatt_client_event_cb");
307         gatt_client_event_param_t bt_event = { 0, 0, NULL, NULL };
308         bt_event.event = event;
309         bt_event.result = result;
310         bt_event.param_data = param;
311         if (callback) {
312                 BT_DBG("GATT Client event callback is registered");
313                 ((gatt_client_cb_func_ptr)callback)(bt_event.event, &bt_event,
314                         user_data);
315         } else {
316                 BT_ERR("GATT Client event callback is not registered!!!");
317         }
318 }
319
320 #ifndef GATT_DIRECT
321 void _bt_gatt_server_event_cb(int event, int result, void *param,
322                 void *callback, void *user_data)
323 {
324         gatt_server_event_param_t bt_event = { 0, 0, NULL, NULL };
325         bt_event.event = event;
326         bt_event.result = result;
327         bt_event.param_data = param;
328         if (callback) {
329                 ((gatt_server_cb_func_ptr)callback)(bt_event.event, &bt_event,
330                         user_data);
331         } else {
332                 BT_ERR("GATT Server event callback is not registered!!!");
333         }
334 }
335 #endif
336
337 void _bt_mesh_event_cb(int event, int result, void *param,
338                 void *callback, void *user_data)
339 {
340         BT_DBG("_bt_mesh_event_cb");
341         mesh_event_param_t bt_event = { 0, 0, NULL, NULL };
342         bt_event.event = event;
343         bt_event.result = result;
344         bt_event.param_data = param;
345         if (callback) {
346                 BT_DBG("Mesh event callback is registered");
347                 ((mesh_cb_func_ptr)callback)(bt_event.event, &bt_event,
348                         user_data);
349         } else {
350                 BT_ERR("Mesh event callback is not registered!!!");
351         }
352 }
353
354 void _bt_divide_device_class(bluetooth_device_class_t *device_class,
355                                 unsigned int cod)
356 {
357         ret_if(device_class == NULL);
358
359         device_class->major_class = (unsigned short)(cod & 0x00001F00) >> 8;
360         device_class->minor_class = (unsigned short)((cod & 0x000000FC));
361         device_class->service_class = (unsigned long)((cod & 0x00FF0000));
362
363         if (cod & 0x002000) {
364                 device_class->service_class |=
365                 BLUETOOTH_DEVICE_SERVICE_CLASS_LIMITED_DISCOVERABLE_MODE;
366         }
367 }
368
369 void _bt_convert_addr_string_to_type(unsigned char *addr, const char *address)
370 {
371         int i;
372         char *ptr = NULL;
373
374         ret_if(address == NULL);
375         ret_if(addr == NULL);
376
377         for (i = 0; i < BT_ADDRESS_LENGTH_MAX; i++) {
378                 addr[i] = strtol(address, &ptr, 16);
379                 if (ptr[0] != '\0') {
380                         if (ptr[0] != ':')
381                                 return;
382
383                         address = ptr + 1;
384                 }
385         }
386 }
387
388 void  _bt_convert_uuid_type_to_string(char *str, const unsigned char *uuid)
389 {
390         if (!str) {
391                 BT_ERR("str == NULL");
392                 return;
393         }
394
395         if (!uuid) {
396                 BT_ERR("uuid == NULL");
397                 return;
398         }
399
400         snprintf(str, 37,
401                         "%2.2X%2.2X%2.2X%2.2X-%2.2X%2.2X-%2.2X%2.2X-%2.2X%2.2X-%2.2X%2.2X%2.2X%2.2X%2.2X%2.2X",
402                         uuid[0], uuid[1], uuid[2], uuid[3], uuid[4], uuid[5], uuid[6], uuid[7],
403                         uuid[8], uuid[9], uuid[10], uuid[11], uuid[12], uuid[13], uuid[14], uuid[15]);
404 }
405
406 void _bt_convert_addr_string_to_secure_string(char *addr, const char *address)
407 {
408         int len;
409
410         ret_if(address == NULL);
411         ret_if(addr == NULL);
412
413         len = strlen(address);
414         ret_if(len != BT_ADDRESS_STRING_SIZE - 1);
415
416         strncpy(addr, address, len);
417         addr[len] = '\0';
418
419         addr[len-7] = 'X';
420         addr[len-8] = 'X';
421         addr[len-10] = 'X';
422         addr[len-11] = 'X';
423         addr[len-13] = 'X';
424         addr[len-14] = 'X';
425         addr[len-16] = 'X';
426         addr[len-17] = 'X';
427
428         return;
429 }
430
431 void _bt_convert_addr_type_to_string(char *address, unsigned char *addr)
432 {
433         ret_if(address == NULL);
434         ret_if(addr == NULL);
435
436         g_snprintf(address, BT_ADDRESS_STRING_SIZE,
437                         "%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X",
438                         addr[0], addr[1], addr[2],
439                         addr[3], addr[4], addr[5]);
440 }
441
442 void _bt_convert_addr_type_to_secure_string(char *address, unsigned char *addr)
443 {
444         ret_if(address == NULL);
445         ret_if(addr == NULL);
446
447         g_snprintf(address, BT_ADDRESS_STRING_SIZE,
448                         "XX:XX:XX:XX:%2.2X:%2.2X", addr[4], addr[5]);
449 }
450
451 const char *_bt_convert_error_to_string(int error)
452 {
453         switch (error) {
454         case BLUETOOTH_ERROR_CANCEL:
455                 return "CANCELLED";
456         case BLUETOOTH_ERROR_INVALID_PARAM:
457                 return "INVALID_PARAMETER";
458         case BLUETOOTH_ERROR_INVALID_DATA:
459                 return "INVALID DATA";
460         case BLUETOOTH_ERROR_MEMORY_ALLOCATION:
461         case BLUETOOTH_ERROR_OUT_OF_MEMORY:
462                 return "OUT_OF_MEMORY";
463         case BLUETOOTH_ERROR_TIMEOUT:
464                 return "TIMEOUT";
465         case BLUETOOTH_ERROR_NO_RESOURCES:
466                 return "NO_RESOURCES";
467         case BLUETOOTH_ERROR_INTERNAL:
468                 return "INTERNAL";
469         case BLUETOOTH_ERROR_NOT_SUPPORT:
470                 return "NOT_SUPPORT";
471         case BLUETOOTH_ERROR_DEVICE_NOT_ENABLED:
472                 return "NOT_ENABLED";
473         case BLUETOOTH_ERROR_DEVICE_ALREADY_ENABLED:
474                 return "ALREADY_ENABLED";
475         case BLUETOOTH_ERROR_DEVICE_BUSY:
476                 return "DEVICE_BUSY";
477         case BLUETOOTH_ERROR_ACCESS_DENIED:
478                 return "ACCESS_DENIED";
479         case BLUETOOTH_ERROR_MAX_CLIENT:
480                 return "MAX_CLIENT";
481         case BLUETOOTH_ERROR_NOT_FOUND:
482                 return "NOT_FOUND";
483         case BLUETOOTH_ERROR_SERVICE_SEARCH_ERROR:
484                 return "SERVICE_SEARCH_ERROR";
485         case BLUETOOTH_ERROR_PARING_FAILED:
486                 return "PARING_FAILED";
487         case BLUETOOTH_ERROR_NOT_PAIRED:
488                 return "NOT_PAIRED";
489         case BLUETOOTH_ERROR_SERVICE_NOT_FOUND:
490                 return "SERVICE_NOT_FOUND";
491         case BLUETOOTH_ERROR_NOT_CONNECTED:
492                 return "NOT_CONNECTED";
493         case BLUETOOTH_ERROR_ALREADY_CONNECT:
494                 return "ALREADY_CONNECT";
495         case BLUETOOTH_ERROR_CONNECTION_BUSY:
496                 return "CONNECTION_BUSY";
497         case BLUETOOTH_ERROR_CONNECTION_ERROR:
498                 return "CONNECTION_ERROR";
499         case BLUETOOTH_ERROR_MAX_CONNECTION:
500                 return "MAX_CONNECTION";
501         case BLUETOOTH_ERROR_NOT_IN_OPERATION:
502                 return "NOT_IN_OPERATION";
503         case BLUETOOTH_ERROR_CANCEL_BY_USER:
504                 return "CANCEL_BY_USER";
505         case BLUETOOTH_ERROR_REGISTRATION_FAILED:
506                 return "REGISTRATION_FAILED";
507         case BLUETOOTH_ERROR_IN_PROGRESS:
508                 return "IN_PROGRESS";
509         case BLUETOOTH_ERROR_AUTHENTICATION_FAILED:
510                 return "AUTHENTICATION_FAILED";
511         case BLUETOOTH_ERROR_HOST_DOWN:
512                 return "HOST_DOWN";
513         case BLUETOOTH_ERROR_END_OF_DEVICE_LIST:
514                 return "END_OF_DEVICE_LIST";
515         case BLUETOOTH_ERROR_AGENT_ALREADY_EXIST:
516                 return "AGENT_ALREADY_EXIST";
517         case BLUETOOTH_ERROR_AGENT_DOES_NOT_EXIST:
518                 return "AGENT_DOES_NOT_EXIST";
519         case BLUETOOTH_ERROR_ALREADY_INITIALIZED:
520                 return "ALREADY_INITIALIZED";
521         case BLUETOOTH_ERROR_PERMISSION_DEINED:
522                 return "PERMISSION_DEINED";
523         case BLUETOOTH_ERROR_ALREADY_DEACTIVATED:
524                 return "ALREADY_DEACTIVATED";
525         case BLUETOOTH_ERROR_NOT_INITIALIZED:
526                 return "NOT_INITIALIZED";
527         case BLUETOOTH_ERROR_AUTHENTICATION_REJECTED:
528                 return "AUTHENTICATION REJECTED";
529         case BLUETOOTH_ERROR_AUTHORIZATION_REJECTED:
530                 return "AUTHORIZATION REJECTED";
531         default:
532                 return "UNKNOWN";
533         }
534 }
535
536 const char *_bt_convert_service_function_to_string(int function)
537 {
538         int i;
539
540         typedef struct {
541                 int function;
542                 const char *function_name;
543         } bt_function_name_t;
544
545         const bt_function_name_t bt_functions[] = {
546                 {BT_CHECK_ADAPTER, "BT_CHECK_ADAPTER"},
547                 {BT_ENABLE_ADAPTER, "BT_ENABLE_ADAPTER"},
548                 {BT_DISABLE_ADAPTER, "BT_DISABLE_ADAPTER"},
549                 {BT_RECOVER_ADAPTER, "BT_RECOVER_ADAPTER"},
550                 {BT_SET_DISCOVERABLE_TIME, "BT_SET_DISCOVERABLE_TIME"},
551                 {BT_GET_DISCOVERABLE_TIME, "BT_GET_DISCOVERABLE_TIME"},
552                 {BT_IGNORE_AUTO_PAIRING, "BT_IGNORE_AUTO_PAIRING"},
553                 {BT_GET_LOCAL_ADDRESS, "BT_GET_LOCAL_ADDRESS"},
554                 {BT_GET_LOCAL_VERSION, "BT_GET_LOCAL_VERSION"},
555                 {BT_GET_LOCAL_NAME, "BT_GET_LOCAL_NAME"},
556                 {BT_SET_LOCAL_NAME, "BT_SET_LOCAL_NAME"},
557                 {BT_IS_SERVICE_USED, "BT_IS_SERVICE_USED"},
558                 {BT_GET_DISCOVERABLE_MODE, "BT_GET_DISCOVERABLE_MODE"},
559                 {BT_SET_DISCOVERABLE_MODE, "BT_SET_DISCOVERABLE_MODE"},
560                 {BT_START_DISCOVERY, "BT_START_DISCOVERY"},
561                 {BT_START_CUSTOM_DISCOVERY, "BT_START_CUSTOM_DISCOVERY"},
562                 {BT_CANCEL_DISCOVERY, "BT_CANCEL_DISCOVERY"},
563                 {BT_START_LE_DISCOVERY, "BT_START_LE_DISCOVERY"},
564                 {BT_STOP_LE_DISCOVERY, "BT_STOP_LE_DISCOVERY"},
565                 {BT_IS_DISCOVERYING, "BT_IS_DISCOVERYING"},
566                 {BT_IS_LE_DISCOVERYING, "BT_IS_LE_DISCOVERYING"},
567                 {BT_ENABLE_RSSI, "BT_ENABLE_RSSI"},
568                 {BT_GET_RSSI, "BT_GET_RSSI"},
569                 {BT_IS_CONNECTABLE, "BT_IS_CONNECTABLE"},
570                 {BT_SET_CONNECTABLE, "BT_SET_CONNECTABLE"},
571                 {BT_GET_BONDED_DEVICES, "BT_GET_BONDED_DEVICES"},
572                 {BT_RESET_ADAPTER, "BT_RESET_ADAPTER"},
573                 {BT_SET_ADVERTISING, "BT_SET_ADVERTISING"},
574                 {BT_SET_CUSTOM_ADVERTISING, "BT_SET_CUSTOM_ADVERTISING"},
575                 {BT_SET_ADVERTISING_PARAMETERS, "BT_SET_ADVERTISING_PARAMETERS"},
576                 {BT_GET_ADVERTISING_DATA, "BT_GET_ADVERTISING_DATA"},
577                 {BT_SET_ADVERTISING_DATA, "BT_SET_ADVERTISING_DATA"},
578                 {BT_SET_SCAN_PARAMETERS, "BT_SET_SCAN_PARAMETERS"},
579                 {BT_SET_SCAN_TYPE, "BT_SET_SCAN_TYPE"},
580                 {BT_GET_SCAN_RESPONSE_DATA, "BT_GET_SCAN_RESPONSE_DATA"},
581                 {BT_SET_SCAN_RESPONSE_DATA, "BT_SET_SCAN_RESPONSE_DATA"},
582                 {BT_IS_ADVERTISING, "BT_IS_ADVERTISING"},
583                 {BT_SET_MANUFACTURER_DATA, "BT_SET_MANUFACTURER_DATA"},
584                 {BT_LE_CONN_UPDATE, "BT_LE_CONN_UPDATE"},
585                 {BT_LE_READ_MAXIMUM_DATA_LENGTH, "BT_LE_READ_MAXIMUM_DATA_LENGTH"},
586                 {BT_LE_WRITE_HOST_SUGGESTED_DATA_LENGTH, "BT_LE_WRITE_HOST_SUGGESTED_DATA_LENGTH"},
587                 {BT_LE_READ_HOST_SUGGESTED_DATA_LENGTH, "BT_LE_READ_HOST_SUGGESTED_DATA_LENGTH"},
588                 {BT_LE_SET_DATA_LENGTH, "BT_LE_SET_DATA_LENGTH"},
589                 {BT_ADD_WHITE_LIST, "BT_ADD_WHITE_LIST"},
590                 {BT_REMOVE_WHITE_LIST, "BT_REMOVE_WHITE_LIST"},
591                 {BT_CLEAR_WHITE_LIST, "BT_CLEAR_WHITE_LIST"},
592                 {BT_REGISTER_SCAN_FILTER, "BT_REGISTER_SCAN_FILTER"},
593                 {BT_IS_SCAN_FILTER_SUPPORTED, "BT_IS_SCAN_FILTER_SUPPORTED"},
594                 {BT_GET_PROFILE_CONNECTED_DEVICES, "BT_GET_PROFILE_CONNECTED_DEVICES"},
595                 {BT_ENABLE_FORCE_HCI_DUMP, "BT_ENABLE_FORCE_HCI_DUMP"},
596                 {BT_SET_PASSKEY_NOTIFICATION, "BT_SET_PASSKEY_NOTIFICATION"},
597                 {BT_BOND_DEVICE, "BT_BOND_DEVICE"},
598                 {BT_BOND_DEVICE_BY_TYPE, "BT_BOND_DEVICE_BY_TYPE"},
599                 {BT_CANCEL_BONDING, "BT_CANCEL_BONDING"},
600                 {BT_PASSKEY_REPLY, "BT_PASSKEY_REPLY"},
601                 {BT_PASSKEY_CONFIRMATION_REPLY, "BT_PASSKEY_CONFIRMATION_REPLY"},
602                 {BT_UNBOND_DEVICE, "BT_UNBOND_DEVICE"},
603                 {BT_SEARCH_SERVICE, "BT_SEARCH_SERVICE"},
604                 {BT_CANCEL_SEARCH_SERVICE, "BT_CANCEL_SEARCH_SERVICE"},
605                 {BT_GET_BONDED_DEVICE, "BT_GET_BONDED_DEVICE"},
606                 {BT_GET_IS_ALIAS_SET, "BT_GET_IS_ALIAS_SET"},
607                 {BT_SET_ALIAS, "BT_SET_ALIAS"},
608                 {BT_SET_AUTHORIZATION, "BT_SET_AUTHORIZATION"},
609                 {BT_UNSET_AUTHORIZATION, "BT_UNSET_AUTHORIZATION"},
610                 {BT_IS_DEVICE_CONNECTED, "BT_IS_DEVICE_CONNECTED"},
611                 {BT_GET_CONNECTED_LINK_TYPE, "BT_GET_CONNECTED_LINK_TYPE"},
612                 {BT_SET_PIN_CODE, "BT_SET_PIN_CODE"},
613                 {BT_UNSET_PIN_CODE, "BT_UNSET_PIN_CODE"},
614                 {BT_UPDATE_LE_CONNECTION_MODE, "BT_UPDATE_LE_CONNECTION_MODE"},
615                 {BT_SET_PROFILE_TRUSTED, "BT_SET_PROFILE_TRUSTED"},
616                 {BT_GET_PROFILE_TRUSTED, "BT_GET_PROFILE_TRUSTED"},
617                 {BT_DISCONNECT_DEVICE, "BT_DISCONNECT_DEVICE"},
618                 {BT_HID_CONNECT, "BT_HID_CONNECT"},
619                 {BT_HID_DISCONNECT, "BT_HID_DISCONNECT"},
620                 {BT_HID_DEVICE_ACTIVATE, "BT_HID_DEVICE_ACTIVATE"},
621                 {BT_HID_DEVICE_DEACTIVATE, "BT_HID_DEVICE_DEACTIVATE"},
622                 {BT_HID_DEVICE_CONNECT, "BT_HID_DEVICE_CONNECT"},
623                 {BT_HID_DEVICE_DISCONNECT, "BT_HID_DEVICE_DISCONNECT"},
624                 {BT_HID_DEVICE_SEND_MOUSE_EVENT, "BT_HID_DEVICE_SEND_MOUSE_EVENT"},
625                 {BT_HID_DEVICE_SEND_KEY_EVENT, "BT_HID_DEVICE_SEND_KEY_EVENT"},
626                 {BT_HID_DEVICE_SEND_CUSTOM_EVENT, "BT_HID_DEVICE_SEND_CUSTOM_EVENT"},
627                 {BT_HID_DEVICE_SEND_REPLY_TO_REPORT, "BT_HID_DEVICE_SEND_REPLY_TO_REPORT"},
628                 {BT_HID_ENABLE_BARCODE_FEATURE, "BT_HID_ENABLE_BARCODE_FEATURE"},
629                 {BT_NETWORK_ACTIVATE, "BT_NETWORK_ACTIVATE"},
630                 {BT_NETWORK_DEACTIVATE, "BT_NETWORK_DEACTIVATE"},
631                 {BT_NETWORK_CONNECT, "BT_NETWORK_CONNECT"},
632                 {BT_NETWORK_DISCONNECT, "BT_NETWORK_DISCONNECT"},
633                 {BT_NETWORK_SERVER_DISCONNECT, "BT_NETWORK_SERVER_DISCONNECT"},
634                 {BT_AUDIO_CONNECT, "BT_AUDIO_CONNECT"},
635                 {BT_AUDIO_DISCONNECT, "BT_AUDIO_DISCONNECT"},
636                 {BT_AG_CONNECT, "BT_AG_CONNECT"},
637                 {BT_AG_DISCONNECT, "BT_AG_DISCONNECT"},
638                 {BT_AV_CONNECT, "BT_AV_CONNECT"},
639                 {BT_AV_DISCONNECT, "BT_AV_DISCONNECT"},
640                 {BT_AV_SOURCE_CONNECT, "BT_AV_SOURCE_CONNECT"},
641                 {BT_AV_SOURCE_DISCONNECT, "BT_AV_SOURCE_DISCONNECT"},
642                 {BT_HF_CONNECT, "BT_HF_CONNECT"},
643                 {BT_HF_DISCONNECT, "BT_HF_DISCONNECT"},
644                 {BT_GET_SPEAKER_GAIN, "BT_GET_SPEAKER_GAIN"},
645                 {BT_SET_SPEAKER_GAIN, "BT_SET_SPEAKER_GAIN"},
646                 {BT_SET_CONTENT_PROTECT, "BT_SET_CONTENT_PROTECT"},
647                 {BT_AUDIO_SELECT_ROLE, "BT_AUDIO_SELECT_ROLE"},
648                 {BT_AUDIO_SET_ABSOLUTE_VOLUME, "BT_AUDIO_SET_ABSOLUTE_VOLUME"},
649                 {BT_AUDIO_GET_ABSOLUTE_VOLUME, "BT_AUDIO_GET_ABSOLUTE_VOLUME"},
650                 {BT_AUDIO_IS_AVC_ACTIVATED, "BT_AUDIO_IS_AVC_ACTIVATED"},
651                 {BT_OOB_READ_LOCAL_DATA, "BT_OOB_READ_LOCAL_DATA"},
652                 {BT_OOB_ADD_REMOTE_DATA, "BT_OOB_ADD_REMOTE_DATA"},
653                 {BT_OOB_REMOVE_REMOTE_DATA, "BT_OOB_REMOVE_REMOTE_DATA"},
654                 {BT_LE_OOB_READ_LOCAL_DATA, "BT_LE_OOB_READ_LOCAL_DATA"},
655                 {BT_LE_OOB_ADD_REMOTE_DATA, "BT_LE_OOB_ADD_REMOTE_DATA"},
656                 {BT_AVRCP_SET_TRACK_INFO, "BT_AVRCP_SET_TRACK_INFO"},
657                 {BT_AVRCP_SET_PROPERTY, "BT_AVRCP_SET_PROPERTY"},
658                 {BT_AVRCP_SET_PROPERTIES, "BT_AVRCP_SET_PROPERTIES"},
659                 {BT_AVRCP_CONTROL_CONNECT, "BT_AVRCP_CONTROL_CONNECT"},
660                 {BT_AVRCP_CONTROL_DISCONNECT, "BT_AVRCP_CONTROL_DISCONNECT"},
661                 {BT_AVRCP_TARGET_CONNECT, "BT_AVRCP_TARGET_CONNECT"},
662                 {BT_AVRCP_TARGET_DISCONNECT, "BT_AVRCP_TARGET_DISCONNECT"},
663                 {BT_AVRCP_HANDLE_CONTROL, "BT_AVRCP_HANDLE_CONTROL"},
664                 {BT_AVRCP_HANDLE_CONTROL_TO_DEST, "BT_AVRCP_HANDLE_CONTROL_TO_DEST"},
665                 {BT_AVRCP_CONTROL_SET_PROPERTY, "BT_AVRCP_CONTROL_SET_PROPERTY"},
666                 {BT_AVRCP_CONTROL_GET_PROPERTY, "BT_AVRCP_CONTROL_GET_PROPERTY"},
667                 {BT_AVRCP_GET_TRACK_INFO, "BT_AVRCP_GET_TRACK_INFO"},
668                 {BT_OPP_PUSH_FILES, "BT_OPP_PUSH_FILES"},
669                 {BT_OPP_CANCEL_PUSH, "BT_OBT_OPP_IS_PUSHING_FILESPP_CANCEL_PUSH"},
670                 {BT_OPP_IS_PUSHING_FILES, "BT_OPP_IS_PUSHING_FILES"},
671                 {BT_OPP_GET_TRANSFER_PROGRESS, "BT_OPP_GET_TRANSFER_PROGRESS"},
672                 {BT_MAP_CREATE_SESSION, "BT_MAP_CREATE_SESSION"},
673                 {BT_MAP_DESTROY_SESSION, "BT_MAP_DESTROY_SESSION"},
674                 {BT_MAP_SET_FOLDER, "BT_MAP_SET_FOLDER"},
675                 {BT_MAP_LIST_FOLDERS, "BT_MAP_LIST_FOLDERS"},
676                 {BT_MAP_LIST_FILTER_FIELDS, "BT_MAP_LIST_FILTER_FIELDS"},
677                 {BT_MAP_LIST_MESSAGES, "BT_MAP_LIST_MESSAGES"},
678                 {BT_MAP_UPDATE_INBOX, "BT_MAP_UPDATE_INBOX"},
679                 {BT_MAP_PUSH_MESSAGE, "BT_MAP_PUSH_MESSAGE"},
680                 {BT_MAP_GET_MESSAGE, "BT_MAP_GET_MESSAGE"},
681                 {BT_OBEX_SERVER_ALLOCATE, "BT_OBEX_SERVER_ALLOCATE"},
682                 {BT_OBEX_SERVER_DEALLOCATE, "BT_OBEX_SERVER_DEALLOCATE"},
683                 {BT_OBEX_SERVER_IS_ACTIVATED, "BT_OBEX_SERVER_IS_ACTIVATED"},
684                 {BT_OBEX_SERVER_ACCEPT_CONNECTION, "BT_OBEX_SERVER_ACCEPT_CONNECTION"},
685                 {BT_OBEX_SERVER_REJECT_CONNECTION, "BT_OBEX_SERVER_REJECT_CONNECTION"},
686                 {BT_OBEX_SERVER_ACCEPT_FILE, "BT_OBEX_SERVER_ACCEPT_FILE"},
687                 {BT_OBEX_SERVER_REJECT_FILE, "BT_OBEX_SERVER_REJECT_FILE"},
688                 {BT_OBEX_SERVER_SET_PATH, "BT_OBEX_SERVER_SET_PATH"},
689                 {BT_OBEX_SERVER_SET_ROOT, "BT_OBEX_SERVER_SET_ROOT"},
690                 {BT_OBEX_SERVER_CANCEL_TRANSFER, "BT_OBEX_SERVER_CANCEL_TRANSFER"},
691                 {BT_OBEX_SERVER_CANCEL_ALL_TRANSFERS, "BT_OBEX_SERVER_CANCEL_ALL_TRANSFERS"},
692                 {BT_OBEX_SERVER_IS_RECEIVING, "BT_OBEX_SERVER_IS_RECEIVING"},
693                 {BT_RFCOMM_CLIENT_CONNECT, "BT_RFCOMM_CLIENT_CONNECT"},
694                 {BT_RFCOMM_CLIENT_CANCEL_CONNECT, "BT_RFCOMM_CLIENT_CANCEL_CONNECT"},
695                 {BT_RFCOMM_CLIENT_IS_CONNECTED, "BT_RFCOMM_CLIENT_IS_CONNECTED"},
696                 {BT_RFCOMM_SOCKET_DISCONNECT, "BT_RFCOMM_SOCKET_DISCONNECT"},
697                 {BT_RFCOMM_SOCKET_WRITE, "BT_RFCOMM_SOCKET_WRITE"},
698                 {BT_RFCOMM_CREATE_SOCKET, "BT_RFCOMM_CREATE_SOCKET"},
699                 {BT_RFCOMM_REMOVE_SOCKET, "BT_RFCOMM_REMOVE_SOCKET"},
700                 {BT_RFCOMM_LISTEN_AND_ACCEPT, "BT_RFCOMM_LISTEN_AND_ACCEPT"},
701                 {BT_RFCOMM_LISTEN, "BT_RFCOMM_LISTEN"},
702                 {BT_RFCOMM_IS_UUID_AVAILABLE, "BT_RFCOMM_IS_UUID_AVAILABLE"},
703                 {BT_RFCOMM_ACCEPT_CONNECTION, "BT_RFCOMM_ACCEPT_CONNECTION"},
704                 {BT_RFCOMM_REJECT_CONNECTION, "BT_RFCOMM_REJECT_CONNECTION"},
705                 {BT_RFCOMM_CREATE_SOCKET_EX, "BT_RFCOMM_CREATE_SOCKET_EX"},
706                 {BT_RFCOMM_REMOVE_SOCKET_EX, "BT_RFCOMM_REMOVE_SOCKET_EX"},
707                 {BT_PBAP_CONNECT, "BT_PBAP_CONNECT"},
708                 {BT_PBAP_DISCONNECT, "BT_PBAP_DISCONNECT"},
709                 {BT_PBAP_GET_PHONEBOOK_SIZE, "BT_PBAP_GET_PHONEBOOK_SIZE"},
710                 {BT_PBAP_GET_PHONEBOOK, "BT_PBAP_GET_PHONEBOOK"},
711                 {BT_PBAP_GET_LIST, "BT_PBAP_GET_LIST"},
712                 {BT_PBAP_PULL_VCARD, "BT_PBAP_PULL_VCARD"},
713                 {BT_PBAP_PHONEBOOK_SEARCH, "BT_PBAP_PHONEBOOK_SEARCH"},
714                 {BT_ENABLE_ADAPTER_LE, "BT_ENABLE_ADAPTER_LE"},
715                 {BT_DISABLE_ADAPTER_LE, "BT_DISABLE_ADAPTER_LE"},
716                 {BT_CONNECT_LE, "BT_CONNECT_LE"},
717                 {BT_DISCONNECT_LE, "BT_DISCONNECT_LE"},
718                 {BT_SET_LE_PRIVACY, "BT_SET_LE_PRIVACY"},
719                 {BT_REQ_ATT_MTU, "BT_REQ_ATT_MTU"},
720                 {BT_GET_ATT_MTU, "BT_GET_ATT_MTU"},
721                 {BT_GATT_ACQUIRE_WRITE, "BT_GATT_ACQUIRE_WRITE"},
722                 {BT_GET_DEVICE_IDA, "BT_GET_DEVICE_IDA"},
723                 {BT_SET_LE_STATIC_RANDOM_ADDRESS, "BT_SET_LE_STATIC_RANDOM_ADDRESS"},
724                 {BT_HDP_CONNECT, "BT_HDP_CONNECT"},
725                 {BT_HDP_DISCONNECT, "BT_HDP_DISCONNECT"},
726                 {BT_HDP_SEND_DATA, "BT_HDP_SEND_DATA"},
727                 {BT_HDP_REGISTER_SINK_APP, "BT_HDP_REGISTER_SINK_APP"},
728                 {BT_HDP_UNREGISTER_SINK_APP, "BT_HDP_UNREGISTER_SINK_APP"},
729                 {BT_GATT_GET_PRIMARY_SERVICES, "BT_GATT_GET_PRIMARY_SERVICES"},
730                 {BT_GATT_DISCOVER_CHARACTERISTICS, "BT_GATT_DISCOVER_CHARACTERISTICS"},
731                 {BT_GATT_SET_PROPERTY_REQUEST, "BT_GATT_SET_PROPERTY_REQUEST"},
732                 {BT_GATT_READ_CHARACTERISTIC, "BT_GATT_READ_CHARACTERISTIC"},
733                 {BT_GATT_DISCOVER_CHARACTERISTICS_DESCRIPTOR, "BT_GATT_DISCOVER_CHARACTERISTICS_DESCRIPTOR"},
734                 {BT_GATT_REGISTER_APPLICATION, "BT_GATT_REGISTER_APPLICATION"},
735                 {BT_GATT_REGISTER_SERVICE, "BT_GATT_REGISTER_SERVICE"},
736                 {BT_GATT_SEND_RESPONSE, "BT_GATT_SEND_RESPONSE"},
737                 {BT_LE_IPSP_INIT, "BT_LE_IPSP_INIT"},
738                 {BT_LE_IPSP_DEINIT, "BT_LE_IPSP_DEINIT"},
739                 {BT_LE_IPSP_CONNECT, "BT_LE_IPSP_CONNECT"},
740                 {BT_LE_IPSP_DISCONNECT, "BT_LE_IPSP_DISCONNECT"},
741                 {BT_DPM_SET_ALLOW_BT_MODE, "BT_DPM_SET_ALLOW_BT_MODE"},
742                 {BT_DPM_GET_ALLOW_BT_MODE, "BT_DPM_GET_ALLOW_BT_MODE"},
743                 {BT_DPM_SET_DEVICE_RESTRITION, "BT_DPM_SET_DEVICE_RESTRITION"},
744                 {BT_DPM_GET_DEVICE_RESTRITION, "BT_DPM_GET_DEVICE_RESTRITION"},
745                 {BT_DPM_SET_UUID_RESTRITION, "BT_DPM_SET_UUID_RESTRITION"},
746                 {BT_DPM_GET_UUID_RESTRITION, "BT_DPM_GET_UUID_RESTRITION"},
747                 {BT_DPM_ADD_DEVICES_BLACKLIST, "BT_DPM_ADD_DEVICES_BLACKLIST"},
748                 {BT_DPM_ADD_DEVICES_WHITELIST, "BT_DPM_ADD_DEVICES_WHITELIST"},
749                 {BT_DPM_ADD_UUIDS_BLACKLIST, "BT_DPM_ADD_UUIDS_BLACKLIST"},
750                 {BT_DPM_ADD_UUIDS_WHITELIST, "BT_DPM_ADD_UUIDS_WHITELIST"},
751                 {BT_DPM_CLEAR_DEVICES_BLACKLIST, "BT_DPM_CLEAR_DEVICES_BLACKLIST"},
752                 {BT_DPM_CLEAR_DEVICES_WHITELIST, "BT_DPM_CLEAR_DEVICES_WHITELIST"},
753                 {BT_DPM_CLEAR_UUIDS_BLACKLIST, "BT_DPM_CLEAR_UUIDS_BLACKLIST"},
754                 {BT_DPM_CLEAR_UUIDS_WHITELIST, "BT_DPM_CLEAR_UUIDS_WHITELIST"},
755                 {BT_DPM_REMOVE_DEVICE_BLACKLIST, "BT_DPM_REMOVE_DEVICE_BLACKLIST"},
756                 {BT_DPM_REMOVE_DEVICE_WHITELIST, "BT_DPM_REMOVE_DEVICE_WHITELIST"},
757                 {BT_DPM_REMOVE_UUID_BLACKLIST, "BT_DPM_REMOVE_UUID_BLACKLIST"},
758                 {BT_DPM_REMOVE_UUID_WHITELIST, "BT_DPM_REMOVE_UUID_WHITELIST"},
759                 {BT_DPM_GET_DEVICES_BLACKLIST, "BT_DPM_GET_DEVICES_BLACKLIST"},
760                 {BT_DPM_GET_DEVICES_WHITELIST, "BT_DPM_GET_DEVICES_WHITELIST"},
761                 {BT_DPM_GET_UUIDS_BLACKLIST, "BT_DPM_GET_UUIDS_BLACKLIST"},
762                 {BT_DPM_GET_UUIDS_WHITELIST, "BT_DPM_GET_UUIDS_WHITELIST"},
763                 {BT_DPM_SET_ALLOW_OUTGOING_CALL, "BT_DPM_SET_ALLOW_OUTGOING_CALL"},
764                 {BT_DPM_GET_ALLOW_OUTGOING_CALL, "BT_DPM_GET_ALLOW_OUTGOING_CALL"},
765                 {BT_DPM_SET_PAIRING_STATE, "BT_DPM_SET_PAIRING_STATE"},
766                 {BT_DPM_GET_PAIRING_STATE, "BT_DPM_GET_PAIRING_STATE"},
767                 {BT_DPM_SET_PROFILE_STATE, "BT_DPM_SET_PROFILE_STATE"},
768                 {BT_DPM_GET_PROFILE_STATE, "BT_DPM_GET_PROFILE_STATE"},
769                 {BT_DPM_SET_DESKROP_CONNECTIVITY_STATE, "BT_DPM_SET_DESKROP_CONNECTIVITY_STATE"},
770                 {BT_DPM_GET_DESKROP_CONNECTIVITY_STATE, "BT_DPM_GET_DESKROP_CONNECTIVITY_STATE"},
771                 {BT_DPM_SET_DISCOVERABLE_STATE, "BT_DPM_SET_DISCOVERABLE_STATE"},
772                 {BT_DPM_GET_DISCOVERABLE_STATE, "BT_DPM_GET_DISCOVERABLE_STATE"},
773                 {BT_DPM_SET_LIMITED_DISCOVERABLE_STATE, "BT_DPM_SET_LIMITED_DISCOVERABLE_STATE"},
774                 {BT_DPM_GET_LIMITED_DISCOVERABLE_STATE, "BT_DPM_GET_LIMITED_DISCOVERABLE_STATE"},
775                 {BT_DPM_SET_DATA_TRANSFER_STATE, "BT_DPM_SET_DATA_TRANSFER_STATE"},
776                 {BT_DPM_GET_DATA_TRANSFER_STATE, "BT_DPM_GET_DATA_TRANSFER_STATE"},
777                 {BT_PXP_MONITOR_SET_PROPERTY, "BT_PXP_MONITOR_SET_PROPERTY"},
778                 {BT_PXP_MONITOR_GET_PROPERTY, "BT_PXP_MONITOR_GET_PROPERTY"},
779                 {BT_PXP_MONITOR_GET_SUPPORTED_SERIVCES, "BT_PXP_MONITOR_GET_SUPPORTED_SERIVCES"},
780                 {BT_PXP_REPORTER_REGISTER, "BT_PXP_REPORTER_REGISTER"},
781                 {BT_PXP_REPORTER_UNREGISTER, "BT_PXP_REPORTER_UNREGISTER"},
782                 {BT_PXP_REPORTER_GET_PROPERTY, "BT_PXP_REPORTER_GET_PROPERTY"},
783                 {BT_TDS_PROVIDER_REGISTER, "BT_TDS_PROVIDER_REGISTER"},
784                 {BT_TDS_PROVIDER_UNREGISTER, "BT_TDS_PROVIDER_UNREGISTER"},
785                 {BT_TDS_PROVIDER_SET_MANUF_DATA, "BT_TDS_PROVIDER_SET_MANUF_DATA"},
786                 {BT_TDS_PROVIDER_CREATE, "BT_TDS_PROVIDER_CREATE"},
787                 {BT_TDS_PROVIDER_DESTROY, "BT_TDS_PROVIDER_DESTROY"},
788                 {BT_TDS_PROVIDER_SET_TRANSPORT_DATA, "BT_TDS_PROVIDER_SET_TRANSPORT_DATA"},
789                 {BT_TDS_SEND_ACTIVATION_RESPONSE, "BT_TDS_SEND_ACTIVATION_RESPONSE"},
790                 {BT_TDS_READ_TRANSPORT_DATA, "BT_TDS_READ_TRANSPORT_DATA"},
791                 {BT_TDS_ENABLE_CONTROL_POINT, "BT_TDS_ENABLE_CONTROL_POINT"},
792                 {BT_TDS_ACTIVATE_CONTROL_POINT, "BT_TDS_ACTIVATE_CONTROL_POINT"},
793                 {BT_OTP_READ_VALUE, "BT_OTP_READ_VALUE"},
794                 {BT_OTP_ENABLE_NOTIFICATION, "BT_OTP_ENABLE_NOTIFICATION"},
795                 {BT_OTP_WRITE_VALUE, "BT_OTP_WRITE_VALUE"},
796                 {BT_LE_OTC_CONNECT, "BT_LE_OTC_CONNECT"},
797                 {BT_LE_OTC_DISCONNECT, "BT_LE_OTC_DISCONNECT"},
798                 {BT_L2CAP_LE_CLIENT_CONNECT, "BT_L2CAP_LE_CLIENT_CONNECT"},
799                 {BT_L2CAP_LE_CLIENT_CANCEL_CONNECT, "BT_L2CAP_LE_CLIENT_CANCEL_CONNECT"},
800                 {BT_L2CAP_LE_CLIENT_IS_CONNECTED, "BT_L2CAP_LE_CLIENT_IS_CONNECTED"},
801                 {BT_L2CAP_LE_SOCKET_DISCONNECT, "BT_L2CAP_LE_SOCKET_DISCONNECT"},
802                 {BT_L2CAP_LE_SOCKET_WRITE, "BT_L2CAP_LE_SOCKET_WRITE"},
803                 {BT_L2CAP_LE_CREATE_SOCKET, "BT_L2CAP_LE_CREATE_SOCKET"},
804                 {BT_L2CAP_LE_REMOVE_SOCKET, "BT_L2CAP_LE_REMOVE_SOCKET"},
805                 {BT_L2CAP_LE_LISTEN_AND_ACCEPT, "BT_L2CAP_LE_LISTEN_AND_ACCEPT"},
806                 {BT_L2CAP_LE_LISTEN, "BT_L2CAP_LE_LISTEN"},
807                 {BT_L2CAP_LE_IS_PSM_AVAILABLE, "BT_L2CAP_LE_IS_PSM_AVAILABLE"},
808                 {BT_L2CAP_LE_ACCEPT_CONNECTION, "BT_L2CAP_LE_ACCEPT_CONNECTION"},
809                 {BT_L2CAP_LE_REJECT_CONNECTION, "BT_L2CAP_LE_REJECT_CONNECTION"},
810                 {-1, ""},
811         };
812
813         for (i = 0; bt_functions[i].function != -1; i++) {
814                 if (bt_functions[i].function == function)
815                         return bt_functions[i].function_name;
816         }
817
818         return NULL;
819 }
820
821 int _bt_copy_utf8_string(char *dest, const char *src, unsigned int length)
822 {
823         int i;
824         const char *p = src;
825         char *next;
826         int count;
827
828         if (dest == NULL || src == NULL)
829                 return BLUETOOTH_ERROR_INVALID_PARAM;
830
831         i = 0;
832         while (*p != '\0' && i < length) {
833                 next = g_utf8_next_char(p);
834                 count = next - p;
835
836                 while (count > 0 && ((i + count) < length)) {
837                         dest[i++] = *p;
838                         p++;
839                         count--;
840                 }
841                 p = next;
842         }
843         return BLUETOOTH_ERROR_NONE;
844 }
845
846 gboolean _bt_utf8_validate(char *name)
847 {
848         BT_DBG("+");
849         gunichar2 *u16;
850         glong items_written = 0;
851
852         if (FALSE == g_utf8_validate(name, -1, NULL))
853                 return FALSE;
854
855         u16 = g_utf8_to_utf16(name, -1, NULL, &items_written, NULL);
856         if (u16 == NULL)
857                 return FALSE;
858
859         g_free(u16);
860
861         if (items_written != g_utf8_strlen(name, -1))
862                 return FALSE;
863
864         BT_DBG("-");
865         return TRUE;
866 }
867
868 static GDBusProxy *profile_gproxy;
869 static int latest_id = -1;
870 #define BT_RFCOMM_ID_MAX 245
871 static gboolean id_used[BT_RFCOMM_ID_MAX];
872
873 static const gchar rfcomm_agent_xml[] =
874 "<node name='/'>"
875 " <interface name='org.bluez.Profile1'>"
876 "     <method name='NewConnection'>"
877 "          <arg type='o' name='object' direction='in'/>"
878 "          <arg type='h' name='fd' direction='in'/>"
879 "          <arg type='a{sv}' name='properties' direction='in'/>"
880 "     </method>"
881 "     <method name='RequestDisconnection'>"
882 "          <arg type='o' name='device' direction='in'/>"
883 "     </method>"
884 "  </interface>"
885 "</node>";
886
887 static void __new_connection_method(GDBusConnection *connection,
888                 const gchar *sender,
889                 const gchar *object_path,
890                 const gchar *interface_name,
891                 const gchar *method_name,
892                 GVariant *parameters,
893                 GDBusMethodInvocation *invocation,
894                 gpointer user_data)
895 {
896         BT_DBG("method %s", method_name);
897         if (g_strcmp0(method_name, "NewConnection") == 0) {
898                 int index;
899                 GDBusMessage *msg;
900                 GUnixFDList *fd_list;
901                 GVariantBuilder *properties;
902                 char *obj_path;
903                 char addr[20];
904                 bluetooth_device_address_t  remote_addr1;
905                 bt_new_connection_cb cb = user_data;
906                 char secure_address[BT_ADDRESS_STRING_SIZE] = { 0 };
907                 int fd;
908
909                 g_variant_get(parameters, "(oha{sv})", &obj_path, &index,
910                                                                 &properties);
911
912                 msg = g_dbus_method_invocation_get_message(invocation);
913                 fd_list = g_dbus_message_get_unix_fd_list(msg);
914                 if (fd_list == NULL) {
915                         BT_ERR("fd_list is NULL");
916                         GQuark quark = g_quark_from_string("rfcomm-app");
917                         GError *err = g_error_new(quark, 0, "No fd in message");
918                         g_dbus_method_invocation_return_gerror(invocation, err);
919                         g_error_free(err);
920                         return;
921                 }
922
923
924                 fd = g_unix_fd_list_get(fd_list, index, NULL);
925                 if (fd == -1) {
926                         BT_ERR("Invalid fd return");
927                         GQuark quark = g_quark_from_string("rfcomm-app");
928                         GError *err = g_error_new(quark, 0, "Invalid FD return");
929                         g_dbus_method_invocation_return_gerror(invocation, err);
930                         g_error_free(err);
931                         return;
932                 }
933
934                 _bt_convert_device_path_to_address(obj_path, addr);
935                 _bt_convert_addr_string_to_type(remote_addr1.addr, (const char *)addr);
936
937                 _bt_convert_addr_string_to_secure_string(secure_address, addr);
938                 BT_INFO("fd: %d, address %s", fd, secure_address);
939
940                 g_dbus_method_invocation_return_value(invocation, NULL);
941
942                 if (cb)
943                         cb(object_path, fd, &remote_addr1);
944         } else if (g_strcmp0(method_name, "RequestDisconnection") == 0) {
945                 g_dbus_method_invocation_return_value(invocation, NULL);
946         }
947 }
948
949
950 static const GDBusInterfaceVTable method_table = {
951         __new_connection_method,
952         NULL,
953         NULL,
954 };
955
956 void _bt_swap_addr(unsigned char *dst, const unsigned char *src)
957 {
958         int i;
959
960         for (i = 0; i < 6; i++)
961                 dst[i] = src[5-i];
962 }
963
964 int __rfcomm_assign_id(void)
965 {
966         int index;
967
968         BT_DBG("latest_id: %d", latest_id);
969
970         index = latest_id + 1;
971
972         if (index >= BT_RFCOMM_ID_MAX)
973                 index = 0;
974
975         BT_DBG("index: %d", index);
976
977         while (id_used[index] == TRUE) {
978                 if (index == latest_id) {
979                         /* No available ID */
980                         BT_ERR("All request ID is used");
981                         return -1;
982                 }
983
984                 index++;
985
986                 if (index >= BT_RFCOMM_ID_MAX)
987                         index = 0;
988         }
989
990         latest_id = index;
991         id_used[index] = TRUE;
992
993         BT_DBG("Assigned Id: %d", latest_id);
994
995         return latest_id;
996 }
997
998 void __rfcomm_delete_id(int id)
999 {
1000         ret_if(id >= BT_RFCOMM_ID_MAX);
1001         ret_if(id < 0);
1002
1003         id_used[id] = FALSE;
1004
1005         /* Next server will use this ID */
1006         latest_id = id - 1;
1007 }
1008
1009 static GDBusProxy *__bt_gdbus_get_profile_proxy(void)
1010 {
1011         GDBusConnection *gconn;
1012         GError *err = NULL;
1013
1014         if (profile_gproxy)
1015                 return profile_gproxy;
1016
1017         /* Shared connection should be used because rfcomm interface was registered
1018          * on shared connection not private. Otherwise, dbus rejection is occured
1019          * because dbus policy is only applied on shared connection not private. */
1020         gconn = _bt_get_system_shared_conn();
1021         if (gconn == NULL)
1022                 return NULL;
1023
1024         profile_gproxy = g_dbus_proxy_new_sync(gconn, G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES,
1025                                                 NULL, BT_BLUEZ_NAME,
1026                                                 "/org/bluez",
1027                                                 "org.bluez.ProfileManager1",
1028                                                 NULL, &err);
1029         if (err) {
1030                 BT_ERR("Unable to create proxy: %s", err->message);
1031                 g_clear_error(&err);
1032                 return NULL;
1033         }
1034
1035         return profile_gproxy;
1036 }
1037
1038 static GDBusProxy *__bt_gdbus_get_device_proxy(char *object_path)
1039 {
1040         GDBusConnection *gconn;
1041         GError *err = NULL;
1042         GDBusProxy *device_gproxy;
1043
1044         gconn = _bt_get_system_common_conn();
1045         if (gconn == NULL)
1046                 return NULL;
1047
1048         device_gproxy = g_dbus_proxy_new_sync(gconn, G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES,
1049                                                 NULL, BT_BLUEZ_NAME,
1050                                                 object_path,
1051                                                 BT_DEVICE_INTERFACE,
1052                                                 NULL, &err);
1053
1054         if (device_gproxy == NULL && err) {
1055                 BT_ERR("Unable to create proxy: %s", err->message);
1056                 g_clear_error(&err);
1057                 return NULL;
1058         }
1059
1060         return device_gproxy;
1061 }
1062
1063 void _bt_unregister_gdbus(int object_id)
1064 {
1065         GDBusConnection *gconn;
1066
1067         gconn = _bt_get_system_shared_conn();
1068         if (gconn == NULL)
1069                 return;
1070
1071         g_dbus_connection_unregister_object(gconn, object_id);
1072
1073         /* TODO: bus_id needs to be un-owned if all of path is unregistered */
1074 }
1075
1076 static GDBusNodeInfo *_bt_get_gdbus_node(GDBusConnection *gconn, const gchar *xml_data, const char *bus_name)
1077 {
1078         if (bus_id == 0) {
1079                 char *name = g_strdup(bus_name);
1080                 BT_DBG("well-known name: %s", name);
1081                 bus_id = g_bus_own_name_on_connection(gconn,
1082                                 name, G_BUS_NAME_OWNER_FLAGS_NONE,
1083                                 NULL, NULL, NULL, NULL);
1084                 BT_DBG("Got bus id %d", bus_id);
1085                 g_free(name);
1086         }
1087
1088         return g_dbus_node_info_new_for_xml(xml_data, NULL);
1089 }
1090
1091 int _bt_register_new_conn(const char *path, bt_new_connection_cb cb)
1092 {
1093         GDBusConnection *gconn;
1094         GDBusNodeInfo *node_info;
1095         int id;
1096         GError *error = NULL;
1097         char *bus_name;
1098
1099         gconn = _bt_get_system_shared_conn();
1100         if (gconn == NULL)
1101                 return -1;
1102
1103         bus_name = g_strdup_printf("org.bt.frwk.p%d", getpid());
1104
1105         node_info = _bt_get_gdbus_node(gconn, rfcomm_agent_xml, bus_name);
1106         if (node_info == NULL) {
1107                 g_free(bus_name);
1108                 return -1;
1109         }
1110         g_free(bus_name);
1111
1112         id = g_dbus_connection_register_object(gconn, path,
1113                                                 node_info->interfaces[0],
1114                                                 &method_table,
1115                                                 cb, NULL, &error);
1116         g_dbus_node_info_unref(node_info);
1117         if (id == 0) {
1118                 BT_ERR("Failed to register: %s", error->message);
1119                 g_error_free(error);
1120                 return -1;
1121         }
1122
1123         BT_DBG("NEW CONNECTION ID %d", id);
1124
1125         return id;
1126 }
1127
1128 static GDBusProxy * __bt_gdbus_get_adapter_proxy()
1129 {
1130         GError *err = NULL;
1131         GDBusProxy *manager_proxy = NULL;
1132         GDBusProxy *adapter_proxy = NULL;
1133         GDBusConnection *conn;
1134         GVariant *result = NULL;
1135         char *adapter_path = NULL;
1136
1137         conn = _bt_get_system_common_conn();
1138         retv_if(conn == NULL, NULL);
1139
1140         manager_proxy =  g_dbus_proxy_new_sync(conn,
1141                         G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES, NULL,
1142                         BT_BLUEZ_NAME,
1143                         BT_MANAGER_PATH,
1144                         BT_MANAGER_INTERFACE,
1145                         NULL, &err);
1146
1147         if (!manager_proxy) {
1148                 BT_ERR("Unable to create proxy: %s", err->message);
1149                 goto fail;
1150         }
1151
1152         result = g_dbus_proxy_call_sync(manager_proxy, "DefaultAdapter", NULL,
1153                         G_DBUS_CALL_FLAGS_NONE, -1, NULL, &err);
1154         if (!result) {
1155                 if (err != NULL)
1156                         BT_ERR("Fail to get DefaultAdapter (Error: %s)", err->message);
1157                 else
1158                         BT_ERR("Fail to get DefaultAdapter");
1159
1160                 goto fail;
1161         }
1162
1163         if (g_strcmp0(g_variant_get_type_string(result), "(o)")) {
1164                 BT_ERR("Incorrect result\n");
1165                 goto fail;
1166         }
1167
1168         g_variant_get(result, "(&o)", &adapter_path);
1169
1170         if (adapter_path == NULL ||
1171                 strlen(adapter_path) >= BT_ADAPTER_OBJECT_PATH_MAX) {
1172                 BT_ERR("Adapter path is inproper\n");
1173                 goto fail;
1174         }
1175
1176         BT_INFO("Adapter Path %s", adapter_path);
1177
1178         adapter_proxy = g_dbus_proxy_new_sync(conn,
1179                                         G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES, NULL,
1180                                         BT_BLUEZ_NAME,
1181                                         adapter_path,
1182                                         BT_ADAPTER_INTERFACE,
1183                                         NULL, &err);
1184         if (err) {
1185                 BT_ERR("DBus Error message: [%s]", err->message);
1186                 g_clear_error(&err);
1187         }
1188
1189 fail:
1190         if (manager_proxy)
1191                 g_object_unref(manager_proxy);
1192         if (result)
1193                 g_variant_unref(result);
1194         return adapter_proxy;
1195 }
1196
1197 int _bt_register_new_conn_ex(const char *path, const char *bus_name, bt_new_connection_cb cb)
1198 {
1199         GDBusConnection *gconn;
1200         GDBusNodeInfo *node_info;
1201         int id;
1202         GError *error = NULL;
1203
1204         gconn = _bt_get_system_shared_conn();
1205         if (gconn == NULL)
1206                 return -1;
1207
1208         node_info = _bt_get_gdbus_node(gconn, rfcomm_agent_xml, bus_name);
1209         if (node_info == NULL)
1210                 return -1;
1211
1212         id = g_dbus_connection_register_object(gconn, path,
1213                                                 node_info->interfaces[0],
1214                                                 &method_table,
1215                                                 cb, NULL, &error);
1216         g_dbus_node_info_unref(node_info);
1217         if (id == 0) {
1218                 BT_ERR("Failed to register: %s", error->message);
1219                 g_error_free(error);
1220                 return -1;
1221         }
1222
1223         BT_DBG("NEW CONNECTION ID %d", id);
1224
1225         return id;
1226 }
1227
1228 int _bt_register_profile(bt_register_profile_info_t *info, gboolean use_default_rfcomm)
1229 {
1230         GVariantBuilder *option_builder;
1231         GVariant *ret;
1232         GDBusProxy *proxy;
1233         GError *err = NULL;
1234         int result = BLUETOOTH_ERROR_NONE;
1235
1236         proxy = __bt_gdbus_get_profile_proxy();
1237         if (proxy == NULL) {
1238                 BT_ERR("Getting profile proxy failed");
1239                 return BLUETOOTH_ERROR_INTERNAL;
1240         }
1241
1242         option_builder = g_variant_builder_new(G_VARIANT_TYPE("a{sv}"));
1243         if (info->authentication)
1244                 g_variant_builder_add(option_builder, "{sv}",
1245                                                 "RequireAuthentication",
1246                                                 g_variant_new_boolean(TRUE));
1247         if (info->authorization)
1248                 g_variant_builder_add(option_builder, "{sv}",
1249                                                 "RequireAuthorization",
1250                                                 g_variant_new_boolean(TRUE));
1251         if (info->role)
1252                 g_variant_builder_add(option_builder, "{sv}",
1253                                                 "Role",
1254                                                 g_variant_new_string(info->role));
1255
1256         /* Setting RFCOMM channel to default value 0; would allow bluez to assign
1257          * RFCOMM channels based on the availability when two services want
1258          * to use the RFCOMM along with SPP. Hence bluez makes sure that no
1259          * two services use the same SPP RFCOMM channel. */
1260         if (use_default_rfcomm) {
1261                 if (TIZEN_FEATURE_ROBOT_REFERENCE) {
1262                         BT_INFO("Use channel 22 for robot");
1263                         g_variant_builder_add(option_builder, "{sv}",
1264                                         "Channel",
1265                                         g_variant_new_uint16(RFCOMM_ROBOT_PROFILE_CHANNEL));
1266                 } else {
1267                         g_variant_builder_add(option_builder, "{sv}",
1268                                         "Channel",
1269                                         g_variant_new_uint16(RFCOMM_DEFAULT_PROFILE_CHANNEL));
1270                 }
1271         }
1272
1273         if (info->service)
1274                 g_variant_builder_add(option_builder, "{sv}",
1275                                                 "Service",
1276                                                 g_variant_new_string(info->service));
1277
1278         ret = g_dbus_proxy_call_sync(proxy, "RegisterProfile",
1279                                         g_variant_new("(osa{sv})", info->obj_path,
1280                                                                 info->uuid,
1281                                                                 option_builder),
1282                                         G_DBUS_CALL_FLAGS_NONE, -1,
1283                                         NULL, &err);
1284         if (err) {
1285                 g_dbus_error_strip_remote_error(err);
1286                 BT_ERR("RegisterProfile failed: %s", err->message);
1287
1288                 if (g_strrstr(err->message, BT_ACCESS_DENIED_MSG))
1289                         result = BLUETOOTH_ERROR_ACCESS_DENIED;
1290                 else
1291                         result = BLUETOOTH_ERROR_INTERNAL;
1292
1293                 g_clear_error(&err);
1294         }
1295
1296         g_variant_builder_unref(option_builder);
1297
1298         if (ret)
1299                 g_variant_unref(ret);
1300
1301         return result;
1302 }
1303
1304 int _bt_register_profile_ex(bt_register_profile_info_t *info, gboolean use_default_rfcomm, const char *name, const char *path)
1305 {
1306         GVariantBuilder *option_builder;
1307         GVariant *ret;
1308         GDBusProxy *proxy;
1309         GError *err = NULL;
1310         int result = BLUETOOTH_ERROR_NONE;
1311
1312         proxy = __bt_gdbus_get_profile_proxy();
1313         if (proxy == NULL) {
1314                 BT_ERR("Getting profile proxy failed");
1315                 return BLUETOOTH_ERROR_INTERNAL;
1316         }
1317
1318         option_builder = g_variant_builder_new(G_VARIANT_TYPE("a{sv}"));
1319         if (info->authentication)
1320                 g_variant_builder_add(option_builder, "{sv}",
1321                                                 "RequireAuthentication",
1322                                                 g_variant_new_boolean(TRUE));
1323         if (info->authorization)
1324                 g_variant_builder_add(option_builder, "{sv}",
1325                                                 "RequireAuthorization",
1326                                                 g_variant_new_boolean(TRUE));
1327         if (info->role)
1328                 g_variant_builder_add(option_builder, "{sv}",
1329                                                 "Role",
1330                                                 g_variant_new_string(info->role));
1331
1332         /* Setting RFCOMM channel to default value 0; would allow bluez to assign
1333          * RFCOMM channels based on the availability when two services want
1334          * to use the RFCOMM along with SPP. Hence bluez makes sure that no
1335          * two services use the same SPP RFCOMM channel. */
1336         if (use_default_rfcomm)
1337                 g_variant_builder_add(option_builder, "{sv}",
1338                                                 "Channel",
1339                                                 g_variant_new_uint16(RFCOMM_DEFAULT_PROFILE_CHANNEL));
1340         if (info->service)
1341                 g_variant_builder_add(option_builder, "{sv}",
1342                                                 "Service",
1343                                                 g_variant_new_string(info->service));
1344
1345         ret = g_dbus_proxy_call_sync(proxy, "RegisterProfile2",
1346                                         g_variant_new("(osssa{sv})", info->obj_path,
1347                                                                 info->uuid,
1348                                                                 name,
1349                                                                 path,
1350                                                                 option_builder),
1351                                         G_DBUS_CALL_FLAGS_NONE, -1,
1352                                         NULL, &err);
1353         if (err) {
1354                 g_dbus_error_strip_remote_error(err);
1355                 BT_ERR("RegisterProfile2 failed: %s", err->message);
1356
1357                 if (g_strrstr(err->message, BT_ACCESS_DENIED_MSG))
1358                         result = BLUETOOTH_ERROR_ACCESS_DENIED;
1359                 else
1360                         result = BLUETOOTH_ERROR_INTERNAL;
1361
1362                 g_clear_error(&err);
1363         }
1364
1365         g_variant_builder_unref(option_builder);
1366
1367         if (ret)
1368                 g_variant_unref(ret);
1369
1370         return result;
1371 }
1372
1373 int _bt_register_profile_platform(bt_register_profile_info_t *info, gboolean use_default_rfcomm)
1374 {
1375         GVariantBuilder *option_builder;
1376         GVariant *ret;
1377         GDBusProxy *proxy;
1378         GError *err = NULL;
1379         int result = BLUETOOTH_ERROR_NONE;
1380
1381         proxy = __bt_gdbus_get_profile_proxy();
1382         if (proxy == NULL) {
1383                 BT_ERR("Getting profile proxy failed");
1384                 return BLUETOOTH_ERROR_INTERNAL;
1385         }
1386
1387         option_builder = g_variant_builder_new(G_VARIANT_TYPE("a{sv}"));
1388         if (info->authentication)
1389                 g_variant_builder_add(option_builder, "{sv}",
1390                                                 "RequireAuthentication",
1391                                                 g_variant_new_boolean(TRUE));
1392         if (info->authorization)
1393                 g_variant_builder_add(option_builder, "{sv}",
1394                                                 "RequireAuthorization",
1395                                                 g_variant_new_boolean(TRUE));
1396         if (info->role)
1397                 g_variant_builder_add(option_builder, "{sv}",
1398                                                 "Role",
1399                                                 g_variant_new_string(info->role));
1400
1401         /* Setting RFCOMM channel to default value 0; would allow bluez to assign
1402          * RFCOMM channels based on the availability when two services want
1403          * to use the RFCOMM along with SPP. Hence bluez makes sure that no
1404          * two services use the same SPP RFCOMM channel. */
1405         if (use_default_rfcomm)
1406                 g_variant_builder_add(option_builder, "{sv}",
1407                                                 "Channel",
1408                                                 g_variant_new_uint16(RFCOMM_DEFAULT_PROFILE_CHANNEL));
1409         if (info->service)
1410                 g_variant_builder_add(option_builder, "{sv}",
1411                                                 "Service",
1412                                                 g_variant_new_string(info->service));
1413
1414         ret = g_dbus_proxy_call_sync(proxy, "RegisterProfile1",
1415                                         g_variant_new("(osa{sv})", info->obj_path,
1416                                                                 info->uuid,
1417                                                                 option_builder),
1418                                         G_DBUS_CALL_FLAGS_NONE, -1,
1419                                         NULL, &err);
1420
1421         if (err) {
1422                 g_dbus_error_strip_remote_error(err);
1423                 BT_ERR("RegisterProfile1 failed: %s", err->message);
1424
1425                 if (g_strrstr(err->message, BT_ACCESS_DENIED_MSG))
1426                         result = BLUETOOTH_ERROR_ACCESS_DENIED;
1427                 else
1428                         result = BLUETOOTH_ERROR_INTERNAL;
1429
1430                 g_clear_error(&err);
1431         }
1432
1433         g_variant_builder_unref(option_builder);
1434
1435         if (ret)
1436                 g_variant_unref(ret);
1437
1438         return result;
1439 }
1440
1441
1442 void _bt_unregister_profile(char *path)
1443 {
1444         GVariant *ret;
1445         GDBusProxy *proxy;
1446         GError *err = NULL;
1447
1448         proxy = __bt_gdbus_get_profile_proxy();
1449         if (proxy == NULL) {
1450                 BT_ERR("Getting profile proxy failed");
1451                 return;
1452         }
1453
1454         ret = g_dbus_proxy_call_sync(proxy, "UnregisterProfile",
1455                         g_variant_new("(o)", path),
1456                         G_DBUS_CALL_FLAGS_NONE, -1,
1457                         NULL, &err);
1458         if (err) {
1459                 BT_ERR("UnregisterProfile failed : %s", err->message);
1460                 g_clear_error(&err);
1461         }
1462
1463         if (ret)
1464                 g_variant_unref(ret);
1465
1466         return;
1467 }
1468
1469 void _bt_print_api_caller_name(void)
1470 {
1471         FILE *fp = NULL;
1472         char *path = NULL;
1473         char buf[256] = {0, };
1474         char **str_list = NULL;
1475
1476         path = g_strdup_printf("/proc/%d/cmdline", getpid());
1477         fp = fopen(path, "r");
1478         if (fp == NULL) {
1479                 g_free(path);
1480                 return;
1481         }
1482
1483         if (fgets(buf, 256, fp) != NULL) {
1484                 str_list = g_strsplit(buf, " ", -1);
1485                 if (str_list[0] != NULL)
1486                         BT_INFO("Caller : %s", str_list[0]);
1487                 g_strfreev(str_list);
1488         }
1489
1490         fclose(fp);
1491         g_free(path);
1492         return;
1493 }
1494
1495 int _bt_connect_profile(char *address, char *uuid, void *cb,
1496                                                         gpointer func_data)
1497 {
1498         GDBusProxy *proxy;
1499         GDBusProxy *adapter_proxy;
1500         char *object_path;
1501         GError *err = NULL;
1502
1503         object_path = _bt_get_device_object_path(address);
1504
1505         if (object_path == NULL) {
1506                 GVariant *ret = NULL;
1507                 BT_ERR("No searched device");
1508                 adapter_proxy = __bt_gdbus_get_adapter_proxy();
1509
1510                 if (adapter_proxy == NULL) {
1511                         BT_ERR("adapter proxy is NULL");
1512                         return BLUETOOTH_ERROR_INTERNAL;
1513                 }
1514
1515                 ret = g_dbus_proxy_call_sync(adapter_proxy, "CreateDevice",
1516                                 g_variant_new("(s)", address),
1517                                 G_DBUS_CALL_FLAGS_NONE,
1518                                 DBUS_TIMEOUT, NULL,
1519                                 &err);
1520
1521                 if (err != NULL) {
1522                         BT_ERR("CreateDevice Failed: %s", err->message);
1523                         g_clear_error(&err);
1524                 }
1525                 if (ret)
1526                         g_variant_unref(ret);
1527                 g_object_unref(adapter_proxy);
1528                 object_path = _bt_get_device_object_path(address);
1529
1530                 if (object_path == NULL)
1531                         return BLUETOOTH_ERROR_INTERNAL;
1532         }
1533
1534         proxy = __bt_gdbus_get_device_proxy(object_path);
1535         g_free(object_path);
1536
1537         if (proxy == NULL) {
1538                 BT_ERR("Error while getting proxy");
1539                 return BLUETOOTH_ERROR_INTERNAL;
1540         }
1541
1542         g_dbus_proxy_call(proxy, "ConnectProfile",
1543                         g_variant_new("(s)", uuid),
1544                         G_DBUS_CALL_FLAGS_NONE,
1545                         DBUS_TIMEOUT, NULL,
1546                         (GAsyncReadyCallback)cb,
1547                         func_data);
1548         if (cb == NULL)
1549                 g_object_unref(proxy);
1550         BT_DBG("-");
1551         return BLUETOOTH_ERROR_NONE;
1552 }
1553
1554 int _bt_discover_services(char *address, char *uuid, void *cb,
1555                 gpointer func_data)
1556 {
1557         char *object_path;
1558         GDBusProxy *proxy;
1559         GDBusProxy *adapter_proxy;
1560         GError *err = NULL;
1561         object_path = _bt_get_device_object_path(address);
1562         if (object_path == NULL) {
1563                 GVariant *ret = NULL;
1564                 BT_ERR("No searched device");
1565                 adapter_proxy = __bt_gdbus_get_adapter_proxy();
1566                 retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1567                 ret = g_dbus_proxy_call_sync(adapter_proxy, "CreateDevice",
1568                                 g_variant_new("(s)", address),
1569                                 G_DBUS_CALL_FLAGS_NONE,
1570                                 DBUS_TIMEOUT, NULL,
1571                                 &err);
1572                 if (err != NULL) {
1573                         BT_ERR("CreateDevice Failed: %s", err->message);
1574                         g_clear_error(&err);
1575                 }
1576                 if (ret)
1577                         g_variant_unref(ret);
1578                 g_object_unref(adapter_proxy);
1579                 object_path = _bt_get_device_object_path(address);
1580                 if (object_path == NULL)
1581                         return BLUETOOTH_ERROR_INTERNAL;
1582         }
1583         proxy = __bt_gdbus_get_device_proxy(object_path);
1584         g_free(object_path);
1585         if (proxy == NULL) {
1586                 BT_ERR("Error while getting proxy");
1587                 return BLUETOOTH_ERROR_INTERNAL;
1588         }
1589         g_dbus_proxy_call(proxy, "DiscoverServices",
1590                         g_variant_new("(s)", uuid),
1591                         G_DBUS_CALL_FLAGS_NONE,
1592                         DBUS_TIMEOUT, NULL,
1593                         (GAsyncReadyCallback)cb,
1594                         func_data);
1595         if (cb == NULL)
1596                 g_object_unref(proxy);
1597         BT_DBG("-");
1598         return BLUETOOTH_ERROR_NONE;
1599 }
1600
1601 int _bt_cancel_discovers(char *address)
1602 {
1603         char *object_path;
1604         GDBusProxy *proxy;
1605         GDBusProxy *adapter_proxy;
1606         GVariant *ret = NULL;
1607         GError *err = NULL;
1608         object_path = _bt_get_device_object_path(address);
1609         if (object_path == NULL) {
1610                 GVariant *ret = NULL;
1611                 BT_ERR("No searched device");
1612                 adapter_proxy = __bt_gdbus_get_adapter_proxy();
1613                 retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1614                 ret = g_dbus_proxy_call_sync(adapter_proxy, "CreateDevice",
1615                                 g_variant_new("(s)", address),
1616                                 G_DBUS_CALL_FLAGS_NONE,
1617                                 DBUS_TIMEOUT, NULL,
1618                                 &err);
1619                 if (err != NULL) {
1620                         BT_ERR("CreateDevice Failed: %s", err->message);
1621                         g_clear_error(&err);
1622                 }
1623                 if (ret)
1624                         g_variant_unref(ret);
1625                 g_object_unref(adapter_proxy);
1626                 object_path = _bt_get_device_object_path(address);
1627                 if (object_path == NULL)
1628                         return BLUETOOTH_ERROR_INTERNAL;
1629         }
1630         proxy = __bt_gdbus_get_device_proxy(object_path);
1631         g_free(object_path);
1632         ret = g_dbus_proxy_call_sync(proxy, "CancelDiscovery",
1633                 NULL,
1634                 G_DBUS_CALL_FLAGS_NONE,
1635                 DBUS_TIMEOUT, NULL,
1636                 &err);
1637         if (err) {
1638                 BT_ERR("DBus Error message: [%s]", err->message);
1639                 g_clear_error(&err);
1640                 return BLUETOOTH_ERROR_INTERNAL;
1641         }
1642         if (ret)
1643                 g_variant_unref(ret);
1644         if (proxy)
1645                 g_object_unref(proxy);
1646         return BLUETOOTH_ERROR_NONE;
1647 }
1648
1649 int _bt_discover_service_uuids(char *address, char *remote_uuid)
1650 {
1651         char *object_path;
1652         GDBusProxy *proxy;
1653         GDBusConnection *gconn;
1654         GError *err = NULL;
1655         char **uuid_value = NULL;
1656         gsize size = 0;
1657         int i = 0;
1658         GVariant *value = NULL;
1659         GVariant *ret = NULL;
1660         int result = BLUETOOTH_ERROR_INTERNAL;
1661
1662         retv_if(remote_uuid == NULL, BLUETOOTH_ERROR_INTERNAL);
1663         gconn = _bt_get_system_common_conn();
1664         retv_if(gconn == NULL, BLUETOOTH_ERROR_INTERNAL);
1665         object_path = _bt_get_device_object_path(address);
1666         retv_if(object_path == NULL, BLUETOOTH_ERROR_INTERNAL);
1667
1668         proxy = g_dbus_proxy_new_sync(gconn, G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES, NULL,
1669                                 BT_BLUEZ_NAME, object_path, BT_PROPERTIES_INTERFACE, NULL,
1670                                 &err);
1671         g_free(object_path);
1672         if (proxy == NULL) {
1673                 if (err) {
1674                         BT_ERR("DBus Error: [%s]", err->message);
1675                         g_clear_error(&err);
1676                 }
1677                 return BLUETOOTH_ERROR_INTERNAL;
1678         }
1679         ret = g_dbus_proxy_call_sync(proxy, "Get",
1680                         g_variant_new("(ss)", BT_DEVICE_INTERFACE, "UUIDs"),
1681                         G_DBUS_CALL_FLAGS_NONE, DBUS_TIMEOUT, NULL, &err);
1682         if (err) {
1683                 result = BLUETOOTH_ERROR_INTERNAL;
1684                 BT_ERR("DBus Error : %s", err->message);
1685                 g_clear_error(&err);
1686                 goto done;
1687         } else {
1688                 g_variant_get(ret, "(v)", &value);
1689                 uuid_value = (char **)g_variant_get_strv(value, &size);
1690                 BT_DBG("Size items %zd", size);
1691         }
1692
1693         if (uuid_value) {
1694                 for (i = 0; uuid_value[i] != NULL; i++) {
1695                         BT_DBG("Remote uuids %s", uuid_value[i]);
1696                         if (uuid_value[i] == NULL) {
1697                                 BT_ERR("_bt_discover_service_uuids Error Parameter are NULL..\n");
1698                                 continue;
1699                         } else if (g_ascii_strcasecmp(uuid_value[i], remote_uuid) == 0) {
1700                                 result = BLUETOOTH_ERROR_NONE;
1701                                 goto done;
1702                         }
1703                 }
1704         }
1705
1706 done:
1707         if (proxy)
1708                 g_object_unref(proxy);
1709         if (uuid_value)
1710                 g_free(uuid_value);
1711
1712         if (value)
1713                 g_variant_unref(value);
1714
1715         if (ret)
1716                 g_variant_unref(ret);
1717
1718         BT_DBG("-");
1719         return result;
1720 }
1721
1722 int _bt_get_cod_by_address(char *address, bluetooth_device_class_t *dev_class)
1723 {
1724         char *object_path;
1725         GDBusProxy *proxy;
1726         GDBusConnection *gconn;
1727         GError *err = NULL;
1728         GVariant *value = NULL;
1729         GVariant *result = NULL;
1730         unsigned int  class = 0x00;
1731         int ret = BLUETOOTH_ERROR_NONE;
1732
1733         gconn = _bt_get_system_common_conn();
1734         retv_if(gconn == NULL, BLUETOOTH_ERROR_INTERNAL);
1735
1736         object_path = _bt_get_device_object_path(address);
1737         retv_if(object_path == NULL, BLUETOOTH_ERROR_INTERNAL);
1738
1739         proxy = g_dbus_proxy_new_sync(gconn, G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES, NULL,
1740                                 BT_BLUEZ_NAME, object_path, BT_PROPERTIES_INTERFACE, NULL,
1741                                 &err);
1742         if (proxy == NULL) {
1743                 ret = BLUETOOTH_ERROR_INTERNAL;
1744                 if (err) {
1745                         BT_ERR("DBus Error: [%s]", err->message);
1746                         g_clear_error(&err);
1747                 }
1748                 goto done;
1749         }
1750
1751         result = g_dbus_proxy_call_sync(proxy, "Get",
1752                         g_variant_new("(ss)", BT_DEVICE_INTERFACE, "Class"),
1753                         G_DBUS_CALL_FLAGS_NONE, DBUS_TIMEOUT, NULL, &err);
1754         if (err) {
1755                 ret = BLUETOOTH_ERROR_INTERNAL;
1756                 BT_ERR("DBus Error : %s", err->message);
1757                 g_clear_error(&err);
1758                 goto done;
1759         } else {
1760                 g_variant_get(result, "(v)", &value);
1761                 class = g_variant_get_uint32(value);
1762                 _bt_divide_device_class(dev_class, class);
1763                 g_variant_unref(value);
1764                 g_variant_unref(result);
1765         }
1766
1767 done:
1768         g_free(object_path);
1769         if (proxy)
1770                 g_object_unref(proxy);
1771
1772         BT_DBG("-");
1773         return ret;
1774 }
1775
1776 int _bt_disconnect_profile(char *address, char *uuid, void *cb,
1777                                                         gpointer func_data)
1778 {
1779         GDBusProxy *proxy;
1780         char *object_path;
1781         GError *err = NULL;
1782         GDBusProxy *adapter_proxy;
1783         object_path = _bt_get_device_object_path(address);
1784         if (object_path == NULL) {
1785                 GVariant *ret = NULL;
1786                 BT_ERR("No searched device");
1787                 adapter_proxy = __bt_gdbus_get_adapter_proxy();
1788                 retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1789                 ret = g_dbus_proxy_call_sync(adapter_proxy, "CreateDevice",
1790                                 g_variant_new("(s)", address),
1791                                 G_DBUS_CALL_FLAGS_NONE,
1792                                 DBUS_TIMEOUT, NULL,
1793                                 &err);
1794                 if (err != NULL) {
1795                         BT_ERR("CreateDevice Failed: %s", err->message);
1796                         g_error_free(err);
1797                 }
1798                 if (ret)
1799                         g_variant_unref(ret);
1800                 g_object_unref(adapter_proxy);
1801                 object_path = _bt_get_device_object_path(address);
1802                 if (object_path == NULL)
1803                         return BLUETOOTH_ERROR_INTERNAL;
1804         }
1805         proxy = __bt_gdbus_get_device_proxy(object_path);
1806         g_free(object_path);
1807         if (proxy == NULL) {
1808                 BT_ERR("Error while getting proxy");
1809                 return BLUETOOTH_ERROR_INTERNAL;
1810         }
1811         g_dbus_proxy_call(proxy, "DisconnectProfile",
1812                         g_variant_new("(s)", uuid),
1813                         G_DBUS_CALL_FLAGS_NONE,
1814                         DBUS_TIMEOUT, NULL,
1815                         (GAsyncReadyCallback)cb,
1816                         func_data);
1817         if (cb == NULL)
1818                 g_object_unref(proxy);
1819         BT_DBG("-");
1820         return BLUETOOTH_ERROR_NONE;
1821 }
1822
1823 int _bt_disconnect_ext_profile(char *address, char *path)
1824 {
1825         GDBusProxy *proxy;
1826         char *object_path;
1827         GDBusConnection *gconn;
1828         GError *err = NULL;
1829
1830         object_path = _bt_get_device_object_path(address);
1831         if (object_path == NULL)
1832                 return BLUETOOTH_ERROR_INTERNAL;
1833
1834         gconn = _bt_get_system_shared_conn();
1835         if (gconn == NULL) {
1836                 g_free(object_path);
1837                 return BLUETOOTH_ERROR_INTERNAL;
1838         }
1839
1840         proxy = g_dbus_proxy_new_sync(gconn, G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES,
1841                                                 NULL, BT_BLUEZ_NAME,
1842                                                 object_path,
1843                                                 BT_DEVICE_INTERFACE,
1844                                                 NULL, &err);
1845
1846         g_free(object_path);
1847
1848         if (proxy == NULL && err) {
1849                 BT_ERR("Unable to create proxy: %s", err->message);
1850                 g_clear_error(&err);
1851                 return BLUETOOTH_ERROR_INTERNAL;
1852         }
1853
1854         g_dbus_proxy_call(proxy, "DisconnectExtProfile",
1855                         g_variant_new("(o)", path),
1856                         G_DBUS_CALL_FLAGS_NONE,
1857                         DBUS_TIMEOUT, NULL, NULL, NULL);
1858         g_object_unref(proxy);
1859         BT_DBG("-");
1860         return BLUETOOTH_ERROR_NONE;
1861 }
1862
1863 int _bt_get_adapter_path(GDBusConnection *conn, char *path)
1864 {
1865         GError *err = NULL;
1866         GDBusProxy *manager_proxy = NULL;
1867         GVariant *result = NULL;
1868         char *adapter_path = NULL;
1869
1870         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1871
1872         manager_proxy =  g_dbus_proxy_new_sync(conn,
1873                         G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES, NULL,
1874                         BT_BLUEZ_NAME,
1875                         BT_MANAGER_PATH,
1876                         BT_MANAGER_INTERFACE,
1877                         NULL, &err);
1878
1879         if (!manager_proxy) {
1880                 BT_ERR("Unable to create proxy: %s", err->message);
1881                 goto fail;
1882         }
1883
1884         result = g_dbus_proxy_call_sync(manager_proxy, "DefaultAdapter", NULL,
1885                         G_DBUS_CALL_FLAGS_NONE, -1, NULL, &err);
1886         if (!result) {
1887                 if (err != NULL) {
1888                         if (!g_strrstr(err->message, "ServiceUnknown"))
1889                                 BT_ERR("Fail to get DefaultAdapter (Error: %s)", err->message);
1890                 } else {
1891                         BT_ERR("Fail to get DefaultAdapter");
1892                 }
1893
1894                 goto fail;
1895         }
1896
1897         if (g_strcmp0(g_variant_get_type_string(result), "(o)")) {
1898                 BT_ERR("Incorrect result\n");
1899                 goto fail;
1900         }
1901
1902         g_variant_get(result, "(&o)", &adapter_path);
1903
1904         if (adapter_path == NULL ||
1905                 strlen(adapter_path) >= BT_ADAPTER_OBJECT_PATH_MAX) {
1906                 BT_ERR("Adapter path is inproper\n");
1907                 goto fail;
1908         }
1909
1910         if (path)
1911                 g_strlcpy(path, adapter_path, BT_ADAPTER_OBJECT_PATH_MAX);
1912
1913         g_variant_unref(result);
1914         g_object_unref(manager_proxy);
1915
1916         return BLUETOOTH_ERROR_NONE;
1917
1918 fail:
1919         g_clear_error(&err);
1920
1921         if (result)
1922                 g_variant_unref(result);
1923
1924         if (manager_proxy)
1925                 g_object_unref(manager_proxy);
1926
1927         return BLUETOOTH_ERROR_INTERNAL;
1928
1929 }
1930
1931 void _bt_convert_device_path_to_addr_type(const char *device_path,
1932                                           unsigned char *addr)
1933 {
1934         char *dev_addr;
1935         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
1936         int i;
1937         char *addr_ptr = address;
1938         char *ptr = NULL;
1939
1940         ret_if(device_path == NULL);
1941         ret_if(addr == NULL);
1942
1943         dev_addr = strstr(device_path, "dev_");
1944         if (dev_addr != NULL) {
1945                 dev_addr += 4;
1946                 g_strlcpy(addr_ptr, dev_addr, BT_ADDRESS_STRING_SIZE);
1947
1948                 for (i = 0; i < BT_ADDRESS_LENGTH_MAX; i++) {
1949                         addr[i] = strtol(addr_ptr, &ptr, 16);
1950                         if (ptr[0] != '\0') {
1951                                 if (ptr[0] != '_')
1952                                         return;
1953
1954                                 addr_ptr = ptr + 1;
1955                         }
1956                 }
1957         }
1958 }
1959
1960 void _bt_convert_device_path_to_address(const char *device_path,
1961                                                 char *device_address)
1962 {
1963         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
1964         char *dev_addr;
1965
1966         ret_if(device_path == NULL);
1967         ret_if(device_address == NULL);
1968
1969         dev_addr = strstr(device_path, "dev_");
1970         if (dev_addr != NULL) {
1971                 char *pos = NULL;
1972                 dev_addr += 4;
1973                 g_strlcpy(address, dev_addr, sizeof(address));
1974
1975                 while ((pos = strchr(address, '_')) != NULL)
1976                         *pos = ':';
1977
1978                 g_strlcpy(device_address, address, BT_ADDRESS_STRING_SIZE);
1979         }
1980 }
1981
1982 static char *__bt_extract_device_path(GVariantIter *iter, char *address)
1983 {
1984         char *object_path = NULL;
1985         char device_address[BT_ADDRESS_STRING_SIZE] = { 0 };
1986         /* Parse the signature:  oa{sa{sv}}} */
1987         while (g_variant_iter_loop(iter, "{&oa{sa{sv}}}", &object_path,
1988                         NULL)) {
1989                 retv_if(object_path == NULL, NULL);
1990                 _bt_convert_device_path_to_address(object_path, device_address);
1991
1992                 if (g_strcmp0(address, device_address) == 0)
1993                         return g_strdup(object_path);
1994         }
1995         return NULL;
1996 }
1997
1998 char *_bt_get_device_object_path(char *address)
1999 {
2000         GError *err = NULL;
2001         GDBusProxy *proxy = NULL;
2002         GVariant *result = NULL;
2003         GVariantIter *iter = NULL;
2004         GDBusConnection *conn = NULL;
2005         char *object_path = NULL;
2006
2007         conn = _bt_get_system_common_conn();
2008         retv_if(conn == NULL, NULL);
2009
2010         proxy =  g_dbus_proxy_new_sync(conn,
2011                         G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES, NULL,
2012                         BT_BLUEZ_NAME,
2013                         BT_MANAGER_PATH,
2014                         BT_MANAGER_INTERFACE,
2015                         NULL, &err);
2016
2017         if (!proxy) {
2018                 BT_ERR("Unable to create proxy: %s", err->message);
2019                 goto fail;
2020         }
2021
2022         result = g_dbus_proxy_call_sync(proxy, "GetManagedObjects", NULL,
2023                         G_DBUS_CALL_FLAGS_NONE, -1, NULL, &err);
2024         if (!result) {
2025                 if (err != NULL)
2026                         BT_ERR("Fail to get GetManagedObjects (Error: %s)", err->message);
2027                 else
2028                         BT_ERR("Fail to get GetManagedObjects");
2029
2030                 goto fail;
2031         }
2032
2033         g_variant_get(result, "(a{oa{sa{sv}}})", &iter);
2034         object_path = __bt_extract_device_path(iter, address);
2035
2036         g_variant_unref(result);
2037         g_object_unref(proxy);
2038         g_variant_iter_free(iter);
2039         return object_path;
2040
2041 fail:
2042         g_clear_error(&err);
2043
2044         if (proxy)
2045                 g_object_unref(proxy);
2046
2047         return object_path;
2048 }
2049
2050 int _bt_register_osp_server_in_agent(int type, char *uuid, char *path, int fd)
2051 {
2052         int ret;
2053         char uuid_str[BLUETOOTH_UUID_STRING_MAX] = { 0, };
2054         char path_str[BLUETOOTH_PATH_STRING] = { 0, };
2055
2056         BT_DBG("+");
2057         BT_INIT_PARAMS();
2058         BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
2059
2060         g_array_append_vals(in_param1, &type, sizeof(int));
2061         g_strlcpy(uuid_str, uuid, sizeof(uuid_str));
2062         g_array_append_vals(in_param2, &uuid_str, BLUETOOTH_UUID_STRING_MAX);
2063         g_strlcpy(path_str, path, sizeof(path_str));
2064         g_array_append_vals(in_param3, &path_str, BLUETOOTH_PATH_STRING);
2065         g_array_append_vals(in_param4, &fd, sizeof(int));
2066
2067         ret =  _bt_send_request(BT_AGENT_SERVICE, BT_SET_AUTHORIZATION,
2068                 in_param1, in_param2, in_param3, in_param4, &out_param);
2069
2070         BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
2071         BT_DBG("-");
2072         return ret;
2073 }
2074
2075 int _bt_unregister_osp_server_in_agent(int type, char *uuid)
2076 {
2077         int ret;
2078         char uuid_str[BLUETOOTH_UUID_STRING_MAX] = { 0, };
2079
2080         BT_DBG("+");
2081         BT_INIT_PARAMS();
2082         BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
2083
2084         g_array_append_vals(in_param1, &type, sizeof(int));
2085         g_strlcpy(uuid_str, uuid, sizeof(uuid_str));
2086         g_array_append_vals(in_param2, &uuid_str, BLUETOOTH_UUID_STRING_MAX);
2087
2088         ret =  _bt_send_request(BT_AGENT_SERVICE, BT_UNSET_AUTHORIZATION,
2089                 in_param1, in_param2, in_param3, in_param4, &out_param);
2090
2091         BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
2092         BT_DBG("-");
2093         return ret;
2094 }
2095
2096 int _bt_check_privilege(int service_type, int service_function)
2097 {
2098         int result;
2099
2100         BT_CHECK_ENABLED(return);
2101
2102         BT_INIT_PARAMS();
2103         BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
2104
2105         result = _bt_sync_send_request(service_type, service_function,
2106                 in_param1, in_param2, in_param3, in_param4, &out_param);
2107
2108         BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
2109
2110         return result;
2111 }
2112
2113 int _bt_check_privilege_le(int service_type, int service_function)
2114 {
2115         int result;
2116
2117         BT_CHECK_ENABLED_LE(return);
2118
2119         BT_INIT_PARAMS();
2120         BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
2121
2122         result = _bt_sync_send_request(service_type, service_function,
2123                 in_param1, in_param2, in_param3, in_param4, &out_param);
2124
2125         BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
2126
2127         return result;
2128 }
2129
2130 GVariant *_bt_get_managed_objects(void)
2131 {
2132         GDBusConnection *g_conn;
2133         GDBusProxy *manager_proxy = NULL;
2134         GVariant *result = NULL;
2135         GError *error = NULL;
2136
2137         BT_DBG("+");
2138
2139         g_conn = _bt_get_system_common_conn();
2140         retv_if(g_conn == NULL, NULL);
2141
2142         manager_proxy = g_dbus_proxy_new_sync(g_conn,
2143                         G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES, NULL,
2144                         BT_BLUEZ_NAME,
2145                         BT_MANAGER_PATH,
2146                         BT_MANAGER_INTERFACE,
2147                         NULL, &error);
2148
2149         if (error) {
2150                 BT_ERR("Unable to create proxy: %s", error->message);
2151                 g_clear_error(&error);
2152                 if (manager_proxy)
2153                         g_object_unref(manager_proxy);
2154                 return NULL;
2155         }
2156
2157         if (!manager_proxy)
2158                 return NULL;
2159
2160         result = g_dbus_proxy_call_sync(manager_proxy,
2161                         "GetManagedObjects", NULL,
2162                         G_DBUS_CALL_FLAGS_NONE, -1,
2163                         NULL, &error);
2164
2165         if (error) {
2166                 BT_ERR("Fail to get ManagedObjects (Error: %s)", error->message);
2167                 g_clear_error(&error);
2168         }
2169
2170         g_object_unref(manager_proxy);
2171
2172         BT_DBG("-");
2173         return result;
2174 }
2175
2176 gboolean _bt_check_enabled_internal(void)
2177 {
2178         if (bt_enabled == TRUE)
2179                 return TRUE;
2180
2181         if (bluetooth_check_adapter() == BLUETOOTH_ADAPTER_ENABLED)
2182                 bt_enabled = TRUE;
2183
2184         return bt_enabled;
2185 }
2186
2187 void _bt_set_adapter_internal_status(gboolean enabled)
2188 {
2189         bt_enabled = enabled;
2190 }
2191
2192 BT_EXPORT_API int bluetooth_get_uuid_name(const char *uuid, char **name)
2193 {
2194 #define SHORT_UUID_COUNT        199
2195 #define LONG_UUID_COUNT         17
2196
2197         int offset = 0;
2198         int uuid_len = 4;
2199         typedef struct {
2200                 const char *uuid;
2201                 const char *specification_name;
2202         } uuid_name_s;
2203         static uuid_name_s short_uuid_name[SHORT_UUID_COUNT] = {
2204                 // List should be sorted by UUID
2205                 /* BT Classic Services */
2206                 {"1101", "Serial Port Service"},
2207                 {"1102", "LAN Access Using PPP Service"},
2208                 {"1103", "Dialup Networking Service"},
2209                 {"1104", "IrMCSync Service"},
2210                 {"1105", "OBEX Object Push Service"},
2211                 {"1106", "OBEX File Transfer Service"},
2212                 {"1107", "IrMC Sync Command Service"},
2213                 {"1108", "Headset Service"},
2214                 {"1109", "Cordless Telephony Service"},
2215                 {"110A", "Audio Source Service"},
2216                 {"110B", "Audio Sink Service"},
2217                 {"110C", "AV Remote Control Target Service"},
2218                 {"110D", "Advanced Audio Distribution Profile"},
2219                 {"110E", "AV Remote Control Service"},
2220                 {"110F", "Video Conferencing Service"},
2221                 {"1110", "Intercom Service"},
2222                 {"1111", "Fax Service"},
2223                 {"1112", "Headset Audio Gateway Service"},
2224                 {"1113", "WAP Service"},
2225                 {"1114", "WAP Client Service"},
2226                 {"1115", "PANU Service"},
2227                 {"1116", "NAP Service"},
2228                 {"1117", "GN Service"},
2229                 {"1118", "Direct Printing Service"},
2230                 {"1119", "Reference Printing Service"},
2231                 {"111A", "Basic Imaging Profile"},
2232                 {"111B", "Imaging Responder Service"},
2233                 {"111C", "Imaging Automatic Archive Service"},
2234                 {"111D", "Imaging Reference Objects Service"},
2235                 {"111E", "Handsfree Service"},
2236                 {"111F", "Handsfree Audio Gateway Service"},
2237                 {"1120", "Direct Printing Reference Objects Service"},
2238                 {"1121", "Reflected UI Service"},
2239                 {"1122", "Basic Printing Profile"},
2240                 {"1123", "Printing Status Service"},
2241                 {"1124", "Human Interface Device Service"},
2242                 {"1125", "Hardcopy Cable Replacement Profile"},
2243                 {"1126", "HCR Print Service"},
2244                 {"1127", "HCR Scan Service"},
2245                 {"112D", "SIM Access Service"},
2246                 {"112E", "Phonebook Access PCE Service"},
2247                 {"112F", "Phonebook Access PSE Service"},
2248                 {"1130", "Phonebook Access Profile"},
2249                 {"1132", "Message Access Server Service"},
2250                 {"1133", "Message Notification Server Service"},
2251                 {"1134", "Message Access Profile"},
2252                 {"1200", "PnP Information Service"},
2253                 {"1201", "Generic Networking Service"},
2254                 {"1202", "Generic File Transfer Service"},
2255                 {"1203", "Generic Audio Service"},
2256                 {"1204", "Generic Telephony Service"},
2257                 {"1205", "UPnP Service"},
2258                 {"1206", "UPnP Ip Service"},
2259                 {"1303", "Video Source Service"},
2260                 {"1304", "Video Sink Service"},
2261                 {"1305", "Video Distribution Profile"},
2262                 {"1400", "Health Device Profile"},
2263                 {"1401", "HDP Source Service"},
2264                 {"1402", "HDP Sink Service"},
2265
2266                 /* GATT Services */
2267                 {"1800", "Generic Access"},
2268                 {"1801", "Generic Attribute"},
2269                 {"1802", "Immediate Alert"},
2270                 {"1803", "Link Loss"},
2271                 {"1804", "Tx Power"},
2272                 {"1805", "Current Time Service"},
2273                 {"1806", "Reference Time Update Service"},
2274                 {"1807", "Next DST Change Service"},
2275                 {"1808", "Glucose"},
2276                 {"1809", "Health Thermometer"},
2277                 {"180A", "Device Information"},
2278                 {"180D", "Heart Rate"},
2279                 {"180F", "Battery Service"},
2280                 {"1810", "Blood Pressure"},
2281                 {"1811", "Alert Notification Service"},
2282                 {"1812", "Human Interface Device"},
2283                 {"1813", "Scan Parameters"},
2284                 {"1814", "Running Speed and Cadence"},
2285                 {"1815", "Automation IO"},
2286                 {"1816", "Cycling Speed and Cadence"},
2287                 {"1818", "Cycling Power"},
2288                 {"1819", "Location and Navigation"},
2289                 {"181A", "Environmental Sensing"},
2290                 {"181B", "Body Composition"},
2291                 {"181C", "User Data"},
2292                 {"181D", "Weight Scale"},
2293                 {"181E", "Bond Management"},
2294                 {"181F", "Continuous Glucose Monitoring"},
2295                 {"1820", "Internet Protocol Support Service"},
2296                 {"1821", "Indoor Positioning"},
2297                 {"1822", "Pulse Oximeter Service"},
2298                 {"1823", "HTTP Proxy"},
2299                 {"1824", "Transport Discovery"},
2300                 {"1825", "Object Transfer Service"},
2301                 {"1826", "Fitness Machine"},
2302                 {"1827", "Mesh Provisioning Service"},
2303                 {"1828", "Mesh Proxy Service"},
2304                 {"1829", "Reconnection Configuration"},
2305                 {"183A", "Insulin Delivery"},
2306
2307                 /* GATT Declarations */
2308                 {"2800", "Primary Service Declaration"},
2309                 {"2801", "Secondary Service Declaration"},
2310                 {"2802", "Include Declaration"},
2311                 {"2803", "Characteristic Declaration"},
2312
2313                 /* GATT Descriptors */
2314                 {"2900", "Characteristic Extended Properties"},
2315                 {"2901", "Characteristic User Description"},
2316                 {"2902", "Client Characteristic Configuration"},
2317                 {"2903", "Server Characteristic Configuration"},
2318                 {"2904", "Characteristic Format"},
2319                 {"2905", "Characteristic Aggregate Formate"},
2320                 {"2906", "Valid Range"},
2321                 {"2907", "External Report Reference"},
2322                 {"2908", "Report Reference"},
2323
2324                 /* GATT Characteristics */
2325                 {"2A00", "Device Name"},
2326                 {"2A01", "Appearance"},
2327                 {"2A02", "Peripheral Privacy Flag"},
2328                 {"2A03", "Reconnection Address"},
2329                 {"2A04", "Peripheral Preferred Connection Parameters"},
2330                 {"2A05", "Service Changed"},
2331                 {"2A06", "Alert Level"},
2332                 {"2A07", "Tx Power Level"},
2333                 {"2A08", "Date Time"},
2334                 {"2A09", "Day of Week"},
2335                 {"2A0A", "Day Date Time"},
2336                 {"2A11", "Time with DST"},
2337                 {"2A12", "Time Accuracy"},
2338                 {"2A13", "Time Source"},
2339                 {"2A14", "Reference Time Information"},
2340                 {"2A16", "Time Update Control Point"},
2341                 {"2A17", "Time Update State"},
2342                 {"2A18", "Glucose Measurement"},
2343                 {"2A19", "Battery Level"},
2344                 {"2A1C", "Temperature Measurement"},
2345                 {"2A1D", "Temperature Type"},
2346                 {"2A1E", "Intermediate Temperature"},
2347                 {"2A21", "Measurement Interval"},
2348                 {"2A23", "System ID"},
2349                 {"2A24", "Model Number String"},
2350                 {"2A25", "Serial Number String"},
2351                 {"2A26", "Firmware Revision String"},
2352                 {"2A27", "Hardware Revision String"},
2353                 {"2A28", "Software Revision String"},
2354                 {"2A29", "Manufacturer Name String"},
2355                 {"2A2A", "IEEE 11073-20601 Regulatory Certification Data List"},
2356                 {"2A2B", "Current Time"},
2357                 {"2A34", "Glucose Measurement Context"},
2358                 {"2A35", "Blood Pressure Measurement"},
2359                 {"2A37", "Heart Rate Measurement"},
2360                 {"2A38", "Body Sensor Location"},
2361                 {"2A39", "Heart Rate Control Point"},
2362                 {"2A3F", "Alert Status"},
2363                 {"2A46", "New Alert"},
2364                 {"2A49", "Blood Pressure Feature"},
2365                 {"2A4A", "HID Information"},
2366                 {"2A4C", "HID Control Point"},
2367                 {"2A50", "PnP ID"},
2368                 {"2A51", "Glucose Feature"},
2369                 {"2A52", "Record Access Control Point"},
2370                 {"2A53", "RSC Measurement"},
2371                 {"2A54", "RSC Feature"},
2372                 {"2A55", "SC Control Point"},
2373                 {"2A56", "Digital"},
2374                 {"2A58", "Analog"},
2375                 {"2A5A", "Aggregate"},
2376                 {"2A5B", "CSC Measurement"},
2377                 {"2A5C", "CSC Feature"},
2378                 {"2A5D", "Sensor Location"},
2379                 {"2A63", "Cycling Power Measurement"},
2380                 {"2A64", "Cycling Power Vector"},
2381                 {"2A65", "Cycling Power Feature"},
2382                 {"2A66", "Cycling Power Control Point"},
2383                 {"2A67", "Location and Speed"},
2384                 {"2A68", "Navigation"},
2385                 {"2A6D", "Pressure"},
2386                 {"2A6E", "Temperature"},
2387                 {"2A8E", "Height"},
2388                 {"2A90", "Last Name"},
2389                 {"2A91", "Maximum Recommended Heart Rate"},
2390                 {"2A92", "Resting Heart Rate"},
2391                 {"2A98", "Weight"},
2392                 {"2A9B", "Body Composition Feature"},
2393                 {"2A9C", "Body Composition Measurement"},
2394                 {"2A9D", "Weight Measurement"},
2395                 {"2AA2", "Language"},
2396                 {"2AA4", "Bond Management Control Point"},
2397                 {"2AA5", "Bond Management Features"},
2398                 {"2AA6", "Central Address Resolution"},
2399                 {"2AAD", "Indoor Positioning Configuration"},
2400                 {"2AB5", "Location Name"},
2401                 {"2AB6", "URI"},
2402                 {"2ABC", "TDS Control Point"},
2403                 {"2AC9", "Resolvable Private Address Only"},
2404                 {"2ACC", "Fitness Machine Feature"},
2405                 {"2ACE", "Cross Trainer Data"},
2406                 {"2AD3", "Training Status"},
2407                 {"2AD7", "Supported Heart Rate Range"},
2408                 {"2AD9", "Fitness Machine Control Point"},
2409                 {"2ADA", "Fitness Machine Status"},
2410                 {"2B1D", "RC Feature"},
2411                 {"2B1E", "RC Settings"},
2412                 {"2B1F", "Reconnection Configuration Control Point"},
2413         };
2414         static uuid_name_s long_uuid_name[LONG_UUID_COUNT] = {
2415                 // List should be sorted by UUID
2416                 /* Custom uuids */
2417                 {"1AB7C24D-185A-45B9-90D4-F7AB1A71949A", "Samsung Health Service"},
2418                 {"22EAC6E9-24D6-4BB5-BE44-B36ACE7C7BFB", "Data Source"},
2419                 {"2F7CABCE-808D-411F-9A0C-BB92BA96C102", "Entity Update"},
2420                 {"32D1955A-E5AA-4A96-9A49-08538DA8B8F6", "Samsung Gear Fit Manager Service"},
2421                 {"69D1D8F3-45E1-49A8-9821-9BBDFDAAD9D9", "Control Point"},
2422                 {"7905F431-B5CE-4E99-A40F-4B1E122D00D0", "Apple Notification Center Service"},
2423                 {"89D3502B-0F36-433A-8EF4-C502AD55F8DC", "Apple Media Service"},
2424                 {"9A3F68E0-86CE-11E5-A309-0002A5D5C51B", "Samsung Gear Manager Service"},
2425                 {"9B3C81D8-57B1-4A8A-B8DF-0E56F7CA51C2", "Remote Command"},
2426                 {"9FBF120D-6301-42D9-8C58-25E699A21DBD", "Notifications Source"},
2427                 {"A49EB41E-CB06-495C-9F4F-BB80A90CDF00", "Samsung Gear Manager Service"},
2428                 {"ADE3D529-C784-4F63-A987-EB69F70EE816", "IoT OIC Service"},
2429                 {"C2051EE0-804D-4D50-A12C-15E243852100", "Notifications Source"},
2430                 {"C2F2CC0F-C085-4DD4-BE5A-ACA3074BBC72", "Control Point"},
2431                 {"C6B2F38C-23AB-46D8-A6AB-A3A870BBD5D7", "Entity Attribute"},
2432                 {"CECE518B-28D7-4171-92D5-76A1E249A3B9", "Notifications Source"},
2433                 {"FE53FF98-B259-4337-B56A-0EC9F82C6BAD", "Control Point"},
2434         };
2435         const uuid_name_s *uuid_name = short_uuid_name;
2436         int start = 0;
2437         int end = SHORT_UUID_COUNT - 1;
2438         int p;
2439         int ret;
2440
2441         if (!uuid || !name)
2442                 return BLUETOOTH_ERROR_INVALID_PARAM;
2443         if (strlen(uuid) == 36) {
2444                 if (!g_ascii_strncasecmp(uuid + 9, "0000-1000-8000-00805F9B34FB", 27))
2445                         offset = 4;
2446                 else {
2447                         offset = 0;
2448                         uuid_len = 36;
2449                         end = LONG_UUID_COUNT - 1;
2450                         uuid_name = long_uuid_name;
2451                 }
2452         } else if (strlen(uuid) >= 8)
2453                 offset = 4;
2454
2455         while (start <= end) {
2456                 p = start + (end - start) / 2;
2457                 ret = g_ascii_strncasecmp(uuid + offset, uuid_name[p].uuid, uuid_len);
2458                 if (ret == 0) {
2459                         *name = g_strdup(uuid_name[p].specification_name);
2460                         return BLUETOOTH_ERROR_NONE;
2461                 } else if (ret < 0)
2462                         end = p - 1;
2463                 else
2464                         start = p + 1;
2465         }
2466
2467         *name = g_strdup("Unknown");
2468         return BLUETOOTH_ERROR_NONE;
2469 }
2470
2471 int _bt_get_error_value_from_message(const char *error_message)
2472 {
2473         if (error_message == NULL) {
2474                 BT_ERR("Error message NULL");
2475                 return BLUETOOTH_ERROR_INTERNAL;
2476         }
2477
2478         BT_ERR("Error message = %s", error_message);
2479
2480         if (g_strrstr(error_message, BT_ERROR_OPERATION_NOT_SUPPORTED))
2481                 return BLUETOOTH_ERROR_NOT_IN_OPERATION;
2482         else if (g_strrstr(error_message, BT_ERROR_OPERATION_NOT_ALLOWED))
2483                 return BLUETOOTH_ERROR_PERMISSION_DEINED;
2484         else if (g_strrstr(error_message, BT_ERROR_ACCESS_DENIED))
2485                 return BLUETOOTH_ERROR_PERMISSION_DEINED;
2486         else
2487                 return BLUETOOTH_ERROR_INTERNAL;
2488 }
2489
2490 char *_bt_print_gio_status(GIOStatus status)
2491 {
2492         switch (status) {
2493         case G_IO_STATUS_ERROR:
2494                 return "G_IO_STATUS_ERROR";
2495         case G_IO_STATUS_NORMAL:
2496                 return "G_IO_STATUS_NORMAL";
2497         case G_IO_STATUS_EOF:
2498                 return "G_IO_STATUS_EOF";
2499         case G_IO_STATUS_AGAIN:
2500                 return "G_IO_STATUS_AGAIN";
2501         }
2502
2503         return "Unknown";
2504 }
2505
2506 BT_EXPORT_API int bluetooth_is_supported(void)
2507 {
2508         int is_supported = 0;
2509         int len = 0;
2510         int fd = -1;
2511         rfkill_event event;
2512
2513         fd = open(RFKILL_NODE, O_RDONLY);
2514         if (fd < 0) {
2515                 BT_ERR("Fail to open RFKILL node");
2516                 return BLUETOOTH_ERROR_INTERNAL;
2517         }
2518
2519         if (fcntl(fd, F_SETFL, O_NONBLOCK) < 0) {
2520                 BT_ERR("Fail to set RFKILL node to non-blocking");
2521                 close(fd);
2522                 return BLUETOOTH_ERROR_INTERNAL;
2523         }
2524
2525         while (1) {
2526                 len = read(fd, &event, sizeof(event));
2527                 if (len < 0) {
2528                         BT_ERR("Fail to read events");
2529                         break;
2530                 }
2531
2532                 if (len != RFKILL_EVENT_SIZE) {
2533                         BT_ERR("The size is wrong\n");
2534                         continue;
2535                 }
2536
2537                 if (event.type == RFKILL_TYPE_BLUETOOTH) {
2538                         is_supported = 1;
2539                         break;
2540                 }
2541         }
2542
2543         close(fd);
2544
2545         BT_DBG("supported: %d", is_supported);
2546
2547         return is_supported;
2548 }
2549
2550 BT_EXPORT_API int bluetooth_register_callback(bluetooth_cb_func_ptr callback_ptr, void *user_data)
2551 {
2552         int ret;
2553
2554         _bt_get_system_common_conn();
2555
2556         ret = _bt_init_event_handler();
2557         if (ret != BLUETOOTH_ERROR_NONE &&
2558              ret != BLUETOOTH_ERROR_ALREADY_INITIALIZED) {
2559                 BT_ERR("Fail to init the event handler");
2560                 return ret;
2561         }
2562
2563
2564         _bt_set_user_data(BT_COMMON, (void *)callback_ptr, user_data);
2565
2566         /* Register All events */
2567         if (ret != BLUETOOTH_ERROR_ALREADY_INITIALIZED) {
2568                 ret = _bt_register_event(BT_ADAPTER_EVENT, (void *)callback_ptr, user_data);
2569                 if (ret != BLUETOOTH_ERROR_NONE)
2570                         goto fail;
2571                 ret = _bt_register_event(BT_DEVICE_EVENT, (void *)callback_ptr, user_data);
2572                 if (ret != BLUETOOTH_ERROR_NONE)
2573                         goto fail;
2574                 ret = _bt_register_event(BT_NETWORK_EVENT, (void *)callback_ptr, user_data);
2575                 if (ret != BLUETOOTH_ERROR_NONE)
2576                         goto fail;
2577                 ret = _bt_register_event(BT_RFCOMM_CLIENT_EVENT, (void *)callback_ptr, user_data);
2578                 if (ret != BLUETOOTH_ERROR_NONE)
2579                         goto fail;
2580                 ret = _bt_register_event(BT_RFCOMM_SERVER_EVENT, (void *)callback_ptr, user_data);
2581                 if (ret != BLUETOOTH_ERROR_NONE)
2582                         goto fail;
2583
2584 #ifdef GATT_NO_RELAY
2585                 ret = _bt_register_event(BT_GATT_BLUEZ_EVENT, (void *)callback_ptr, user_data);
2586                 if (ret != BLUETOOTH_ERROR_NONE)
2587                         goto fail;
2588 #endif
2589                 ret = _bt_register_event(BT_TDS_EVENT, (void *)callback_ptr, user_data);
2590                 if (ret != BLUETOOTH_ERROR_NONE)
2591                         goto fail;
2592                 ret = _bt_register_event(BT_OTP_EVENT, (void *)callback_ptr, user_data);
2593                 if (ret != BLUETOOTH_ERROR_NONE)
2594                         goto fail;
2595                 ret = _bt_register_event(BT_HDP_EVENT, (void *)callback_ptr, user_data);
2596                 if (ret != BLUETOOTH_ERROR_NONE)
2597                         goto fail;
2598                 ret = _bt_register_event(BT_L2CAP_LE_CLIENT_EVENT, (void *)callback_ptr, user_data);
2599                 if (ret != BLUETOOTH_ERROR_NONE)
2600                         goto fail;
2601                 ret = _bt_register_event(BT_L2CAP_LE_SERVER_EVENT, (void *)callback_ptr, user_data);
2602                 if (ret != BLUETOOTH_ERROR_NONE)
2603                         goto fail;
2604         }
2605
2606         _bt_register_name_owner_changed();
2607
2608         return BLUETOOTH_ERROR_NONE;
2609 fail:
2610         BT_ERR("Fail to do _bt_register_event()");
2611         bluetooth_unregister_callback();
2612         return ret;
2613 }
2614
2615 BT_EXPORT_API int bluetooth_unregister_callback(void)
2616 {
2617         int ret;
2618
2619         ret = _bt_deinit_event_handler();
2620         if (ret != BLUETOOTH_ERROR_NONE)
2621                 BT_ERR("Fail to deinit the event handler");
2622
2623         _bt_unregister_name_owner_changed();
2624
2625         _bt_set_user_data(BT_COMMON, NULL, NULL);
2626
2627         _bt_set_obex_server_id(BT_NO_SERVER);
2628
2629         _bt_reset_battery_monitor_info();
2630
2631         _bt_gdbus_deinit_proxys();
2632
2633         if (profile_gproxy) {
2634                 g_object_unref(profile_gproxy);
2635                 profile_gproxy = NULL;
2636         }
2637
2638         if (system_common_conn) {
2639                 g_object_unref(system_common_conn);
2640                 system_common_conn = NULL;
2641         }
2642
2643         return BLUETOOTH_ERROR_NONE;
2644 }
2645
2646 static void __bt_fill_garray_from_variant(GVariant *var, GArray *param)
2647 {
2648         char *data;
2649         int size;
2650
2651         size = g_variant_get_size(var);
2652         if (size > 0) {
2653                 data = (char *)g_variant_get_data(var);
2654                 if (data)
2655                          param = g_array_append_vals(param, data, size);
2656         }
2657 }
2658
2659 /* TODO_40 : 4.0 merge  */
2660 /* Don't use this function directly. Instead of it, get the out parameter only */
2661 static void __bt_get_event_info(int service_function, GArray *output,
2662                 int *event, int *event_type, void **param_data)
2663 {
2664         ret_if(event == NULL);
2665
2666         BT_INFO("service_function : %s (0x%x)",
2667                 _bt_convert_service_function_to_string(service_function),
2668                 service_function);
2669         switch (service_function) {
2670         case BT_L2CAP_LE_CLIENT_CONNECT:
2671                 *event_type = BT_L2CAP_LE_CLIENT_EVENT;
2672                 *event = BLUETOOTH_EVENT_L2CAP_LE_CONNECTED;
2673                 ret_if(output == NULL);
2674                 *param_data = &g_array_index(output,
2675                         bluetooth_l2cap_le_connection_t, 0);
2676                 break;
2677         case BT_RFCOMM_CLIENT_CONNECT:
2678                 *event_type = BT_RFCOMM_CLIENT_EVENT;
2679                 *event = BLUETOOTH_EVENT_RFCOMM_CONNECTED;
2680                 ret_if(output == NULL);
2681                 *param_data = &g_array_index(output,
2682                         bluetooth_rfcomm_connection_t, 0);
2683                 break;
2684         default:
2685                 BT_ERR("Unknown function");
2686                 return;
2687         }
2688 }
2689
2690 void _bt_get_fd_list_info(GDBusProxy *proxy, GAsyncResult *res, gpointer user_data, bluetooth_event_param_t *bt_event, GArray **out_param1,
2691                 int *event_type, GUnixFDList **out_fd_list, int *result, gboolean *fail)
2692 {
2693         bt_req_info_t *cb_data = user_data;
2694
2695         GError *error = NULL;
2696         GVariant *value;
2697         GVariant *param1;
2698
2699         BT_DBG("+");
2700
2701         memset(bt_event, 0x00, sizeof(bluetooth_event_param_t));
2702
2703         value = g_dbus_proxy_call_with_unix_fd_list_finish(proxy, out_fd_list, res, &error);
2704         if (value == NULL) {
2705                 if (error) {
2706                         /* dBUS gives error cause */
2707                         BT_ERR("D-Bus API failure: message[%s]",
2708                                         error->message);
2709                         g_clear_error(&error);
2710                 }
2711                 *result = BLUETOOTH_ERROR_TIMEOUT;
2712
2713                 ret_if(cb_data == NULL);
2714
2715                 __bt_get_event_info(cb_data->service_function, NULL,
2716                                 &bt_event->event, event_type,
2717                                 &bt_event->param_data);
2718                 *fail = true;
2719                 return;
2720         }
2721
2722         g_variant_get(value, "(iv)", result, &param1);
2723         g_variant_unref(value);
2724
2725         if (param1) {
2726                 *out_param1 = g_array_new(TRUE, TRUE, sizeof(gchar));
2727                 __bt_fill_garray_from_variant(param1, *out_param1);
2728                 g_variant_unref(param1);
2729         }
2730
2731         if (!cb_data)
2732                 return;
2733
2734         __bt_get_event_info(cb_data->service_function, *out_param1,
2735                         &bt_event->event, event_type,
2736                         &bt_event->param_data);
2737         return;
2738 }