[OAL] Add support for 'Reset Adapter'
[platform/core/connectivity/bluetooth-frwk.git] / bt-oal / oal-adapter-mgr.c
old mode 100755 (executable)
new mode 100644 (file)
index 0099338..7bc9d71
 #include "oal-internal.h"
 #include "oal-manager.h"
 #include "oal-hardware.h"
+#include "oal-common.h"
+#include "oal-utils.h"
+#include "oal-gatt.h"
 
 #define CHECK_MAX(max, x) (((max) > (x)) ? (x) : (max))
 
 static const bt_interface_t * blued_api;
 
+static bt_address_t local_address;
+static char local_name[BT_DEVICE_NAME_LENGTH_MAX + 1] = {'O', 'A', 'L', 0};
+static char local_version[BT_VERSION_STR_LEN_MAX + 1];
+static bt_scan_mode_t scan_mode = BT_SCAN_MODE_NONE;
+static int discoverable_timeout = 0;
+
 /* Forward declarations */
-const char * status2string(bt_status_t status);
 oal_status_t convert_to_oal_status(bt_status_t status);
-void parse_device_properties(int num_properties, bt_property_t *properties,
-               remote_device_t *dev_info, ble_adv_data_t * adv_info);
 static gboolean retry_enable_adapter(gpointer data);
+#ifdef TIZEN_BT_HAL
+static gboolean retry_enable_le(gpointer data);
+#endif
 oal_status_t oal_mgr_init_internal(void);
 
 
 /* Callback registered with Stack */
 static void cb_adapter_state_change(bt_state_t status);
+static void cb_adapter_discovery_state_changed(bt_discovery_state_t state);
+static void cb_adapter_device_found(int num_properties, bt_property_t *properties);
+static void cb_adapter_properties (bt_status_t status,
+               int num_properties, bt_property_t *properties);
+extern void cb_device_properties(bt_status_t status, bt_bdaddr_t *bd_addr,
+               int num_properties, bt_property_t *properties);
+extern void cb_device_bond_state_changed(bt_status_t status, bt_bdaddr_t *bd_addr,
+                                        bt_bond_state_t state);
+extern void cb_device_acl_state_changed(bt_status_t status, bt_bdaddr_t *remote_bd_addr,
+                                            bt_acl_state_t state);
+extern void cb_device_pin_request(bt_bdaddr_t *bd_addr, bt_bdname_t *bdname, uint32_t device_class);
+extern void cb_device_ssp_request(bt_bdaddr_t *bd_addr, bt_bdname_t *bdname, uint32_t device_class,
+                       bt_ssp_variant_t pairing_variant, uint32_t pass_key);
+extern void cb_device_authorize_request(bt_bdaddr_t *remote_bd_addr, bt_service_id_t service_d);
+extern void cb_device_trust_state_changed(bt_bdaddr_t *remote_bd_addr, bt_device_trust_state_t trusted);
+#ifdef TIZEN_BT_HAL
+extern void cb_socket_conn_authorize_request(bt_bdaddr_t *remote_bd_addr, bt_uuid_t *uuid);
+static void cb_ble_state_change(bt_state_t status);
+#endif
 
 static bt_callbacks_t callbacks = {
        sizeof(callbacks),
        cb_adapter_state_change,
-       NULL, /* adapter_properties_callback */
-       NULL, /* remote_device_properties_callback */
-       NULL, /* device_found_callback */
-       NULL, /* discovery_state_changed_callback */
-       NULL, /* pin_request_callback */
-       NULL, /* ssp_request_callback */
-       NULL, /* bond_state_changed_callback */
-       NULL, /* acl_state_changed_callback */
+       cb_adapter_properties,
+       cb_device_properties,
+       cb_adapter_device_found,
+       cb_adapter_discovery_state_changed,
+       cb_device_pin_request,
+       cb_device_ssp_request,
+       cb_device_bond_state_changed,
+       cb_device_acl_state_changed,
        NULL, /* callback_thread_event */
        NULL, /* dut_mode_recv_callback */
        NULL, /* le_test_mode_callback*/
        NULL, /* energy_info_callback */
+       cb_device_authorize_request,
+       cb_device_trust_state_changed,
+#ifdef TIZEN_BT_HAL
+       cb_socket_conn_authorize_request,
+       cb_ble_state_change,
+#endif
 };
 
 oal_status_t adapter_mgr_init(const bt_interface_t * stack_if)
