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