Fix SVace issue.
[platform/core/connectivity/bluetooth-frwk.git] / bt-service / bt-service-common.c
index 4b43c34..8dc9985 100644 (file)
@@ -23,7 +23,6 @@
 #include <errno.h>
 #include <termios.h>
 #include <net_connection.h>
-#include <dbus/dbus.h>
 #include <glib.h>
 #include <dlog.h>
 #include <fcntl.h>
 #include "bluetooth-api.h"
 #include "bt-service-common.h"
 #include "bt-service-agent.h"
+#include "bt-internal-types.h"
 
 static GDBusConnection *system_conn;
 static GDBusConnection *session_conn;
 static GDBusProxy *manager_proxy;
 static GDBusProxy *adapter_proxy;
+static GDBusProxy *ipsp_proxy;
 static void *net_conn;
 
 static GDBusProxy *adapter_properties_proxy;
 
-static GDBusConnection *system_gconn = NULL;
-
 GDBusConnection *_bt_gdbus_init_system_gconn(void)
 {
        GError *error = NULL;
 
-       dbus_threads_init_default();
-
-       if (system_gconn != NULL)
-               return system_gconn;
+       if (system_conn != NULL)
+               return system_conn;
 
-       system_gconn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
+       system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
 
-       if (!system_gconn) {
+       if (!system_conn) {
                BT_ERR("Unable to connect to dbus: %s", error->message);
                g_clear_error(&error);
        }
 
-       return system_gconn;
+       return system_conn;
 }
 
 GDBusConnection *_bt_gdbus_get_system_gconn(void)
@@ -71,10 +68,9 @@ GDBusConnection *_bt_gdbus_get_system_gconn(void)
        GDBusConnection *local_system_gconn = NULL;
        GError *error = NULL;
 
-       if (system_gconn == NULL) {
-               system_gconn = _bt_gdbus_init_system_gconn();
-       } else if (g_dbus_connection_is_closed(system_gconn)) {
-
+       if (system_conn == NULL) {
+               system_conn = _bt_gdbus_init_system_gconn();
+       } else if (g_dbus_connection_is_closed(system_conn)) {
                local_system_gconn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
 
                if (!local_system_gconn) {
@@ -82,22 +78,59 @@ GDBusConnection *_bt_gdbus_get_system_gconn(void)
                        g_clear_error(&error);
                }
 
-               system_gconn = local_system_gconn;
+               system_conn = local_system_gconn;
+       }
+
+       return system_conn;
+}
+
+GDBusConnection *_bt_gdbus_init_session_gconn(void)
+{
+       GError *error = NULL;
+
+       if (session_conn != NULL)
+               return session_conn;
+
+       session_conn = g_bus_get_sync(G_BUS_TYPE_SESSION, NULL, &error);
+
+       if (!session_conn) {
+               BT_ERR("Unable to connect to dbus: %s", error->message);
+               g_clear_error(&error);
        }
 
-       return system_gconn;
+       return session_conn;
+}
+
+GDBusConnection *_bt_gdbus_get_session_gconn(void)
+{
+       GDBusConnection *local_session_gconn = NULL;
+       GError *error = NULL;
+
+       if (session_conn == NULL) {
+               session_conn = _bt_gdbus_init_session_gconn();
+       } else if (g_dbus_connection_is_closed(session_conn)) {
+               local_session_gconn = g_bus_get_sync(G_BUS_TYPE_SESSION, NULL, &error);
+
+               if (!local_session_gconn) {
+                       BT_ERR("Unable to connect to dbus: %s", error->message);
+                       g_clear_error(&error);
+               }
+
+               session_conn = local_session_gconn;
+       }
+
+       return session_conn;
 }
 
 static GDBusProxy *__bt_init_manager_proxy(void)
 {
+       GDBusConnection *g_conn;
        GDBusProxy *proxy;
 
-       if (system_conn == NULL) {
-               system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
-               retv_if(system_conn == NULL, NULL);
-       }
+       g_conn = _bt_gdbus_get_system_gconn();
+       retv_if(g_conn == NULL, NULL);
 
-       proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE,
+       proxy = g_dbus_proxy_new_sync(g_conn, G_DBUS_PROXY_FLAGS_NONE,
                                                                NULL, BT_BLUEZ_NAME,
                                                                BT_MANAGER_PATH, BT_MANAGER_INTERFACE,  NULL, NULL);
 
@@ -113,14 +146,13 @@ static GDBusProxy *__bt_init_manager_proxy(void)
 
 static GDBusProxy *__bt_init_adapter_proxy(void)
 {
+       GDBusConnection *g_conn;
        GDBusProxy *manager_proxy;
        GDBusProxy *proxy;
        char *adapter_path = NULL;
 
-       if (system_conn == NULL) {
-               system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
-               retv_if(system_conn == NULL, NULL);
-       }
+       g_conn = _bt_gdbus_get_system_gconn();
+       retv_if(g_conn == NULL, NULL);
 
        manager_proxy = _bt_get_manager_proxy();
        retv_if(manager_proxy == NULL, NULL);
@@ -128,7 +160,7 @@ static GDBusProxy *__bt_init_adapter_proxy(void)
        adapter_path = _bt_get_adapter_path();
        retv_if(adapter_path == NULL, NULL);
 
-       proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE,
+       proxy = g_dbus_proxy_new_sync(g_conn, G_DBUS_PROXY_FLAGS_NONE,
                                                                NULL, BT_BLUEZ_NAME,
                                                                adapter_path, BT_ADAPTER_INTERFACE,  NULL, NULL);
 
@@ -141,16 +173,41 @@ static GDBusProxy *__bt_init_adapter_proxy(void)
        return proxy;
 }
 
+static GDBusProxy *__bt_init_ipsp_proxy(void)
+{
+       BT_DBG("+");
+
+       GDBusConnection *g_conn;
+       GDBusProxy *proxy;
+
+
+       g_conn = _bt_gdbus_get_system_gconn();
+       retv_if(g_conn == NULL, NULL);
+
+       proxy = g_dbus_proxy_new_sync(g_conn, G_DBUS_PROXY_FLAGS_NONE,
+                                                               NULL, BT_IPSP_NAME,
+                                                               "/org/projectx/bt_ipsp", BT_IPSP_INTERFACE,  NULL, NULL);
+
+       if (!proxy) {
+               BT_ERR("Unable to get proxy");
+               return NULL;
+       }
+
+       ipsp_proxy = proxy;
+
+       BT_DBG("-");
+       return proxy;
+}
+
 static GDBusProxy *__bt_init_adapter_properties_proxy(void)
 {
+       GDBusConnection *g_conn;
        GDBusProxy *manager_proxy;
        GDBusProxy *proxy;
        char *adapter_path = NULL;
 
-       if (system_conn == NULL) {
-               system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
-               retv_if(system_conn == NULL, NULL);
-       }
+       g_conn = _bt_gdbus_get_system_gconn();
+       retv_if(g_conn == NULL, NULL);
 
        manager_proxy = _bt_get_manager_proxy();
        retv_if(manager_proxy == NULL, NULL);
@@ -158,7 +215,7 @@ static GDBusProxy *__bt_init_adapter_properties_proxy(void)
        adapter_path = _bt_get_adapter_path();
        retv_if(adapter_path == NULL, NULL);
 
-       proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE,
+       proxy = g_dbus_proxy_new_sync(g_conn, G_DBUS_PROXY_FLAGS_NONE,
                                                                        NULL, BT_BLUEZ_NAME,
                                                                        adapter_path, BT_PROPERTIES_INTERFACE,  NULL, NULL);
 
@@ -171,50 +228,6 @@ static GDBusProxy *__bt_init_adapter_properties_proxy(void)
        return proxy;
 }
 
-GDBusConnection *__bt_init_system_gconn(void)
-{
-       if (system_conn == NULL)
-               system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
-
-       return system_conn;
-}
-
-GDBusConnection *__bt_init_session_conn(void)
-{
-       if (session_conn == NULL)
-               session_conn = g_bus_get_sync(G_BUS_TYPE_SESSION, NULL, NULL);
-
-       return session_conn;
-}
-
-GDBusConnection *_bt_get_session_gconn(void)
-{
-       return (session_conn) ? session_conn : __bt_init_session_conn();
-}
-
-GDBusConnection *_bt_get_system_gconn(void)
-{
-       return (system_conn) ? system_conn : __bt_init_system_gconn();
-}
-
-GDBusConnection *_bt_get_system_conn(void)
-{
-       GDBusConnection *g_conn;
-
-       if (system_conn == NULL) {
-               g_conn = __bt_init_system_gconn();
-       } else {
-               g_conn = system_conn;
-       }
-
-       if (!g_conn) {
-               BT_ERR("Unable to get dbus connection");
-               return NULL;
-       }
-
-       return g_conn;
-}
-
 GDBusProxy *_bt_get_manager_proxy(void)
 {
        if (manager_proxy) {
@@ -228,6 +241,21 @@ GDBusProxy *_bt_get_manager_proxy(void)
        return  __bt_init_manager_proxy();
 }
 
+GDBusProxy *_bt_get_ipsp_proxy(void)
+{
+       if (ipsp_proxy) {
+               const char *path =  g_dbus_proxy_get_object_path(ipsp_proxy);
+               if (path == NULL) {
+                       BT_ERR("Already proxy released hence creating new proxy");
+                       return  __bt_init_ipsp_proxy();
+               }
+
+               return ipsp_proxy;
+       }
+       return  __bt_init_ipsp_proxy();
+
+}
+
 static void *__bt_init_net_conn(void)
 {
        int result;
@@ -309,7 +337,7 @@ char *_bt_get_adapter_path(void)
        GVariantIter *iter = NULL;
        char *adapter_path = NULL;
 
-       conn = _bt_get_system_conn();
+       conn = _bt_gdbus_get_system_gconn();
        retv_if(conn == NULL, NULL);
 
        manager_proxy = _bt_get_manager_proxy();
@@ -375,6 +403,29 @@ void _bt_deinit_proxys(void)
        }
 }
 
+GDBusProxy *_bt_gdbus_get_hid_agent_proxy(void)
+{
+       GDBusConnection *conn;
+       GDBusProxy *proxy;
+       GError *err = NULL;
+
+       conn = _bt_gdbus_get_system_gconn();
+       retv_if(conn == NULL, NULL);
+
+       proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE, NULL,
+                                       BT_HID_SERVICE_NAME, BT_HID_AGENT_OBJECT_PATH,
+                                       BT_HID_SERVICE_INTERFACE, NULL, &err);
+       if (proxy == NULL) {
+               if (err != NULL) {
+                       ERR("Unable to create proxy: %s", err->message);
+                       g_clear_error(&err);
+               }
+               return NULL;
+       }
+
+       return proxy;
+}
+
 void _bt_convert_device_path_to_address(const char *device_path,
                                                char *device_address)
 {
@@ -390,9 +441,8 @@ void _bt_convert_device_path_to_address(const char *device_path,
                dev_addr += 4;
                g_strlcpy(address, dev_addr, sizeof(address));
 
-               while ((pos = strchr(address, '_')) != NULL) {
+               while ((pos = strchr(address, '_')) != NULL)
                        *pos = ':';
-               }
 
                g_strlcpy(device_address, address, BT_ADDRESS_STRING_SIZE);
        }
@@ -402,21 +452,21 @@ void _bt_convert_device_path_to_address(const char *device_path,
 void _bt_convert_addr_string_to_type(unsigned char *addr,
                                        const char *address)
 {
-        int i;
-        char *ptr = NULL;
+       int i;
+       char *ptr = NULL;
 
        ret_if(address == NULL);
        ret_if(addr == NULL);
 
-        for (i = 0; i < BT_ADDRESS_LENGTH_MAX; i++) {
-                addr[i] = strtol(address, &ptr, 16);
-                if (ptr[0] != '\0') {
-                        if (ptr[0] != ':')
-                                return;
+       for (i = 0; i < BT_ADDRESS_LENGTH_MAX; i++) {
+               addr[i] = strtol(address, &ptr, 16);
+               if (ptr[0] != '\0') {
+                       if (ptr[0] != ':')
+                               return;
 
-                        address = ptr + 1;
-                }
-        }
+               address = ptr + 1;
+               }
+       }
 }
 
 void _bt_convert_addr_string_to_secure_string(char *addr,
@@ -428,9 +478,10 @@ void _bt_convert_addr_string_to_secure_string(char *addr,
        ret_if(addr == NULL);
 
        len = strlen(address);
-       ret_if(len != BT_ADDRESS_STRING_SIZE- 1);
+       ret_if(len != BT_ADDRESS_STRING_SIZE - 1);
 
        strncpy(addr, address, len);
+       addr[len] = '\0';
 
        addr[len-1] = 'X';
        addr[len-2] = 'X';
@@ -577,9 +628,8 @@ int _bt_set_socket_non_blocking(int socket_fd)
        if (arg < 0)
                return -errno;
 
-       if (arg & O_NONBLOCK) {
+       if (arg & O_NONBLOCK)
                BT_ERR("Already Non-blocking \n");
-       }
 
        arg |= O_NONBLOCK;
 
@@ -623,9 +673,9 @@ static char *__bt_extract_device_path(GVariantIter *iter, char *address)
                        return NULL;
                }
                _bt_convert_device_path_to_address(object_path, device_address);
-               if (g_strcmp0(address, device_address) == 0) {
+               if (g_strcmp0(address, device_address) == 0)
                        return g_strdup(object_path);
-               }
+
        }
 
        BT_ERR("Unable to get object path");
@@ -640,7 +690,7 @@ char *_bt_get_device_object_path(char *address)
        GVariant *result = NULL;
        GVariantIter *iter = NULL;
 
-       conn = _bt_get_system_conn();
+       conn = _bt_gdbus_get_system_gconn();
        retv_if(conn == NULL, NULL);
 
        manager_proxy = _bt_get_manager_proxy();
@@ -691,7 +741,182 @@ char *_bt_get_profile_uuid128(bt_profile_type_t profile_type)
        };
 }
 
-char *_bt_convert_error_to_string(int error)
+const char *_bt_convert_uuid_to_string(const char *uuid)
+{
+       if (!uuid)
+               return NULL;
+
+       int i;
+       int offset = 0;
+       int uuid_len = 4;
+       static struct {
+               const char *uuid;
+               const char *specification_name;
+       } bt_uuid_name[] = {
+               /* BT Classic Services */
+               {"1101", "Serial Port Service"},
+               {"1102", "LAN Access Using PPP Service"},
+               {"1103", "Dialup Networking Service"},
+               {"1104", "IrMCSync Service"},
+               {"1105", "OBEX Object Push Service"},
+               {"1106", "OBEX File Transfer Service"},
+               {"1107", "IrMC Sync Command Service"},
+               {"1108", "Headset Service"},
+               {"1109", "Cordless Telephony Service"},
+               {"110A", "Audio Source Service"},
+               {"110B", "Audio Sink Service"},
+               {"110C", "AV Remote Control Target Service"},
+               {"110D", "Advanced Audio Distribution Profile"},
+               {"110E", "AV Remote Control Service"},
+               {"110F", "Video Conferencing Service"},
+               {"1110", "Intercom Service"},
+               {"1111", "Fax Service"},
+               {"1112", "Headset Audio Gateway Service"},
+               {"1113", "WAP Service"},
+               {"1114", "WAP Client Service"},
+               {"1115", "PANU Service"},
+               {"1116", "NAP Service"},
+               {"1117", "GN Service"},
+               {"1118", "Direct Printing Service"},
+               {"1119", "Reference Printing Service"},
+               {"111A", "Basic Imaging Profile"},
+               {"111B", "Imaging Responder Service"},
+               {"111C", "Imaging Automatic Archive Service"},
+               {"111D", "Imaging Reference Objects Service"},
+               {"111E", "Handsfree Service"},
+               {"111F", "Handsfree Audio Gateway Service"},
+               {"1120", "Direct Printing Reference Objects Service"},
+               {"1121", "Reflected UI Service"},
+               {"1122", "Basic Printing Profile"},
+               {"1123", "Printing Status Service"},
+               {"1124", "Human Interface Device Service"},
+               {"1125", "Hardcopy Cable Replacement Profile"},
+               {"1126", "HCR Print Service"},
+               {"1127", "HCR Scan Service"},
+               {"112D", "SIM Access Service"},
+               {"112E", "Phonebook Access PCE Service"},
+               {"112F", "Phonebook Access PSE Service"},
+               {"1130", "Phonebook Access Profile"},
+               {"1132", "Message Access Server Service"},
+               {"1133", "Message Notification Server Service"},
+               {"1134", "Message Access Profile"},
+               {"1200", "PnP Information Service"},
+               {"1201", "Generic Networking Service"},
+               {"1202", "Generic File Transfer Service"},
+               {"1203", "Generic Audio Service"},
+               {"1204", "Generic Telephony Service"},
+               {"1205", "UPnP Service"},
+               {"1206", "UPnP Ip Service"},
+               {"1303", "Video Source Service"},
+               {"1304", "Video Sink Service"},
+               {"1305", "Video Distribution Profile"},
+               {"1400", "Health Device Profile"},
+               {"1401", "HDP Source Service"},
+               {"1402", "HDP Sink Service"},
+
+               /* GATT Services */
+               {"1800", "Generic Access"},
+               {"1801", "Generic Attribute"},
+               {"1802", "Immediate Alert"},
+               {"1803", "Link Loss"},
+               {"1804", "Tx Power"},
+               {"1805", "Current Time Service"},
+               {"1806", "Reference Time Update Service"},
+               {"1807", "Next DST Change Service"},
+               {"1808", "Glucose"},
+               {"1809", "Health Thermometer"},
+               {"180A", "Device Information"},
+               {"180D", "Heart Rate"},
+               {"180F", "Battery Service"},
+               {"1810", "Blood Pressure"},
+               {"1811", "Alert Notification Service"},
+               {"1812", "Human Interface Device"},
+
+               /* GATT Declarations */
+               {"2800", "Primary Service Declaration"},
+               {"2801", "Secondary Service Declaration"},
+               {"2802", "Include Declaration"},
+               {"2803", "Characteristic Declaration"},
+
+               /* GATT Descriptors */
+               {"2900", "Characteristic Extended Properties"},
+               {"2901", "Characteristic User Description"},
+               {"2902", "Client Characteristic Configuration"},
+               {"2903", "Server Characteristic Configuration"},
+               {"2904", "Characteristic Format"},
+               {"2905", "Characteristic Aggregate Formate"},
+               {"2906", "Valid Range"},
+               {"2907", "External Report Reference"},
+               {"2908", "Report Reference"},
+
+               /* GATT Characteristics */
+               {"2A00", "Device Name"},
+               {"2A01", "Appearance"},
+               {"2A02", "Peripheral Privacy Flag"},
+               {"2A03", "Reconnection Address"},
+               {"2A04", "Peripheral Preferred Connection Parameters"},
+               {"2A05", "Service Changed"},
+               {"2A06", "Alert Level"},
+               {"2A07", "Tx Power Level"},
+               {"2A08", "Date Time"},
+               {"2A09", "Day of Week"},
+               {"2A0A", "Day Date Time"},
+               {"2A19", "Battery Level"},
+               {"2A1E", "Intermediate Temperature"},
+               {"2A23", "System ID"},
+               {"2A24", "Model Number String"},
+               {"2A25", "Serial Number String"},
+               {"2A26", "Firmware Revision String"},
+               {"2A27", "Hardware Revision String"},
+               {"2A28", "Software Revision String"},
+               {"2A29", "Manufacturer Name String"},
+               {"2A2A", "IEEE 11073-20601 Regulatory Certification Data List"},
+               {"2A2B", "Current Time"},
+               {"2A37", "Heart Rate Measurement"},
+               {"2A38", "Body Sensor Location"},
+               {"2A3F", "Alert Status"},
+               {"2A46", "New Alert"},
+               {"2A4A", "HID Information"},
+               {"2A4C", "HID Control Point"},
+               {"2A50", "PnP ID"},
+
+               /* Custom uuids */
+               {"7905F431-B5CE-4E99-A40F-4B1E122D00D0", "Apple Notification Center Service"},
+               {"9FBF120D-6301-42D9-8C58-25E699A21DBD", "Notifications Source"},
+               {"69D1D8F3-45E1-49A8-9821-9BBDFDAAD9D9", "Control Point"},
+               {"22EAC6E9-24D6-4BB5-BE44-B36ACE7C7BFB", "Data Source"},
+               {"89D3502B-0F36-433A-8EF4-C502AD55F8DC", "Apple Media Service"},
+               {"9B3C81D8-57B1-4A8A-B8DF-0E56F7CA51C2", "Remote Command"},
+               {"2F7CABCE-808D-411F-9A0C-BB92BA96C102", "Entity Update"},
+               {"C6B2F38C-23AB-46D8-A6AB-A3A870BBD5D7", "Entity Attribute"},
+               {"9A3F68E0-86CE-11E5-A309-0002A5D5C51B", "Samsung Gear Manager Service"},
+               {"c2f2cc0f-c085-4dd4-be5a-aca3074bbc72", "Control Point"},
+               {"cece518b-28d7-4171-92d5-76a1e249a3b9", "Notifications Source"},
+               {"32D1955A-E5AA-4A96-9A49-08538DA8B8F6", "Samsung Gear Fit Manager Service"},
+               {"FE53FF98-B259-4337-B56A-0EC9F82C6BAD", "Control Point"},
+               {"C2051EE0-804D-4D50-A12C-15E243852100", "Notifications Source"},
+               {NULL, NULL}
+       };
+
+       if (strlen(uuid) == 36) {
+               if (!g_ascii_strncasecmp(uuid + 9, "0000-1000-8000-00805F9B34FB", 27))
+                       offset = 4;
+               else {
+                       offset = 0;
+                       uuid_len = 36;
+               }
+       } else if (strlen(uuid) >= 8)
+               offset = 4;
+
+       for (i = 0; bt_uuid_name[i].uuid; i++) {
+               if (!g_ascii_strncasecmp(uuid + offset, bt_uuid_name[i].uuid, uuid_len))
+                       return (char *)bt_uuid_name[i].specification_name;
+       }
+
+       return "Unknown";
+}
+
+const char *_bt_convert_error_to_string(int error)
 {
        switch (error) {
        case BLUETOOTH_ERROR_CANCEL:
@@ -774,9 +999,9 @@ char *_bt_convert_error_to_string(int error)
        }
 }
 
-char * _bt_convert_disc_reason_to_string(int reason)
+const char *_bt_convert_disc_reason_to_string(int reason)
 {
-       switch(reason) {
+       switch (reason) {
        case (int)BLUETOOTH_ERROR_PAGE_TIMEOUT:
                return "Page timeout";
        case (int)BLUETOOTH_ERROR_CONNECTION_TIMEOUT:
@@ -795,6 +1020,14 @@ char * _bt_convert_disc_reason_to_string(int reason)
                return "Repeated attempts";
        case (int)BLUETOOTH_ERROR_LMP_RESPONSE_TIMEOUT:
                return "LMP response timeout";
+       case (int)BLUETOOTH_ERROR_LMP_TRANSACTION_COLLISION:
+               return "LMP transaction collision";
+       case (int)BLUETOOTH_ERROR_INSTANT_PASSED:
+               return "Instant passed";
+       case (int)BLUETOOTH_ERROR_INSUFFICIENT_SECURITY:
+               return "Insufficient security";
+       case (int)BLUETOOTH_ERROR_CONNECTION_TERMINATED_DUE_TO_MIC_FAILURE:
+               return "Connection terminated due to MIC failure";
        case (int)BLUETOOTH_ERROR_CONNECTION_FAILED_TO_BE_ESTABLISHED:
                return "Connection failed to be established";
        default:
@@ -802,6 +1035,265 @@ char * _bt_convert_disc_reason_to_string(int reason)
        }
 }
 
+const char *_bt_convert_service_function_to_string(int function)
+{
+       int i;
+
+       typedef struct {
+               int function;
+               const char *function_name;
+       } bt_function_name_t;
+
+       const bt_function_name_t bt_functions[] = {
+               {BT_CHECK_ADAPTER, "BT_CHECK_ADAPTER"},
+               {BT_ENABLE_ADAPTER, "BT_ENABLE_ADAPTER"},
+               {BT_DISABLE_ADAPTER, "BT_DISABLE_ADAPTER"},
+               {BT_RECOVER_ADAPTER, "BT_RECOVER_ADAPTER"},
+               {BT_SET_DISCOVERABLE_TIME, "BT_SET_DISCOVERABLE_TIME"},
+               {BT_GET_DISCOVERABLE_TIME, "BT_GET_DISCOVERABLE_TIME"},
+               {BT_IGNORE_AUTO_PAIRING, "BT_IGNORE_AUTO_PAIRING"},
+               {BT_GET_LOCAL_ADDRESS, "BT_GET_LOCAL_ADDRESS"},
+               {BT_GET_LOCAL_VERSION, "BT_GET_LOCAL_VERSION"},
+               {BT_GET_LOCAL_NAME, "BT_GET_LOCAL_NAME"},
+               {BT_SET_LOCAL_NAME, "BT_SET_LOCAL_NAME"},
+               {BT_IS_SERVICE_USED, "BT_IS_SERVICE_USED"},
+               {BT_GET_DISCOVERABLE_MODE, "BT_GET_DISCOVERABLE_MODE"},
+               {BT_SET_DISCOVERABLE_MODE, "BT_SET_DISCOVERABLE_MODE"},
+               {BT_START_DISCOVERY, "BT_START_DISCOVERY"},
+               {BT_START_CUSTOM_DISCOVERY, "BT_START_CUSTOM_DISCOVERY"},
+               {BT_CANCEL_DISCOVERY, "BT_CANCEL_DISCOVERY"},
+               {BT_START_LE_DISCOVERY, "BT_START_LE_DISCOVERY"},
+               {BT_STOP_LE_DISCOVERY, "BT_STOP_LE_DISCOVERY"},
+               {BT_IS_DISCOVERYING, "BT_IS_DISCOVERYING"},
+               {BT_IS_LE_DISCOVERYING, "BT_IS_LE_DISCOVERYING"},
+               {BT_ENABLE_RSSI, "BT_ENABLE_RSSI"},
+               {BT_GET_RSSI, "BT_GET_RSSI"},
+               {BT_IS_CONNECTABLE, "BT_IS_CONNECTABLE"},
+               {BT_SET_CONNECTABLE, "BT_SET_CONNECTABLE"},
+               {BT_GET_BONDED_DEVICES, "BT_GET_BONDED_DEVICES"},
+               {BT_RESET_ADAPTER, "BT_RESET_ADAPTER"},
+               {BT_SET_ADVERTISING, "BT_SET_ADVERTISING"},
+               {BT_SET_CUSTOM_ADVERTISING, "BT_SET_CUSTOM_ADVERTISING"},
+               {BT_SET_ADVERTISING_PARAMETERS, "BT_SET_ADVERTISING_PARAMETERS"},
+               {BT_GET_ADVERTISING_DATA, "BT_GET_ADVERTISING_DATA"},
+               {BT_SET_ADVERTISING_DATA, "BT_SET_ADVERTISING_DATA"},
+               {BT_SET_SCAN_PARAMETERS, "BT_SET_SCAN_PARAMETERS"},
+               {BT_GET_SCAN_RESPONSE_DATA, "BT_GET_SCAN_RESPONSE_DATA"},
+               {BT_SET_SCAN_RESPONSE_DATA, "BT_SET_SCAN_RESPONSE_DATA"},
+               {BT_IS_ADVERTISING, "BT_IS_ADVERTISING"},
+               {BT_SET_MANUFACTURER_DATA, "BT_SET_MANUFACTURER_DATA"},
+               {BT_LE_CONN_UPDATE, "BT_LE_CONN_UPDATE"},
+               {BT_LE_READ_MAXIMUM_DATA_LENGTH, "BT_LE_READ_MAXIMUM_DATA_LENGTH"},
+               {BT_LE_WRITE_HOST_SUGGESTED_DATA_LENGTH, "BT_LE_WRITE_HOST_SUGGESTED_DATA_LENGTH"},
+               {BT_LE_READ_HOST_SUGGESTED_DATA_LENGTH, "BT_LE_READ_HOST_SUGGESTED_DATA_LENGTH"},
+               {BT_LE_SET_DATA_LENGTH, "BT_LE_SET_DATA_LENGTH"},
+               {BT_ADD_WHITE_LIST, "BT_ADD_WHITE_LIST"},
+               {BT_REMOVE_WHITE_LIST, "BT_REMOVE_WHITE_LIST"},
+               {BT_CLEAR_WHITE_LIST, "BT_CLEAR_WHITE_LIST"},
+               {BT_REGISTER_SCAN_FILTER, "BT_REGISTER_SCAN_FILTER"},
+               {BT_UNREGISTER_SCAN_FILTER, "BT_UNREGISTER_SCAN_FILTER"},
+               {BT_UNREGISTER_ALL_SCAN_FILTERS, "BT_UNREGISTER_ALL_SCAN_FILTERS"},
+               {BT_IS_SCAN_FILTER_SUPPORTED, "BT_IS_SCAN_FILTER_SUPPORTED"},
+               {BT_GET_PROFILE_CONNECTED_DEVICES, "BT_GET_PROFILE_CONNECTED_DEVICES"},
+               {BT_ENABLE_FORCE_HCI_DUMP, "BT_ENABLE_FORCE_HCI_DUMP"},
+               {BT_SET_PASSKEY_NOTIFICATION, "BT_SET_PASSKEY_NOTIFICATION"},
+               {BT_BOND_DEVICE, "BT_BOND_DEVICE"},
+               {BT_BOND_DEVICE_BY_TYPE, "BT_BOND_DEVICE_BY_TYPE"},
+               {BT_CANCEL_BONDING, "BT_CANCEL_BONDING"},
+               {BT_PASSKEY_REPLY, "BT_PASSKEY_REPLY"},
+               {BT_PASSKEY_CONFIRMATION_REPLY, "BT_PASSKEY_CONFIRMATION_REPLY"},
+               {BT_UNBOND_DEVICE, "BT_UNBOND_DEVICE"},
+               {BT_SEARCH_SERVICE, "BT_SEARCH_SERVICE"},
+               {BT_CANCEL_SEARCH_SERVICE, "BT_CANCEL_SEARCH_SERVICE"},
+               {BT_GET_BONDED_DEVICE, "BT_GET_BONDED_DEVICE"},
+               {BT_GET_IS_ALIAS_SET, "BT_GET_IS_ALIAS_SET"},
+               {BT_SET_ALIAS, "BT_SET_ALIAS"},
+               {BT_SET_AUTHORIZATION, "BT_SET_AUTHORIZATION"},
+               {BT_UNSET_AUTHORIZATION, "BT_UNSET_AUTHORIZATION"},
+               {BT_IS_DEVICE_CONNECTED, "BT_IS_DEVICE_CONNECTED"},
+               {BT_GET_CONNECTED_LINK_TYPE, "BT_GET_CONNECTED_LINK_TYPE"},
+               {BT_SET_PIN_CODE, "BT_SET_PIN_CODE"},
+               {BT_UNSET_PIN_CODE, "BT_UNSET_PIN_CODE"},
+               {BT_UPDATE_LE_CONNECTION_MODE, "BT_UPDATE_LE_CONNECTION_MODE"},
+               {BT_SET_PROFILE_TRUSTED, "BT_SET_PROFILE_TRUSTED"},
+               {BT_GET_PROFILE_TRUSTED, "BT_GET_PROFILE_TRUSTED"},
+               {BT_HID_CONNECT, "BT_HID_CONNECT"},
+               {BT_HID_DISCONNECT, "BT_HID_DISCONNECT"},
+               {BT_HID_DEVICE_ACTIVATE, "BT_HID_DEVICE_ACTIVATE"},
+               {BT_HID_DEVICE_DEACTIVATE, "BT_HID_DEVICE_DEACTIVATE"},
+               {BT_HID_DEVICE_CONNECT, "BT_HID_DEVICE_CONNECT"},
+               {BT_HID_DEVICE_DISCONNECT, "BT_HID_DEVICE_DISCONNECT"},
+               {BT_HID_DEVICE_SEND_MOUSE_EVENT, "BT_HID_DEVICE_SEND_MOUSE_EVENT"},
+               {BT_HID_DEVICE_SEND_KEY_EVENT, "BT_HID_DEVICE_SEND_KEY_EVENT"},
+               {BT_HID_DEVICE_SEND_CUSTOM_EVENT, "BT_HID_DEVICE_SEND_CUSTOM_EVENT"},
+               {BT_HID_DEVICE_SEND_REPLY_TO_REPORT, "BT_HID_DEVICE_SEND_REPLY_TO_REPORT"},
+               {BT_HID_ENABLE_BARCODE_FEATURE, "BT_HID_ENABLE_BARCODE_FEATURE"},
+               {BT_NETWORK_ACTIVATE, "BT_NETWORK_ACTIVATE"},
+               {BT_NETWORK_DEACTIVATE, "BT_NETWORK_DEACTIVATE"},
+               {BT_NETWORK_CONNECT, "BT_NETWORK_CONNECT"},
+               {BT_NETWORK_DISCONNECT, "BT_NETWORK_DISCONNECT"},
+               {BT_NETWORK_SERVER_DISCONNECT, "BT_NETWORK_SERVER_DISCONNECT"},
+               {BT_AUDIO_CONNECT, "BT_AUDIO_CONNECT"},
+               {BT_AUDIO_DISCONNECT, "BT_AUDIO_DISCONNECT"},
+               {BT_AG_CONNECT, "BT_AG_CONNECT"},
+               {BT_AG_DISCONNECT, "BT_AG_DISCONNECT"},
+               {BT_AV_CONNECT, "BT_AV_CONNECT"},
+               {BT_AV_DISCONNECT, "BT_AV_DISCONNECT"},
+               {BT_AV_SOURCE_CONNECT, "BT_AV_SOURCE_CONNECT"},
+               {BT_AV_SOURCE_DISCONNECT, "BT_AV_SOURCE_DISCONNECT"},
+               {BT_HF_CONNECT, "BT_HF_CONNECT"},
+               {BT_HF_DISCONNECT, "BT_HF_DISCONNECT"},
+               {BT_GET_SPEAKER_GAIN, "BT_GET_SPEAKER_GAIN"},
+               {BT_SET_SPEAKER_GAIN, "BT_SET_SPEAKER_GAIN"},
+               {BT_SET_CONTENT_PROTECT, "BT_SET_CONTENT_PROTECT"},
+               {BT_OOB_READ_LOCAL_DATA, "BT_OOB_READ_LOCAL_DATA"},
+               {BT_OOB_ADD_REMOTE_DATA, "BT_OOB_ADD_REMOTE_DATA"},
+               {BT_OOB_REMOVE_REMOTE_DATA, "BT_OOB_REMOVE_REMOTE_DATA"},
+               {BT_AVRCP_SET_TRACK_INFO, "BT_AVRCP_SET_TRACK_INFO"},
+               {BT_AVRCP_SET_PROPERTY, "BT_AVRCP_SET_PROPERTY"},
+               {BT_AVRCP_SET_PROPERTIES, "BT_AVRCP_SET_PROPERTIES"},
+               {BT_AVRCP_CONTROL_CONNECT, "BT_AVRCP_CONTROL_CONNECT"},
+               {BT_AVRCP_CONTROL_DISCONNECT, "BT_AVRCP_CONTROL_DISCONNECT"},
+               {BT_AVRCP_TARGET_CONNECT, "BT_AVRCP_TARGET_CONNECT"},
+               {BT_AVRCP_TARGET_DISCONNECT, "BT_AVRCP_TARGET_DISCONNECT"},
+               {BT_AVRCP_HANDLE_CONTROL, "BT_AVRCP_HANDLE_CONTROL"},
+               {BT_AVRCP_CONTROL_SET_PROPERTY, "BT_AVRCP_CONTROL_SET_PROPERTY"},
+               {BT_AVRCP_CONTROL_GET_PROPERTY, "BT_AVRCP_CONTROL_GET_PROPERTY"},
+               {BT_AVRCP_GET_TRACK_INFO, "BT_AVRCP_GET_TRACK_INFO"},
+               {BT_OPP_PUSH_FILES, "BT_OPP_PUSH_FILES"},
+               {BT_OPP_CANCEL_PUSH, "BT_OBT_OPP_IS_PUSHING_FILESPP_CANCEL_PUSH"},
+               {BT_OPP_IS_PUSHING_FILES, "BT_OPP_IS_PUSHING_FILES"},
+               {BT_OPP_GET_TRANSFER_PROGRESS, "BT_OPP_GET_TRANSFER_PROGRESS"},
+               {BT_MAP_CREATE_SESSION, "BT_MAP_CREATE_SESSION"},
+               {BT_MAP_DESTROY_SESSION, "BT_MAP_DESTROY_SESSION"},
+               {BT_MAP_SET_FOLDER, "BT_MAP_SET_FOLDER"},
+               {BT_MAP_LIST_FOLDERS, "BT_MAP_LIST_FOLDERS"},
+               {BT_MAP_LIST_FILTER_FIELDS, "BT_MAP_LIST_FILTER_FIELDS"},
+               {BT_MAP_LIST_MESSAGES, "BT_MAP_LIST_MESSAGES"},
+               {BT_MAP_UPDATE_INBOX, "BT_MAP_UPDATE_INBOX"},
+               {BT_MAP_PUSH_MESSAGE, "BT_MAP_PUSH_MESSAGE"},
+               {BT_MAP_GET_MESSAGE, "BT_MAP_GET_MESSAGE"},
+               {BT_OBEX_SERVER_ALLOCATE, "BT_OBEX_SERVER_ALLOCATE"},
+               {BT_OBEX_SERVER_DEALLOCATE, "BT_OBEX_SERVER_DEALLOCATE"},
+               {BT_OBEX_SERVER_IS_ACTIVATED, "BT_OBEX_SERVER_IS_ACTIVATED"},
+               {BT_OBEX_SERVER_ACCEPT_CONNECTION, "BT_OBEX_SERVER_ACCEPT_CONNECTION"},
+               {BT_OBEX_SERVER_REJECT_CONNECTION, "BT_OBEX_SERVER_REJECT_CONNECTION"},
+               {BT_OBEX_SERVER_ACCEPT_FILE, "BT_OBEX_SERVER_ACCEPT_FILE"},
+               {BT_OBEX_SERVER_REJECT_FILE, "BT_OBEX_SERVER_REJECT_FILE"},
+               {BT_OBEX_SERVER_SET_PATH, "BT_OBEX_SERVER_SET_PATH"},
+               {BT_OBEX_SERVER_SET_ROOT, "BT_OBEX_SERVER_SET_ROOT"},
+               {BT_OBEX_SERVER_CANCEL_TRANSFER, "BT_OBEX_SERVER_CANCEL_TRANSFER"},
+               {BT_OBEX_SERVER_CANCEL_ALL_TRANSFERS, "BT_OBEX_SERVER_CANCEL_ALL_TRANSFERS"},
+               {BT_OBEX_SERVER_IS_RECEIVING, "BT_OBEX_SERVER_IS_RECEIVING"},
+               {BT_RFCOMM_CLIENT_CONNECT, "BT_RFCOMM_CLIENT_CONNECT"},
+               {BT_RFCOMM_CLIENT_CANCEL_CONNECT, "BT_RFCOMM_CLIENT_CANCEL_CONNECT"},
+               {BT_RFCOMM_CLIENT_IS_CONNECTED, "BT_RFCOMM_CLIENT_IS_CONNECTED"},
+               {BT_RFCOMM_SOCKET_DISCONNECT, "BT_RFCOMM_SOCKET_DISCONNECT"},
+               {BT_RFCOMM_SOCKET_WRITE, "BT_RFCOMM_SOCKET_WRITE"},
+               {BT_RFCOMM_CREATE_SOCKET, "BT_RFCOMM_CREATE_SOCKET"},
+               {BT_RFCOMM_REMOVE_SOCKET, "BT_RFCOMM_REMOVE_SOCKET"},
+               {BT_RFCOMM_LISTEN, "BT_RFCOMM_LISTEN"},
+               {BT_RFCOMM_IS_UUID_AVAILABLE, "BT_RFCOMM_IS_UUID_AVAILABLE"},
+               {BT_RFCOMM_ACCEPT_CONNECTION, "BT_RFCOMM_ACCEPT_CONNECTION"},
+               {BT_RFCOMM_REJECT_CONNECTION, "BT_RFCOMM_REJECT_CONNECTION"},
+               {BT_RFCOMM_CREATE_SOCKET_EX, "BT_RFCOMM_CREATE_SOCKET_EX"},
+               {BT_RFCOMM_REMOVE_SOCKET_EX, "BT_RFCOMM_REMOVE_SOCKET_EX"},
+               {BT_PBAP_CONNECT, "BT_PBAP_CONNECT"},
+               {BT_PBAP_DISCONNECT, "BT_PBAP_DISCONNECT"},
+               {BT_PBAP_GET_PHONEBOOK_SIZE, "BT_PBAP_GET_PHONEBOOK_SIZE"},
+               {BT_PBAP_GET_PHONEBOOK, "BT_PBAP_GET_PHONEBOOK"},
+               {BT_PBAP_GET_LIST, "BT_PBAP_GET_LIST"},
+               {BT_PBAP_PULL_VCARD, "BT_PBAP_PULL_VCARD"},
+               {BT_PBAP_PHONEBOOK_SEARCH, "BT_PBAP_PHONEBOOK_SEARCH"},
+               {BT_ENABLE_ADAPTER_LE, "BT_ENABLE_ADAPTER_LE"},
+               {BT_DISABLE_ADAPTER_LE, "BT_DISABLE_ADAPTER_LE"},
+               {BT_CONNECT_LE, "BT_CONNECT_LE"},
+               {BT_DISCONNECT_LE, "BT_DISCONNECT_LE"},
+               {BT_SET_LE_PRIVACY, "BT_SET_LE_PRIVACY"},
+               {BT_REQ_ATT_MTU, "BT_REQ_ATT_MTU"},
+               {BT_GET_ATT_MTU, "BT_GET_ATT_MTU"},
+               {BT_GET_DEVICE_IDA, "BT_GET_DEVICE_IDA"},
+               {BT_SET_LE_STATIC_RANDOM_ADDRESS, "BT_SET_LE_STATIC_RANDOM_ADDRESS"},
+               {BT_HDP_CONNECT, "BT_HDP_CONNECT"},
+               {BT_HDP_DISCONNECT, "BT_HDP_DISCONNECT"},
+               {BT_HDP_SEND_DATA, "BT_HDP_SEND_DATA"},
+               {BT_HDP_REGISTER_SINK_APP, "BT_HDP_REGISTER_SINK_APP"},
+               {BT_HDP_UNREGISTER_SINK_APP, "BT_HDP_UNREGISTER_SINK_APP"},
+               {BT_GATT_GET_PRIMARY_SERVICES, "BT_GATT_GET_PRIMARY_SERVICES"},
+               {BT_GATT_DISCOVER_CHARACTERISTICS, "BT_GATT_DISCOVER_CHARACTERISTICS"},
+               {BT_GATT_SET_PROPERTY_REQUEST, "BT_GATT_SET_PROPERTY_REQUEST"},
+               {BT_GATT_READ_CHARACTERISTIC, "BT_GATT_READ_CHARACTERISTIC"},
+               {BT_GATT_DISCOVER_CHARACTERISTICS_DESCRIPTOR, "BT_GATT_DISCOVER_CHARACTERISTICS_DESCRIPTOR"},
+               {BT_GATT_REGISTER_APPLICATION, "BT_GATT_REGISTER_APPLICATION"},
+               {BT_GATT_REGISTER_SERVICE, "BT_GATT_REGISTER_SERVICE"},
+               {BT_GATT_SEND_RESPONSE, "BT_GATT_SEND_RESPONSE"},
+               {BT_LE_IPSP_INIT, "BT_LE_IPSP_INIT"},
+               {BT_LE_IPSP_DEINIT, "BT_LE_IPSP_DEINIT"},
+               {BT_LE_IPSP_CONNECT, "BT_LE_IPSP_CONNECT"},
+               {BT_LE_IPSP_DISCONNECT, "BT_LE_IPSP_DISCONNECT"},
+               {BT_DPM_SET_ALLOW_BT_MODE, "BT_DPM_SET_ALLOW_BT_MODE"},
+               {BT_DPM_GET_ALLOW_BT_MODE, "BT_DPM_GET_ALLOW_BT_MODE"},
+               {BT_DPM_SET_DEVICE_RESTRITION, "BT_DPM_SET_DEVICE_RESTRITION"},
+               {BT_DPM_GET_DEVICE_RESTRITION, "BT_DPM_GET_DEVICE_RESTRITION"},
+               {BT_DPM_SET_UUID_RESTRITION, "BT_DPM_SET_UUID_RESTRITION"},
+               {BT_DPM_GET_UUID_RESTRITION, "BT_DPM_GET_UUID_RESTRITION"},
+               {BT_DPM_ADD_DEVICES_BLACKLIST, "BT_DPM_ADD_DEVICES_BLACKLIST"},
+               {BT_DPM_ADD_DEVICES_WHITELIST, "BT_DPM_ADD_DEVICES_WHITELIST"},
+               {BT_DPM_ADD_UUIDS_BLACKLIST, "BT_DPM_ADD_UUIDS_BLACKLIST"},
+               {BT_DPM_ADD_UUIDS_WHITELIST, "BT_DPM_ADD_UUIDS_WHITELIST"},
+               {BT_DPM_CLEAR_DEVICES_BLACKLIST, "BT_DPM_CLEAR_DEVICES_BLACKLIST"},
+               {BT_DPM_CLEAR_DEVICES_WHITELIST, "BT_DPM_CLEAR_DEVICES_WHITELIST"},
+               {BT_DPM_CLEAR_UUIDS_BLACKLIST, "BT_DPM_CLEAR_UUIDS_BLACKLIST"},
+               {BT_DPM_CLEAR_UUIDS_WHITELIST, "BT_DPM_CLEAR_UUIDS_WHITELIST"},
+               {BT_DPM_REMOVE_DEVICE_BLACKLIST, "BT_DPM_REMOVE_DEVICE_BLACKLIST"},
+               {BT_DPM_REMOVE_DEVICE_WHITELIST, "BT_DPM_REMOVE_DEVICE_WHITELIST"},
+               {BT_DPM_REMOVE_UUID_BLACKLIST, "BT_DPM_REMOVE_UUID_BLACKLIST"},
+               {BT_DPM_REMOVE_UUID_WHITELIST, "BT_DPM_REMOVE_UUID_WHITELIST"},
+               {BT_DPM_GET_DEVICES_BLACKLIST, "BT_DPM_GET_DEVICES_BLACKLIST"},
+               {BT_DPM_GET_DEVICES_WHITELIST, "BT_DPM_GET_DEVICES_WHITELIST"},
+               {BT_DPM_GET_UUIDS_BLACKLIST, "BT_DPM_GET_UUIDS_BLACKLIST"},
+               {BT_DPM_GET_UUIDS_WHITELIST, "BT_DPM_GET_UUIDS_WHITELIST"},
+               {BT_DPM_SET_ALLOW_OUTGOING_CALL, "BT_DPM_SET_ALLOW_OUTGOING_CALL"},
+               {BT_DPM_GET_ALLOW_OUTGOING_CALL, "BT_DPM_GET_ALLOW_OUTGOING_CALL"},
+               {BT_DPM_SET_PAIRING_STATE, "BT_DPM_SET_PAIRING_STATE"},
+               {BT_DPM_GET_PAIRING_STATE, "BT_DPM_GET_PAIRING_STATE"},
+               {BT_DPM_SET_PROFILE_STATE, "BT_DPM_SET_PROFILE_STATE"},
+               {BT_DPM_GET_PROFILE_STATE, "BT_DPM_GET_PROFILE_STATE"},
+               {BT_DPM_SET_DESKROP_CONNECTIVITY_STATE, "BT_DPM_SET_DESKROP_CONNECTIVITY_STATE"},
+               {BT_DPM_GET_DESKROP_CONNECTIVITY_STATE, "BT_DPM_GET_DESKROP_CONNECTIVITY_STATE"},
+               {BT_DPM_SET_DISCOVERABLE_STATE, "BT_DPM_SET_DISCOVERABLE_STATE"},
+               {BT_DPM_GET_DISCOVERABLE_STATE, "BT_DPM_GET_DISCOVERABLE_STATE"},
+               {BT_DPM_SET_LIMITED_DISCOVERABLE_STATE, "BT_DPM_SET_LIMITED_DISCOVERABLE_STATE"},
+               {BT_DPM_GET_LIMITED_DISCOVERABLE_STATE, "BT_DPM_GET_LIMITED_DISCOVERABLE_STATE"},
+               {BT_DPM_SET_DATA_TRANSFER_STATE, "BT_DPM_SET_DATA_TRANSFER_STATE"},
+               {BT_DPM_GET_DATA_TRANSFER_STATE, "BT_DPM_GET_DATA_TRANSFER_STATE"},
+               {BT_PXP_MONITOR_SET_PROPERTY, "BT_PXP_MONITOR_SET_PROPERTY"},
+               {BT_PXP_MONITOR_GET_PROPERTY, "BT_PXP_MONITOR_GET_PROPERTY"},
+               {BT_PXP_MONITOR_GET_SUPPORTED_SERIVCES, "BT_PXP_MONITOR_GET_SUPPORTED_SERIVCES"},
+               {BT_PXP_REPORTER_REGISTER, "BT_PXP_REPORTER_REGISTER"},
+               {BT_PXP_REPORTER_UNREGISTER, "BT_PXP_REPORTER_UNREGISTER"},
+               {BT_PXP_REPORTER_GET_PROPERTY, "BT_PXP_REPORTER_GET_PROPERTY"},
+               {BT_TDS_PROVIDER_REGISTER, "BT_TDS_PROVIDER_REGISTER"},
+               {BT_TDS_PROVIDER_UNREGISTER, "BT_TDS_PROVIDER_UNREGISTER"},
+               {BT_TDS_PROVIDER_SET_MANUF_DATA, "BT_TDS_PROVIDER_SET_MANUF_DATA"},
+               {BT_TDS_PROVIDER_CREATE, "BT_TDS_PROVIDER_CREATE"},
+               {BT_TDS_PROVIDER_DESTROY, "BT_TDS_PROVIDER_DESTROY"},
+               {BT_TDS_PROVIDER_SET_TRANSPORT_DATA, "BT_TDS_PROVIDER_SET_TRANSPORT_DATA"},
+               {BT_TDS_SEND_ACTIVATION_RESPONSE, "BT_TDS_SEND_ACTIVATION_RESPONSE"},
+               {BT_TDS_READ_TRANSPORT_DATA, "BT_TDS_READ_TRANSPORT_DATA"},
+               {BT_TDS_ENABLE_CONTROL_POINT, "BT_TDS_ENABLE_CONTROL_POINT"},
+               {BT_TDS_ACTIVATE_CONTROL_POINT, "BT_TDS_ACTIVATE_CONTROL_POINT"},
+               {-1, ""},
+       };
+
+       for (i = 0; bt_functions[i].function != -1; i++) {
+               if (bt_functions[i].function == function)
+                       return bt_functions[i].function_name;
+       }
+
+       return NULL;
+}
+
 void _bt_logging_connection(gboolean connect, int addr_type)
 {
        static int le_conn = 0;
@@ -874,7 +1366,7 @@ int _bt_eventsystem_set_value(const char *event, const char *key, const char *va
 {
        int ret = ES_R_OK;
 /* Send event system event in bt-core process because bt-service's permission is not system in now */
-\r#if 0
+#if 0
        bundle *b = NULL;
 
        b = bundle_create();
@@ -890,7 +1382,7 @@ int _bt_eventsystem_set_value(const char *event, const char *key, const char *va
        return ret;
 }
 
-void __bt_get_auth_info(GVariant *reply,  char *auth_info)
+void __bt_get_auth_info(GVariant *reply, char *auth_info)
 {
        int cursor;
        GVariant *tmp_value;
@@ -901,8 +1393,7 @@ void __bt_get_auth_info(GVariant *reply,  char *auth_info)
        guint8 m_value;
        int i = 0;
 
-
-       tmp_value = g_variant_lookup_value (reply, "IsAliasSet",
+       tmp_value = g_variant_lookup_value(reply, "IsAliasSet",
                                                                G_VARIANT_TYPE_BOOLEAN);
        if (tmp_value) {
                is_alias_set = g_variant_get_boolean(tmp_value);