@@ -129,6 +163,133 @@ oal_status_t adapter_disable(void)
        return OAL_STATUS_SUCCESS;
 }
 
+oal_status_t le_enable(void)
+{
+       int ret = BT_STATUS_SUCCESS;
+
+       API_TRACE();
+       CHECK_OAL_INITIALIZED();
+
+#ifdef TIZEN_BT_HAL
+       if (OAL_STATUS_SUCCESS != hw_is_module_ready()) {
+               g_timeout_add(200, retry_enable_le, NULL);
+               return OAL_STATUS_PENDING;
+       }
+
+       ret = blued_api->le_enable();
+
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("Enable failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+#else
+       BT_INFO("Not Supported");
+       ret = OAL_STATUS_NOT_SUPPORT;
+#endif
+
+       return ret;
+}
+
+oal_status_t le_disable(void)
+{
+       int ret;
+
+       API_TRACE();
+
+       CHECK_OAL_INITIALIZED();
+
+#ifdef TIZEN_BT_HAL
+       ret = blued_api->le_disable();
+
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("Disable failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+#else
+       BT_INFO("Not Supported");
+       ret = OAL_STATUS_NOT_SUPPORT;
+#endif
+       return ret;
+}
+
+oal_status_t adapter_start_custom_inquiry(discovery_type_t disc_type)
+{
+       int ret;
+
+       API_TRACE();
+
+       CHECK_OAL_INITIALIZED();
+       BT_INFO("Custom Discovery Type [0x%x]", disc_type);
+
+#ifdef TIZEN_BT_HAL
+       ret = blued_api->start_custom_discovery(disc_type);
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("start_custom_discovery failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+#else
+       BT_INFO("Not Supported");
+       ret = OAL_STATUS_NOT_SUPPORT;
+#endif
+       return ret;
+}
+
+oal_status_t adapter_reset(void)
+{
+       int ret;
+
+       API_TRACE();
+
+       CHECK_OAL_INITIALIZED();
+       BT_INFO("Adapter Reset");
+
+#ifdef TIZEN_BT_HAL
+       ret = blued_api->reset();
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("Adapter Reset failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+#else
+       BT_INFO("Not Supported");
+       ret = OAL_STATUS_NOT_SUPPORT;
+#endif
+       return ret;
+}
+
+oal_status_t adapter_start_inquiry(unsigned short duration)
+{
+       int ret;
+
+       API_TRACE();
+
+       CHECK_OAL_INITIALIZED();
+
+       ret = blued_api->start_discovery();
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("start_discovery failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_stop_inquiry(void)
+{
+       int ret;
+
+       API_TRACE();
+
+       CHECK_OAL_INITIALIZED();
+
+       ret = blued_api->cancel_discovery();
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("cancel_discovery failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
 /* Callbacks from Stack */
 static void cb_adapter_state_change(bt_state_t status)
 {
@@ -140,8 +301,520 @@ static void cb_adapter_state_change(bt_state_t status)
        send_event(event, NULL, 0);
 }
 
+#ifdef TIZEN_BT_HAL
+/* Callbacks from Stack */
+static void cb_ble_state_change(bt_state_t status)
+{
+       BT_DBG("+");
+       oal_event_t event;
+
+       event = (BT_STATE_ON == status)?OAL_EVENT_BLE_ENABLED:OAL_EVENT_BLE_DISABLED;
+
+       send_event(event, NULL, 0);
+}
+#endif
+
 static gboolean retry_enable_adapter(gpointer data)
 {
        adapter_enable();
        return FALSE;
 }
+
+#ifdef TIZEN_BT_HAL
+static gboolean retry_enable_le(gpointer data)
+{
+       le_enable();
+       return FALSE;
+}
+#endif
+oal_status_t adapter_get_properties(void)
+{
+       int ret;
+
+       API_TRACE();
+       CHECK_OAL_INITIALIZED();
+
+       ret = blued_api->get_adapter_properties();
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("get_adapter_properties failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_get_address(void)
+{
+       int ret;
+
+       API_TRACE();
+       CHECK_OAL_INITIALIZED();
+
+       ret = blued_api->get_adapter_property(BT_PROPERTY_BDADDR);
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_get_version(void)
+{
+       int ret;
+
+       API_TRACE();
+       CHECK_OAL_INITIALIZED();
+
+       ret = blued_api->get_adapter_property(BT_PROPERTY_VERSION);
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_get_name(void)
+{
+       int ret;
+
+       CHECK_OAL_INITIALIZED();
+
+       API_TRACE();
+
+       ret = blued_api->get_adapter_property(BT_PROPERTY_BDNAME);
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_set_name(char * name)
+{
+       int ret;
+       bt_property_t prop;
+
+       CHECK_OAL_INITIALIZED();
+
+       OAL_CHECK_PARAMETER(name, return);
+       API_TRACE("Name: %s", name);
+
+       prop.type = BT_PROPERTY_BDNAME;
+       prop.len = strlen(name);
+       prop.val = name;
+
+       ret = blued_api->set_adapter_property(&prop);
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("set_adapter_property: [%s]", status2string(ret));
+               ret = OAL_STATUS_INTERNAL_ERROR;
+       } else
+               ret = OAL_STATUS_SUCCESS;
+
+       return ret;
+}
+
+oal_status_t adapter_is_discoverable(int *p_discoverable)
+{
+       OAL_CHECK_PARAMETER(p_discoverable, return);
+
+       *p_discoverable = (scan_mode == BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE);
+
+       API_TRACE("%d", *p_discoverable);
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_is_connectable(int *p_connectable)
+{
+       OAL_CHECK_PARAMETER(p_connectable, return);
+
+       *p_connectable = (scan_mode == BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE)
+               ||(scan_mode == BT_SCAN_MODE_CONNECTABLE);
+
+       API_TRACE("%d", *p_connectable);
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_get_discoverable_timeout(int *p_timeout)
+{
+       API_TRACE("%d", discoverable_timeout);
+
+       *p_timeout = discoverable_timeout;
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_get_service_uuids(void)
+{
+       int ret;
+
+       CHECK_OAL_INITIALIZED();
+
+       API_TRACE();
+
+       ret = blued_api->get_adapter_property(BT_PROPERTY_UUIDS);
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_get_bonded_devices(void)
+{
+       int ret;
+
+       CHECK_OAL_INITIALIZED();
+
+       API_TRACE();
+
+       ret = blued_api->get_adapter_property(BT_PROPERTY_ADAPTER_BONDED_DEVICES);
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
+static oal_status_t set_scan_mode(bt_scan_mode_t mode)
+{
+       bt_property_t prop;
+       int res;
+
+       BT_DBG("+");
+
+       CHECK_OAL_INITIALIZED();
+
+       prop.type = BT_PROPERTY_ADAPTER_SCAN_MODE;
+       prop.len = sizeof(bt_scan_mode_t);
+       prop.val = &mode;
+       res = blued_api->set_adapter_property(&prop);
+       if (res != BT_STATUS_SUCCESS) {
+               BT_ERR("set scan mode failed [%s]", status2string(res));
+               return convert_to_oal_status(res);
+       }
+
+       BT_DBG("-");
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_set_connectable(int connectable)
+{
+       bt_scan_mode_t mode;
+
+       API_TRACE("%d", connectable);
+
+       CHECK_OAL_INITIALIZED();
+
+       mode = connectable ? BT_SCAN_MODE_CONNECTABLE : BT_SCAN_MODE_NONE;
+
+       return set_scan_mode(mode);
+}
+
+oal_status_t adapter_set_discoverable(void)
+{
+       CHECK_OAL_INITIALIZED();
+       API_TRACE();
+
+       return set_scan_mode(BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE);
+}
+
+oal_status_t adapter_set_discoverable_timeout(int timeout)
+{
+       bt_property_t prop;
+       int res;
+       uint32_t prop_val = timeout;
+
+       CHECK_OAL_INITIALIZED();
+       API_TRACE("%d", timeout);
+
+       prop.type = BT_PROPERTY_ADAPTER_DISCOVERY_TIMEOUT;
+       prop.len = sizeof(prop_val);
+       prop.val = &prop_val;
+       res = blued_api->set_adapter_property(&prop);
+       if (res != BT_STATUS_SUCCESS) {
+               BT_ERR("set_adapter_property failed [%s]", status2string(res));
+               return convert_to_oal_status(res);
+       }
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_ble_multi_adv_update(int Ins_id, int min_intv, int max_intv,
+                       int adv_type, int chnl_map, int tx_power, int timeout_s)
+{
+       int res;
+       CHECK_OAL_INITIALIZED();
+       API_TRACE();
+
+       res = gatts_multi_adv_update(Ins_id, min_intv, max_intv,
+                       adv_type, chnl_map, tx_power, timeout_s);
+       if (res != OAL_STATUS_SUCCESS) {
+               BT_ERR("gatts_multi_adv_update: [%d]", res);
+               return res;
+       }
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_ble_multi_adv_set_inst_data(int instance_id,
+                       oal_ble_multi_adv_param_setup_t * adv_param_setup)
+{
+       int res;
+       CHECK_OAL_INITIALIZED();
+       OAL_CHECK_PARAMETER(adv_param_setup, return);
+
+       API_TRACE();
+
+       res = gatts_multi_adv_set_inst_data(instance_id, adv_param_setup);
+       if (res != OAL_STATUS_SUCCESS) {
+               BT_ERR("failed: [%d]", res);
+               return res;
+       }
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_ble_multi_adv_enable(int instance_id)
+{
+       int res;
+       CHECK_OAL_INITIALIZED();
+       API_TRACE();
+
+       res = gatts_multi_adv_enable(instance_id);
+       if (res != OAL_STATUS_SUCCESS) {
+               BT_ERR("failed: [%d]", res);
+               return res;
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_ble_multi_adv_disable(int instance_id)
+{
+        int res;
+        CHECK_OAL_INITIALIZED();
+        API_TRACE();
+
+        res = gatts_multi_adv_disable(instance_id);
+        if (res != OAL_STATUS_SUCCESS) {
+                BT_ERR("failed: [%d]", res);
+                return res;
+        }
+
+        return OAL_STATUS_SUCCESS;
+}
+
+static void cb_adapter_properties(bt_status_t status,
+                                               int num_properties,
+                                               bt_property_t *properties)
+{
+       int i;
+
+       BT_DBG("status: %d, count: %d", status, num_properties);
+
+       if (status != BT_STATUS_SUCCESS) {
+               if (num_properties == 1) {
+                       BT_ERR("Adapter Prop failed: status: [%s], count: %d, prop: %d",
+                               status2string(status), num_properties, properties[num_properties-1].type);
+               } else {
+                       BT_ERR("Adapter Prop failed: status: [%s], count: %d", status2string(status), num_properties);
+               }
+               return;
+       }
+
+       for (i = 0; i < num_properties; i++) {
+               BT_DBG("prop type %d, len %d", properties[i].type, properties[i].len);
+               switch (properties[i].type) {
+               case BT_PROPERTY_VERSION: {
+                       g_strlcpy(local_version, properties[i].val, BT_VERSION_STR_LEN_MAX);
+                       local_version[properties[i].len] = '\0';
+
+                       BT_DBG("Version: %s", local_version);
+                       /* Send event to application */
+                       if (num_properties == 1) {
+                               char *adapter_ver = g_strdup(local_version);
+
+                               /* Application has requested this property SET/GET hence send EVENT */
+                               send_event(OAL_EVENT_ADAPTER_PROPERTY_VERSION, adapter_ver, strlen(adapter_ver));
+                       }
+                       break;
+               }
+               case BT_PROPERTY_BDNAME: {
+                       g_strlcpy(local_name, properties[i].val, BT_DEVICE_NAME_LENGTH_MAX);
+                       local_name[properties[i].len] = '\0';
+
+                       BT_DBG("Name: %s", local_name);
+                       /* Send event to application */
+                       if (num_properties == 1) {
+                               char * adap_name = g_strdup(local_name);
+
+                               /* Application has requested this property SET/GET hence send EVENT */
+                               send_event(OAL_EVENT_ADAPTER_PROPERTY_NAME, adap_name, strlen(adap_name));
+                       }
+                       break;
+               }
+               case BT_PROPERTY_BDADDR: {
+                       bt_bdaddr_t * addr;
+
+                       addr =  properties[i].val;
+                       memcpy(local_address.addr, addr->address, 6);
+                       if (num_properties == 1) {
+                               /* Application has requested this property SET/GET hence send EVENT */
+                               send_event(OAL_EVENT_ADAPTER_PROPERTY_ADDRESS,
+                                               g_memdup(&local_address, sizeof(local_address)),
+                                               sizeof(local_address));
+                       }
+                       break;
+               }
+               case BT_PROPERTY_UUIDS: {
+                       int num_uuid;
+
+                       num_uuid = properties[i].len/sizeof(bt_uuid_t);
+
+                       BT_DBG("num_uuid: %d", num_uuid);
+
+                       /* Send event to application */
+                       if (num_properties == 1) {
+                               event_adapter_services_t *uuids_event;
+
+                               uuids_event = g_malloc(sizeof(event_adapter_services_t) + properties[i].len);
+                               memcpy(uuids_event->service_list, properties[i].val, properties[i].len);
+                               uuids_event->num = num_uuid;
+
+                               /* Application has requested this property SET/GET hence send EVENT */
+                               send_event(OAL_EVENT_ADAPTER_PROPERTY_SERVICES,
+                                               uuids_event, (sizeof(event_adapter_services_t) + num_uuid * sizeof(bt_uuid_t)));
+                       }
+                       break;
+               }
+               case BT_PROPERTY_ADAPTER_SCAN_MODE: {
+                       bt_scan_mode_t cur_mode = *((bt_scan_mode_t *)properties[i].val);
+
+                       BT_INFO("Scan mode (%d)", cur_mode);
+
+                       scan_mode = cur_mode;
+
+                       /* Send event to application */
+                       if (num_properties == 1) {
+                               oal_event_t event = OAL_EVENT_ADAPTER_MODE_NON_CONNECTABLE;
+
+                               if (BT_SCAN_MODE_CONNECTABLE == cur_mode)
+                                       event = OAL_EVENT_ADAPTER_MODE_CONNECTABLE;
+                               else if (BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE == cur_mode)
+                                       event = OAL_EVENT_ADAPTER_MODE_DISCOVERABLE;
+
+                               /* Application has requested this property SET/GET hence send EVENT */
+                               send_event(event, NULL, 0);
+                       }
+                       break;
+               }
+               case BT_PROPERTY_ADAPTER_DISCOVERY_TIMEOUT: {
+                       int timeout;
+
+                       timeout = *((uint32_t*)properties[i].val);
+
+                       BT_INFO("Discoverability timeout: %d", timeout);
+                       discoverable_timeout = timeout;
+
+                       send_event(OAL_EVENT_ADAPTER_MODE_DISCOVERABLE_TIMEOUT,
+                                       g_memdup(properties[i].val, sizeof(uint32_t)),
+                                       sizeof(uint32_t));
+                       break;
+               }
+               case BT_PROPERTY_ADAPTER_BONDED_DEVICES: {
+                       int j;
+                       int num_bonded;
+                       bt_bdaddr_t *bonded_addr_list;
+                       event_device_list_t *event_data;
+
+                       num_bonded = properties[i].len/sizeof(bt_bdaddr_t);
+                       BT_DBG("num_bonded %d", num_bonded);
+
+                       if (num_properties > 1) /* No explicit req for this prop, ignore */
+                               break;
+
+                       bonded_addr_list = properties[i].val;
+                       event_data = g_malloc(sizeof(event_device_list_t) + num_bonded*sizeof(bt_address_t));
+                       event_data->num = num_bonded;
+
+                       for (j = 0; j < num_bonded; j++)
+                               memcpy(event_data->devices[j].addr, bonded_addr_list[j].address, 6);
+
+                       send_event(OAL_EVENT_ADAPTER_BONDED_DEVICE_LIST,
+                                       event_data, (sizeof(event_device_list_t) + num_bonded * sizeof(bt_bdaddr_t)));
+                       break;
+               }
+               default:
+                        BT_WARN("Unhandled property: %d", properties[i].type);
+                        break;
+               }
+       }
+}
+
+static void cb_adapter_discovery_state_changed(bt_discovery_state_t state)
+{
+       oal_event_t event;
+
+       event = (BT_DISCOVERY_STARTED == state)?OAL_EVENT_ADAPTER_INQUIRY_STARTED:OAL_EVENT_ADAPTER_INQUIRY_FINISHED;
+
+       BT_DBG("%d", state);
+       send_event(event, NULL, 0);
+}
+
+static void cb_adapter_device_found(int num_properties, bt_property_t *properties)
+{
+       remote_device_t dev_info;
+       ble_adv_data_t adv_info;
+       oal_event_t event;
+       gpointer event_data;
+       gsize size = 0;
+       BT_DBG("+");
+
+       if (num_properties == 0) {
+               BT_ERR("Unexpected, properties count is zero!!");
+               return;
+       }
+
+       memset(&dev_info, 0x00, sizeof(remote_device_t));
+       memset(&adv_info, 0x00, sizeof(ble_adv_data_t));
+
+       print_bt_properties(num_properties, properties);
+       parse_device_properties(num_properties, properties, &dev_info, &adv_info);
+
+       BT_INFO("number of properties= [%d] ", num_properties, size);
+
+       if (dev_info.type != DEV_TYPE_BREDR) {
+               /* BLE Single or DUAL mode found, so it should have Adv data */
+               event_ble_dev_found_t * ble_dev_event = g_new0(event_ble_dev_found_t, 1);
+
+               ble_dev_event->adv_len = adv_info.len;
+
+               if (adv_info.len > 0 && adv_info.adv_data) {
+                       memcpy(ble_dev_event->adv_data, adv_info.adv_data, adv_info.len);
+                       ble_dev_event->adv_len = adv_info.len;
+               } else
+                       ble_dev_event->adv_len = 0;
+
+               ble_dev_event->device_info = dev_info;
+
+               event_data = ble_dev_event;
+               size = sizeof(event_ble_dev_found_t);
+               event = OAL_EVENT_ADAPTER_INQUIRY_RESULT_BLE;
+       } else {
+               /* BREDR device, so No Adv data */
+               event_dev_found_t * dev_event = g_new0(event_dev_found_t, 1);
+
+               memcpy(dev_event, &dev_info, sizeof(remote_device_t));
+               event_data = dev_event;
+               size = sizeof(remote_device_t);
+               event = OAL_EVENT_ADAPTER_INQUIRY_RESULT_BREDR_ONLY;
+       }
+
+       send_event(event, event_data, size);
+
+       BT_DBG("-");
+}