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