X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=bt-service%2Fbt-service-common.c;h=5575ed945dd37e763ff960d43fc3399514ba21b0;hb=1fa07edcd0e77a445700975773db3300f556caf5;hp=48710a0b05248a2577602725f4a5eab213b80f7a;hpb=39a6cbc0e0b202a9ec628daacc1cd4128912964d;p=platform%2Fcore%2Fconnectivity%2Fbluetooth-frwk.git diff --git a/bt-service/bt-service-common.c b/bt-service/bt-service-common.c index 48710a0..5575ed9 100644 --- a/bt-service/bt-service-common.c +++ b/bt-service/bt-service-common.c @@ -45,25 +45,23 @@ 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 +69,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 +79,66 @@ GDBusConnection *_bt_gdbus_get_system_gconn(void) g_clear_error(&error); } - system_gconn = local_system_gconn; + system_conn = local_system_gconn; } - return system_gconn; + return system_conn; +} + +GDBusConnection *_bt_gdbus_init_session_gconn(void) +{ + GError *error = NULL; + + if (!g_thread_supported()) + g_thread_init(NULL); + + dbus_threads_init_default(); + + 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 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); - } + dbus_threads_init_default(); - proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE, + 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_BLUEZ_NAME, BT_MANAGER_PATH, BT_MANAGER_INTERFACE, NULL, NULL); @@ -113,14 +154,15 @@ 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); - } + dbus_threads_init_default(); + + 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 +170,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); @@ -143,14 +185,15 @@ static GDBusProxy *__bt_init_adapter_proxy(void) 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); - } + dbus_threads_init_default(); + + 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 +201,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 +214,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) { @@ -309,7 +308,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(); @@ -390,9 +389,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 +400,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,12 +426,19 @@ 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'; + addr[len-7] = 'X'; + addr[len-8] = 'X'; + addr[len-10] = 'X'; + addr[len-11] = 'X'; + addr[len-13] = 'X'; + addr[len-14] = 'X'; + addr[len-16] = 'X'; + addr[len-17] = 'X'; return; } @@ -577,9 +582,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 +627,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 +644,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(); @@ -682,6 +686,8 @@ char *_bt_get_profile_uuid128(bt_profile_type_t profile_type) return strdup(NAP_UUID); case BT_PROFILE_CONN_HFG: return strdup(HFP_AG_UUID); + case BT_PROFILE_CONN_PBAP: + return strdup(PBAP_UUID); case BT_PROFILE_CONN_GATT: case BT_PROFILE_CONN_ALL: /* NULL UUID will connect to both the audio profiles*/ default: @@ -689,7 +695,286 @@ 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) +{ +#define SHORT_UUID_COUNT 199 +#define LONG_UUID_COUNT 17 + + if (!uuid) + return NULL; + + int offset = 0; + int uuid_len = 4; + typedef struct { + const char *uuid; + const char *specification_name; + } uuid_name_s; + static uuid_name_s short_uuid_name[SHORT_UUID_COUNT] = { + // List should be sorted by UUID + /* 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"}, + {"1813", "Scan Parameters"}, + {"1814", "Running Speed and Cadence"}, + {"1815", "Automation IO"}, + {"1816", "Cycling Speed and Cadence"}, + {"1818", "Cycling Power"}, + {"1819", "Location and Navigation"}, + {"181A", "Environmental Sensing"}, + {"181B", "Body Composition"}, + {"181C", "User Data"}, + {"181D", "Weight Scale"}, + {"181E", "Bond Management"}, + {"181F", "Continuous Glucose Monitoring"}, + {"1820", "Internet Protocol Support Service"}, + {"1821", "Indoor Positioning"}, + {"1822", "Pulse Oximeter Service"}, + {"1823", "HTTP Proxy"}, + {"1824", "Transport Discovery"}, + {"1825", "Object Transfer Service"}, + {"1826", "Fitness Machine"}, + {"1827", "Mesh Provisioning Service"}, + {"1828", "Mesh Proxy Service"}, + {"1829", "Reconnection Configuration"}, + {"183A", "Insulin Delivery"}, + + /* 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"}, + {"2A11", "Time with DST"}, + {"2A12", "Time Accuracy"}, + {"2A13", "Time Source"}, + {"2A14", "Reference Time Information"}, + {"2A16", "Time Update Control Point"}, + {"2A17", "Time Update State"}, + {"2A18", "Glucose Measurement"}, + {"2A19", "Battery Level"}, + {"2A1C", "Temperature Measurement"}, + {"2A1D", "Temperature Type"}, + {"2A1E", "Intermediate Temperature"}, + {"2A21", "Measurement Interval"}, + {"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"}, + {"2A34", "Glucose Measurement Context"}, + {"2A35", "Blood Pressure Measurement"}, + {"2A37", "Heart Rate Measurement"}, + {"2A38", "Body Sensor Location"}, + {"2A39", "Heart Rate Control Point"}, + {"2A3F", "Alert Status"}, + {"2A46", "New Alert"}, + {"2A49", "Blood Pressure Feature"}, + {"2A4A", "HID Information"}, + {"2A4C", "HID Control Point"}, + {"2A50", "PnP ID"}, + {"2A51", "Glucose Feature"}, + {"2A52", "Record Access Control Point"}, + {"2A53", "RSC Measurement"}, + {"2A54", "RSC Feature"}, + {"2A55", "SC Control Point"}, + {"2A56", "Digital"}, + {"2A58", "Analog"}, + {"2A5A", "Aggregate"}, + {"2A5B", "CSC Measurement"}, + {"2A5C", "CSC Feature"}, + {"2A5D", "Sensor Location"}, + {"2A63", "Cycling Power Measurement"}, + {"2A64", "Cycling Power Vector"}, + {"2A65", "Cycling Power Feature"}, + {"2A66", "Cycling Power Control Point"}, + {"2A67", "Location and Speed"}, + {"2A68", "Navigation"}, + {"2A6D", "Pressure"}, + {"2A6E", "Temperature"}, + {"2A8E", "Height"}, + {"2A90", "Last Name"}, + {"2A91", "Maximum Recommended Heart Rate"}, + {"2A92", "Resting Heart Rate"}, + {"2A98", "Weight"}, + {"2A9B", "Body Composition Feature"}, + {"2A9C", "Body Composition Measurement"}, + {"2A9D", "Weight Measurement"}, + {"2AA2", "Language"}, + {"2AA4", "Bond Management Control Point"}, + {"2AA5", "Bond Management Features"}, + {"2AA6", "Central Address Resolution"}, + {"2AAD", "Indoor Positioning Configuration"}, + {"2AB5", "Location Name"}, + {"2AB6", "URI"}, + {"2ABC", "TDS Control Point"}, + {"2AC9", "Resolvable Private Address Only"}, + {"2ACC", "Fitness Machine Feature"}, + {"2ACE", "Cross Trainer Data"}, + {"2AD3", "Training Status"}, + {"2AD7", "Supported Heart Rate Range"}, + {"2AD9", "Fitness Machine Control Point"}, + {"2ADA", "Fitness Machine Status"}, + {"2B1D", "RC Feature"}, + {"2B1E", "RC Settings"}, + {"2B1F", "Reconnection Configuration Control Point"}, + }; + static uuid_name_s long_uuid_name[LONG_UUID_COUNT] = { + // List should be sorted by UUID + /* Custom uuids */ + {"1AB7C24D-185A-45B9-90D4-F7AB1A71949A", "Samsung Health Service"}, + {"22EAC6E9-24D6-4BB5-BE44-B36ACE7C7BFB", "Data Source"}, + {"2F7CABCE-808D-411F-9A0C-BB92BA96C102", "Entity Update"}, + {"32D1955A-E5AA-4A96-9A49-08538DA8B8F6", "Samsung Gear Fit Manager Service"}, + {"69D1D8F3-45E1-49A8-9821-9BBDFDAAD9D9", "Control Point"}, + {"7905F431-B5CE-4E99-A40F-4B1E122D00D0", "Apple Notification Center Service"}, + {"89D3502B-0F36-433A-8EF4-C502AD55F8DC", "Apple Media Service"}, + {"9A3F68E0-86CE-11E5-A309-0002A5D5C51B", "Samsung Gear Manager Service"}, + {"9B3C81D8-57B1-4A8A-B8DF-0E56F7CA51C2", "Remote Command"}, + {"9FBF120D-6301-42D9-8C58-25E699A21DBD", "Notifications Source"}, + {"A49EB41E-CB06-495C-9F4F-BB80A90CDF00", "Samsung Gear Manager Service"}, + {"ADE3D529-C784-4F63-A987-EB69F70EE816", "IoT OIC Service"}, + {"C2051EE0-804D-4D50-A12C-15E243852100", "Notifications Source"}, + {"C2F2CC0F-C085-4DD4-BE5A-ACA3074BBC72", "Control Point"}, + {"C6B2F38C-23AB-46D8-A6AB-A3A870BBD5D7", "Entity Attribute"}, + {"CECE518B-28D7-4171-92D5-76A1E249A3B9", "Notifications Source"}, + {"FE53FF98-B259-4337-B56A-0EC9F82C6BAD", "Control Point"}, + }; + const uuid_name_s *uuid_name = short_uuid_name; + static const char *unknown_name = "Unknown"; + int start = 0; + int end = SHORT_UUID_COUNT - 1; + int p; + int ret; + + if (strlen(uuid) == 36) { + if (!g_ascii_strncasecmp(uuid + 9, "0000-1000-8000-00805F9B34FB", 27)) + offset = 4; + else { + offset = 0; + uuid_len = 36; + end = LONG_UUID_COUNT - 1; + uuid_name = long_uuid_name; + } + } else if (strlen(uuid) >= 8) + offset = 4; + + while (start <= end) { + p = start + (end - start) / 2; + ret = g_ascii_strncasecmp(uuid + offset, uuid_name[p].uuid, uuid_len); + if (ret == 0) + return uuid_name[p].specification_name; + else if (ret < 0) + end = p - 1; + else + start = p + 1; + } + + return unknown_name; +} + +const char *_bt_convert_error_to_string(int error) { switch (error) { case BLUETOOTH_ERROR_CANCEL: @@ -767,32 +1052,44 @@ char *_bt_convert_error_to_string(int error) return "NOT_INITIALIZED"; case BLUETOOTH_ERROR_AUTHENTICATION_REJECTED: return "AUTHENTICATION REJECTED"; + case BLUETOOTH_ERROR_AUTHORIZATION_REJECTED: + return "AUTHORIZATION REJECTED"; default: return "UNKNOWN"; } } -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: - return "Link loss"; + case (int)BLUETOOTH_ERROR_AUTH_FAILURE: + return "Authentication Failure"; case (int)BLUETOOTH_ERROR_PIN_OR_KEY_MISSING: return "PIN or Key missing"; - case (int)BLUETOOTH_ERROR_LOCAL_HOST_TERM: - return "Connection terminated by local host"; + case (int)BLUETOOTH_ERROR_CONNECTION_TIMEOUT: + return "Link loss"; + case (int)BLUETOOTH_ERROR_CONNECTION_REJECTED_DUE_TO_SECURITY_REASONS: + return "Connection rejected due to security reasons"; case (int)BLUETOOTH_ERROR_REMOTE_USER_TERM: case (int)BLUETOOTH_ERROR_REMOTE_LOW_RESOURCES: case (int)BLUETOOTH_ERROR_REMOTE_POWER_OFF: return "Remote user terminated connection"; - case (int)BLUETOOTH_ERROR_AUTH_FAILURE: - return "Authentication Failure"; + case (int)BLUETOOTH_ERROR_LOCAL_HOST_TERM: + return "Connection terminated by local host"; case (int)BLUETOOTH_ERROR_REPEATED_ATTEMPTS: 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: @@ -800,6 +1097,284 @@ char * _bt_convert_disc_reason_to_string(int reason) } } +const char *_bt_convert_profile_state_to_string(bt_profile_state_t state) +{ + switch (state) { + case BT_PROFILE_STATE_UNAVAILABLE: + return "UNAVAILABLE"; + case BT_PROFILE_STATE_DISCONNECTED: + return "DISCONNECTED"; + case BT_PROFILE_STATE_CONNECTING: + return "CONNECTING"; + case BT_PROFILE_STATE_CONNECTED: + return "CONNECTED"; + case BT_PROFILE_STATE_DISCONNECTING: + return "DISCONNECTING"; + } + + return NULL; +} + +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_DISCONNECT_DEVICE, "BT_DISCONNECT_DEVICE"}, + {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; @@ -870,7 +1445,10 @@ int _bt_byte_arr_cmp_with_mask(const char *data1, const char *data2, int _bt_eventsystem_set_value(const char *event, const char *key, const char *value) { - int ret; + int ret = ES_R_OK; +/* Send event system event in bt-core process because bt-service's permission is not system in now */ + +#if 0 bundle *b = NULL; b = bundle_create(); @@ -882,11 +1460,11 @@ int _bt_eventsystem_set_value(const char *event, const char *key, const char *va BT_DBG("eventsystem_send_system_event result: %d", ret); bundle_free(b); - +#endif 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; @@ -897,8 +1475,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); @@ -907,7 +1484,7 @@ void __bt_get_auth_info(GVariant *reply, char *auth_info) is_alias_set = FALSE; } if (is_alias_set == FALSE) { - tmp_value = g_variant_lookup_value(reply, "ManufacturerDataLen", + tmp_value = g_variant_lookup_value(reply, "LegacyManufacturerDataLen", G_VARIANT_TYPE_UINT16); if (tmp_value) { manufacturer_data_len = g_variant_get_uint16(tmp_value); @@ -920,7 +1497,7 @@ void __bt_get_auth_info(GVariant *reply, char *auth_info) } else manufacturer_data_len = 0; - tmp_value = g_variant_lookup_value(reply, "ManufacturerData", + tmp_value = g_variant_lookup_value(reply, "LegacyManufacturerData", G_VARIANT_TYPE_ARRAY); if (tmp_value) { if ((manufacturer_data_len == 0) ||