2 * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
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
8 * http://www.apache.org/licenses/LICENSE-2.0
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.
26 #include <net_connection.h>
27 #include <dbus/dbus.h>
33 #include <net_connection.h>
35 #include <eventsystem.h>
36 #include <arpa/inet.h>
38 #include "bluetooth-api.h"
39 #include "bt-service-common.h"
41 #include <oal-manager.h>
43 static GDBusConnection *system_conn;
44 static GDBusConnection *session_conn;
45 static GDBusProxy *manager_proxy;
46 static GDBusProxy *adapter_proxy;
47 static void *net_conn;
49 static GDBusProxy *adapter_properties_proxy;
51 static GDBusConnection *system_gconn = NULL;
53 GDBusConnection *_bt_gdbus_init_system_gconn(void)
57 dbus_threads_init_default();
59 if (system_gconn != NULL)
62 system_gconn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
65 BT_ERR("Unable to connect to dbus: %s", error->message);
66 g_clear_error(&error);
72 GDBusConnection *_bt_gdbus_get_system_gconn(void)
74 GDBusConnection *local_system_gconn = NULL;
77 if (system_gconn == NULL) {
78 system_gconn = _bt_gdbus_init_system_gconn();
79 } else if (g_dbus_connection_is_closed(system_gconn)) {
81 local_system_gconn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
83 if (!local_system_gconn) {
84 BT_ERR("Unable to connect to dbus: %s", error->message);
85 g_clear_error(&error);
88 system_gconn = local_system_gconn;
94 static GDBusProxy *__bt_init_manager_proxy(void)
98 if (system_conn == NULL) {
99 system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
100 retv_if(system_conn == NULL, NULL);
103 proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE,
105 BT_MANAGER_PATH, BT_MANAGER_INTERFACE, NULL, NULL);
107 retv_if(proxy == NULL, NULL);
109 manager_proxy = proxy;
114 static GDBusProxy *__bt_init_adapter_proxy(void)
116 GDBusProxy *manager_proxy;
118 char *adapter_path = NULL;
120 if (system_conn == NULL) {
121 system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
122 retv_if(system_conn == NULL, NULL);
125 manager_proxy = _bt_get_manager_proxy();
126 retv_if(manager_proxy == NULL, NULL);
128 adapter_path = _bt_get_adapter_path();
129 retv_if(adapter_path == NULL, NULL);
131 proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE,
133 adapter_path, BT_ADAPTER_INTERFACE, NULL, NULL);
135 g_free(adapter_path);
137 retv_if(proxy == NULL, NULL);
139 adapter_proxy = proxy;
144 static GDBusProxy *__bt_init_adapter_properties_proxy(void)
146 GDBusProxy *manager_proxy;
148 char *adapter_path = NULL;
150 if (system_conn == NULL) {
151 system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
152 retv_if(system_conn == NULL, NULL);
155 manager_proxy = _bt_get_manager_proxy();
156 retv_if(manager_proxy == NULL, NULL);
158 adapter_path = _bt_get_adapter_path();
159 retv_if(adapter_path == NULL, NULL);
161 proxy = g_dbus_proxy_new_sync(system_conn, G_DBUS_PROXY_FLAGS_NONE,
163 adapter_path, BT_PROPERTIES_INTERFACE, NULL, NULL);
165 g_free(adapter_path);
167 retv_if(proxy == NULL, NULL);
169 adapter_properties_proxy = proxy;
174 GDBusConnection *__bt_init_system_gconn(void)
176 if (system_conn == NULL)
177 system_conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, NULL);
182 GDBusConnection *__bt_init_session_conn(void)
184 if (session_conn == NULL)
185 session_conn = g_bus_get_sync(G_BUS_TYPE_SESSION, NULL, NULL);
190 GDBusConnection *_bt_get_session_gconn(void)
192 return (session_conn) ? session_conn : __bt_init_session_conn();
195 GDBusConnection *_bt_get_system_gconn(void)
197 return (system_conn) ? system_conn : __bt_init_system_gconn();
200 GDBusConnection *_bt_get_system_conn(void)
202 GDBusConnection *g_conn;
204 if (system_conn == NULL) {
205 g_conn = __bt_init_system_gconn();
207 g_conn = system_conn;
210 retv_if(g_conn == NULL, NULL);
215 GDBusProxy *_bt_get_manager_proxy(void)
218 const gchar *path = g_dbus_proxy_get_object_path(manager_proxy);
220 BT_ERR("Already proxy released hence creating new proxy");
221 return __bt_init_manager_proxy();
223 return manager_proxy;
225 return __bt_init_manager_proxy();
228 static void *__bt_init_net_conn(void)
231 connection_h connection = NULL;
233 if (net_conn == NULL) {
234 result = connection_create(&connection);
236 if (result != CONNECTION_ERROR_NONE ||
237 connection == NULL) {
238 BT_DBG("connection_create() failed: %d", result);
242 net_conn = connection;
247 void *_bt_get_net_conn(void)
249 return (net_conn) ? net_conn : __bt_init_net_conn();
252 GDBusProxy *_bt_get_adapter_proxy(void)
255 const char *path = g_dbus_proxy_get_object_path(adapter_proxy);
257 BT_ERR("Already proxy released hence creating new proxy");
258 return __bt_init_adapter_proxy();
261 return adapter_proxy;
263 return __bt_init_adapter_proxy();
267 GDBusProxy *_bt_get_adapter_properties_proxy(void)
269 return (adapter_properties_proxy) ? adapter_properties_proxy :
270 __bt_init_adapter_properties_proxy();
273 static char *__bt_extract_adapter_path(GVariantIter *iter)
275 char *object_path = NULL;
276 GVariantIter *interface_iter;
277 GVariantIter *svc_iter;
278 char *interface_str = NULL;
280 /* Parse the signature: oa{sa{sv}}} */
281 while (g_variant_iter_loop(iter, "{&oa{sa{sv}}}", &object_path,
284 if (object_path == NULL)
287 while (g_variant_iter_loop(interface_iter, "{&sa{sv}}",
288 &interface_str, &svc_iter)) {
289 if (g_strcmp0(interface_str, "org.bluez.Adapter1") != 0)
292 BT_DBG("Object Path: %s", object_path);
293 g_variant_iter_free(svc_iter);
294 g_variant_iter_free(interface_iter);
295 return g_strdup(object_path);
301 char *_bt_get_adapter_path(void)
303 GDBusConnection *conn;
304 GDBusProxy *manager_proxy;
305 GVariant *result = NULL;
306 GVariantIter *iter = NULL;
307 char *adapter_path = NULL;
309 conn = _bt_get_system_conn();
310 retv_if(conn == NULL, NULL);
312 manager_proxy = _bt_get_manager_proxy();
313 retv_if(manager_proxy == NULL, NULL);
315 result = g_dbus_proxy_call_sync(manager_proxy, "GetManagedObjects",
317 G_DBUS_CALL_FLAGS_NONE,
322 BT_ERR("Can't get managed objects");
326 /* signature of GetManagedObjects: a{oa{sa{sv}}} */
327 g_variant_get(result, "(a{oa{sa{sv}}})", &iter);
329 adapter_path = __bt_extract_adapter_path(iter);
330 g_variant_iter_free(iter);
331 g_variant_unref(result);
335 void _bt_deinit_bluez_proxy(void)
338 g_object_unref(manager_proxy);
339 manager_proxy = NULL;
343 g_object_unref(adapter_proxy);
344 adapter_proxy = NULL;
346 if (adapter_properties_proxy) {
347 g_object_unref(adapter_properties_proxy);
348 adapter_properties_proxy = NULL;
352 void _bt_deinit_proxys(void)
355 _bt_deinit_bluez_proxy();
358 g_object_unref(system_conn);
363 g_object_unref(session_conn);
368 ret = connection_destroy(net_conn);
371 BT_ERR("connection_destroy failed : %d", ret);
375 void _bt_convert_device_path_to_address(const char *device_path,
376 char *device_address)
378 char address[BT_ADDRESS_STRING_SIZE] = { 0 };
381 ret_if(device_path == NULL);
382 ret_if(device_address == NULL);
384 dev_addr = strstr(device_path, "dev_");
385 if (dev_addr != NULL) {
388 g_strlcpy(address, dev_addr, sizeof(address));
390 while ((pos = strchr(address, '_')) != NULL) {
394 g_strlcpy(device_address, address, BT_ADDRESS_STRING_SIZE);
399 void _bt_convert_addr_string_to_type(unsigned char *addr,
405 ret_if(address == NULL);
406 ret_if(addr == NULL);
408 for (i = 0; i < BT_ADDRESS_LENGTH_MAX; i++) {
409 addr[i] = strtol(address, &ptr, 16);
410 if (ptr[0] != '\0') {
419 void _bt_convert_addr_type_to_string(char *address,
422 ret_if(address == NULL);
423 ret_if(addr == NULL);
425 snprintf(address, BT_ADDRESS_STRING_SIZE,
426 "%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X",
427 addr[0], addr[1], addr[2],
428 addr[3], addr[4], addr[5]);
431 void _bt_print_device_address_t(const bluetooth_device_address_t *addr)
433 BT_INFO("%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X\n",
434 addr->addr[0], addr->addr[1], addr->addr[2],
435 addr->addr[3], addr->addr[4], addr->addr[5]);
438 void _bt_divide_device_class(bluetooth_device_class_t *device_class,
441 ret_if(device_class == NULL);
443 device_class->major_class = (unsigned short)(cod & 0x00001F00) >> 8;
444 device_class->minor_class = (unsigned short)((cod & 0x000000FC));
445 device_class->service_class = (unsigned long)((cod & 0x00FF0000));
447 if (cod & 0x002000) {
448 device_class->service_class |=
449 BLUETOOTH_DEVICE_SERVICE_CLASS_LIMITED_DISCOVERABLE_MODE;
453 void _bt_free_device_info(bt_remote_dev_info_t *dev_info)
457 ret_if(dev_info == NULL);
459 g_free(dev_info->address);
460 g_free(dev_info->name);
461 g_free(dev_info->manufacturer_data);
463 if (dev_info->uuids) {
464 for (i = 0; i < dev_info->uuid_count && dev_info->uuids[i]; i++)
465 g_free(dev_info->uuids[i]);
467 g_free(dev_info->uuids);
473 void _bt_free_le_device_info(bt_remote_le_dev_info_t *le_dev_info)
475 ret_if(le_dev_info == NULL);
477 g_free(le_dev_info->adv_data);
481 int _bt_copy_utf8_string(char *dest, const char *src, unsigned int length)
488 if (dest == NULL || src == NULL)
489 return BLUETOOTH_ERROR_INVALID_PARAM;
491 BT_DBG("+src : %s", src);
492 BT_DBG("+dest : %s", dest);
495 while (*p != '\0' && i < length) {
496 next = g_utf8_next_char(p);
499 while (count > 0 && ((i + count) < length)) {
506 return BLUETOOTH_ERROR_NONE;
509 gboolean _bt_utf8_validate(char *name)
513 glong items_written = 0;
515 if (FALSE == g_utf8_validate(name, -1, NULL))
518 u16 = g_utf8_to_utf16(name, -1, NULL, &items_written, NULL);
524 if (items_written != g_utf8_strlen(name, -1))
531 int _bt_set_socket_non_blocking(int socket_fd)
533 /* Set Nonblocking */
536 arg = fcntl(socket_fd, F_GETFL);
541 if (arg & O_NONBLOCK) {
542 BT_ERR("Already Non-blocking \n");
547 if (fcntl(socket_fd, F_SETFL, arg) < 0)
550 return BLUETOOTH_ERROR_NONE;
553 int _bt_set_non_blocking_tty(int sk)
555 struct termios ti = {0,};
558 err = _bt_set_socket_non_blocking(sk);
561 BT_ERR("Error in set non blocking!\n");
565 tcflush(sk, TCIOFLUSH);
567 /* Switch tty to RAW mode */
569 tcsetattr(sk, TCSANOW, &ti);
571 return BLUETOOTH_ERROR_NONE;
574 static char *__bt_extract_device_path(GVariantIter *iter, char *address)
576 char *object_path = NULL;
577 char device_address[BT_ADDRESS_STRING_SIZE] = { 0 };
579 /* Parse the signature: oa{sa{sv}}} */
580 while (g_variant_iter_loop(iter, "{&oa{sa{sv}}}", &object_path,
582 retv_if(object_path == NULL, NULL);
583 _bt_convert_device_path_to_address(object_path, device_address);
584 if (g_strcmp0(address, device_address) == 0) {
585 return g_strdup(object_path);
591 char *_bt_get_device_object_path(char *address)
593 char *object_path = NULL;
594 GDBusConnection *conn;
595 GDBusProxy *manager_proxy;
596 GVariant *result = NULL;
597 GVariantIter *iter = NULL;
599 conn = _bt_get_system_conn();
600 retv_if(conn == NULL, NULL);
602 manager_proxy = _bt_get_manager_proxy();
603 retv_if(manager_proxy == NULL, NULL);
605 result = g_dbus_proxy_call_sync(manager_proxy, "GetManagedObjects",
607 G_DBUS_CALL_FLAGS_NONE,
612 BT_ERR("Can't get managed objects");
616 /* signature of GetManagedObjects: a{oa{sa{sv}}} */
617 g_variant_get(result, "(a{oa{sa{sv}}})", &iter);
618 object_path = __bt_extract_device_path(iter, address);
619 g_variant_iter_free(iter);
620 g_variant_unref(result);
624 char *_bt_get_profile_uuid128(bt_profile_type_t profile_type)
626 switch (profile_type) {
627 case BT_PROFILE_CONN_RFCOMM:
628 return strdup(RFCOMM_UUID_STR);
629 case BT_PROFILE_CONN_A2DP:
630 return strdup(A2DP_SINK_UUID);
631 case BT_PROFILE_CONN_A2DP_SINK:
632 return strdup(A2DP_SOURCE_UUID);
633 case BT_PROFILE_CONN_HSP:
634 return strdup(HFP_HS_UUID);
635 case BT_PROFILE_CONN_HID:
636 return strdup(HID_UUID);
637 case BT_PROFILE_CONN_NAP:
638 return strdup(NAP_UUID);
639 case BT_PROFILE_CONN_HFG:
640 return strdup(HFP_AG_UUID);
641 case BT_PROFILE_CONN_GATT:
642 case BT_PROFILE_CONN_ALL: /* NULL UUID will connect to both the audio profiles*/
648 char *_bt_convert_error_to_string(int error)
651 case BLUETOOTH_ERROR_CANCEL:
653 case BLUETOOTH_ERROR_INVALID_PARAM:
654 return "INVALID_PARAMETER";
655 case BLUETOOTH_ERROR_INVALID_DATA:
656 return "INVALID DATA";
657 case BLUETOOTH_ERROR_MEMORY_ALLOCATION:
658 case BLUETOOTH_ERROR_OUT_OF_MEMORY:
659 return "OUT_OF_MEMORY";
660 case BLUETOOTH_ERROR_TIMEOUT:
662 case BLUETOOTH_ERROR_NO_RESOURCES:
663 return "NO_RESOURCES";
664 case BLUETOOTH_ERROR_INTERNAL:
666 case BLUETOOTH_ERROR_NOT_SUPPORT:
667 return "NOT_SUPPORT";
668 case BLUETOOTH_ERROR_DEVICE_NOT_ENABLED:
669 return "NOT_ENABLED";
670 case BLUETOOTH_ERROR_DEVICE_ALREADY_ENABLED:
671 return "ALREADY_ENABLED";
672 case BLUETOOTH_ERROR_DEVICE_BUSY:
673 return "DEVICE_BUSY";
674 case BLUETOOTH_ERROR_ACCESS_DENIED:
675 return "ACCESS_DENIED";
676 case BLUETOOTH_ERROR_MAX_CLIENT:
678 case BLUETOOTH_ERROR_NOT_FOUND:
680 case BLUETOOTH_ERROR_SERVICE_SEARCH_ERROR:
681 return "SERVICE_SEARCH_ERROR";
682 case BLUETOOTH_ERROR_PARING_FAILED:
683 return "PARING_FAILED";
684 case BLUETOOTH_ERROR_NOT_PAIRED:
686 case BLUETOOTH_ERROR_SERVICE_NOT_FOUND:
687 return "SERVICE_NOT_FOUND";
688 case BLUETOOTH_ERROR_NOT_CONNECTED:
689 return "NOT_CONNECTED";
690 case BLUETOOTH_ERROR_ALREADY_CONNECT:
691 return "ALREADY_CONNECT";
692 case BLUETOOTH_ERROR_CONNECTION_BUSY:
693 return "CONNECTION_BUSY";
694 case BLUETOOTH_ERROR_CONNECTION_ERROR:
695 return "CONNECTION_ERROR";
696 case BLUETOOTH_ERROR_MAX_CONNECTION:
697 return "MAX_CONNECTION";
698 case BLUETOOTH_ERROR_NOT_IN_OPERATION:
699 return "NOT_IN_OPERATION";
700 case BLUETOOTH_ERROR_CANCEL_BY_USER:
701 return "CANCEL_BY_USER";
702 case BLUETOOTH_ERROR_REGISTRATION_FAILED:
703 return "REGISTRATION_FAILED";
704 case BLUETOOTH_ERROR_IN_PROGRESS:
705 return "IN_PROGRESS";
706 case BLUETOOTH_ERROR_AUTHENTICATION_FAILED:
707 return "AUTHENTICATION_FAILED";
708 case BLUETOOTH_ERROR_HOST_DOWN:
710 case BLUETOOTH_ERROR_END_OF_DEVICE_LIST:
711 return "END_OF_DEVICE_LIST";
712 case BLUETOOTH_ERROR_AGENT_ALREADY_EXIST:
713 return "AGENT_ALREADY_EXIST";
714 case BLUETOOTH_ERROR_AGENT_DOES_NOT_EXIST:
715 return "AGENT_DOES_NOT_EXIST";
716 case BLUETOOTH_ERROR_ALREADY_INITIALIZED:
717 return "ALREADY_INITIALIZED";
718 case BLUETOOTH_ERROR_PERMISSION_DEINED:
719 return "PERMISSION_DEINED";
720 case BLUETOOTH_ERROR_ALREADY_DEACTIVATED:
721 return "ALREADY_DEACTIVATED";
722 case BLUETOOTH_ERROR_NOT_INITIALIZED:
723 return "NOT_INITIALIZED";
729 char * _bt_convert_disc_reason_to_string(int reason)
735 return "Connection terminated by local host";
737 return "Remote user terminated connection";
744 void _bt_logging_connection(gboolean connect, int addr_type)
746 static int le_conn = 0;
747 static int le_disc = 0;
748 static int edr_conn = 0;
749 static int edr_disc = 0;
763 BT_INFO("[PM] Number of LE conn: %d disc: %d, Number of BR/EDR conn: %d disc: %d",
764 le_conn, le_disc, edr_conn, edr_disc);
767 int _bt_eventsystem_set_value(const char *event, const char *key, const char *value)
774 bundle_add_str(b, key, value);
776 ret = eventsystem_send_system_event(event, b);
778 BT_DBG("eventsystem_send_system_event result: %d", ret);
785 void _bt_swap_byte_ordering(char *data, int data_len)
790 ret_if(data == NULL);
791 /* Swap to opposite endian */
792 for (i = 0, j = data_len - 1; i < data_len; i++, j--) {
799 int _bt_byte_arr_cmp(const char *data1, const char *data2, int data_len)
803 retv_if(data1 == NULL, -1);
804 retv_if(data2 == NULL, -1);
805 for (i = 0; i < data_len; i++) {
806 if (data1[i] != data2[i])
807 return data1[i] - data2[i];
811 int _bt_byte_arr_cmp_with_mask(const char *data1, const char *data2,
812 const char *mask, int data_len)
817 retv_if(data1 == NULL, -1);
818 retv_if(data2 == NULL, -1);
819 retv_if(mask == NULL, -1);
820 for (i = 0; i < data_len; i++) {
821 a = data1[i] & mask[i];
822 b = data2[i] & mask[i];
829 void _bt_copy_remote_dev(bt_remote_dev_info_t * dev_info, remote_device_t * oal_device)
834 dev_info->address = g_new0(char, BT_ADDRESS_STRING_SIZE);
835 _bt_convert_addr_type_to_string(dev_info->address, oal_device->address.addr);
836 BT_INFO("Address [%s]", dev_info->address);
838 if(strlen(oal_device->name)== 0)
839 dev_info->name = NULL;
841 dev_info->name = g_strdup(oal_device->name);
842 _bt_truncate_non_utf8_chars(dev_info->name);
843 BT_INFO("Name [%s]", dev_info->name);
846 dev_info->class = oal_device->cod;
847 BT_INFO("COD [%d]", dev_info->class);
848 dev_info->paired = oal_device->is_bonded;
849 BT_INFO("Is Bonded [%d]", dev_info->paired);
850 dev_info->connected = oal_device->is_connected;
851 BT_INFO("iS Connected [%d]", dev_info->connected);
852 dev_info->rssi = oal_device->rssi;
853 BT_INFO("RSSI [%d]", dev_info->rssi);
854 dev_info->addr_type = oal_device->type;
855 dev_info->uuid_count = oal_device->uuid_count;
856 BT_INFO("UUID Count [%d]", dev_info->uuid_count);
857 dev_info->trust = oal_device->is_trusted;
859 if (dev_info->uuid_count > 0)
860 dev_info->uuids = g_new0(char *, dev_info->uuid_count);
862 /* Fill Remote Device Service List list */
863 for (i=0; i < dev_info->uuid_count; i++) {
864 dev_info->uuids[i] = g_malloc0(BLUETOOTH_UUID_STRING_MAX);
865 _bt_uuid_to_string((service_uuid_t *)&oal_device->uuid[i].uuid, dev_info->uuids[i]);
866 BT_DBG("UUID size=%d value=%s", sizeof(dev_info->uuids[i]), dev_info->uuids[i]);
872 static void __bt_get_service_list(bt_remote_dev_info_t *info, bluetooth_device_info_t *dev)
880 ret_if(info == NULL);
889 dev->service_index = 0;
890 BT_DBG("Total UUID count [%d]", info->uuid_count);
891 for (i = 0; i < info->uuid_count; i++) {
892 BT_DBG("UUID count [%d]", i);
893 g_strlcpy(dev->uuids[i], uuids[i], BLUETOOTH_UUID_STRING_MAX);
895 parts = g_strsplit(uuids[i], "-", -1);
897 if (parts == NULL || parts[0] == NULL)
900 dev->service_list_array[i] = g_ascii_strtoull(parts[0], NULL, 16);
903 dev->service_index++;
909 void _bt_copy_remote_device(bt_remote_dev_info_t *rem_dev, bluetooth_device_info_t *dev)
913 memset(dev, 0x00, sizeof(bluetooth_device_info_t));
914 __bt_get_service_list(rem_dev, dev);
915 _bt_convert_addr_string_to_type(dev->device_address.addr, rem_dev->address);
916 _bt_divide_device_class(&dev->device_class, rem_dev->class);
917 g_strlcpy(dev->device_name.name, rem_dev->name,
918 BLUETOOTH_DEVICE_NAME_LENGTH_MAX+1);
919 dev->rssi = rem_dev->rssi;
920 dev->trust = rem_dev->trust;
921 dev->paired = rem_dev->paired;
922 dev->connected = rem_dev->connected;
924 /* Fill Manufacturer data */
925 if (rem_dev->manufacturer_data_len > 0) {
926 dev->manufacturer_data.data_len = rem_dev->manufacturer_data_len;
927 memcpy(dev->manufacturer_data.data,
928 rem_dev->manufacturer_data, rem_dev->manufacturer_data_len);
930 dev->manufacturer_data.data_len = 0;
935 void _bt_service_print_dev_info(bluetooth_device_info_t *dev_info)
939 ret_if(dev_info == NULL);
941 _bt_print_device_address_t(&(dev_info->device_address));
942 BT_INFO("Device Name:[%s]", dev_info->device_name.name);
943 BT_INFO("Device Major Class:[0x%X]", dev_info->device_class.major_class);
944 BT_INFO("Device Minor Class:[0x%X]", dev_info->device_class.minor_class);
945 BT_INFO("Device Service Class:[0x%X]", dev_info->device_class.minor_class);
946 BT_INFO("Device Paired:[%s]", (dev_info->paired?"TRUE":"FALSE"));
947 BT_INFO("Device Trusted:[%s]", (dev_info->trust?"TRUE":"FALSE"));
948 BT_INFO("Device Connected:[%d]", dev_info->connected);
949 BT_INFO("Device Service index:[%d]", dev_info->service_index);
950 for (i = 0; i < dev_info->service_index; i++) {
951 BT_INFO("Device Service List:[%d]", dev_info->service_list_array[i]);
952 BT_INFO("Device UUID:[%s]", dev_info->uuids[i]);
955 BT_INFO("Device manufacturer data len:[%d]", dev_info->manufacturer_data.data_len);
956 for (i = 0; i < dev_info->manufacturer_data.data_len; i++)
957 BT_INFO("%2.2X", dev_info->manufacturer_data.data[i]);
960 void _bt_uuid_to_string(service_uuid_t *p_uuid, char *str)
962 uint32_t uuid0, uuid4;
963 uint16_t uuid1, uuid2, uuid3, uuid5;
965 memcpy(&uuid0, &(p_uuid->uuid[0]), 4);
966 memcpy(&uuid1, &(p_uuid->uuid[4]), 2);
967 memcpy(&uuid2, &(p_uuid->uuid[6]), 2);
968 memcpy(&uuid3, &(p_uuid->uuid[8]), 2);
969 memcpy(&uuid4, &(p_uuid->uuid[10]), 4);
970 memcpy(&uuid5, &(p_uuid->uuid[14]), 2);
972 snprintf((char *)str, BLUETOOTH_UUID_STRING_MAX, "%.8x-%.4x-%.4x-%.4x-%.8x%.4x",
973 ntohl(uuid0), ntohs(uuid1),
974 ntohs(uuid2), ntohs(uuid3),
975 ntohl(uuid4), ntohs(uuid5));
979 /* Trim string at first non-utf8 char */
980 void _bt_truncate_non_utf8_chars(char * str)
983 const char *ptr = NULL;
985 if (strlen(str) != 0) {
986 if (!g_utf8_validate(str, -1, &ptr)) {
987 while(*(str + i) != *ptr)