Add discovery_duration in adapter_start_discovery()
[platform/core/connectivity/bluetooth-frwk.git] / bt-oal / oal-adapter-mgr.c
1 /*
2  * Open Adaptation Layer (OAL)
3  *
4  * Copyright (c) 2014-2015 Samsung Electronics Co., Ltd.
5  *
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  *
18  */
19
20 #include <stdio.h>
21 #include <stdlib.h>
22 #include <dlog.h>
23 #include <string.h>
24 #include <vconf.h>
25 #include <sys/wait.h>
26
27 #include <bluetooth.h>
28
29 #include "oal-event.h"
30 #include "oal-internal.h"
31 #include "oal-manager.h"
32 #include "oal-hardware.h"
33 #include "oal-common.h"
34 #include "oal-utils.h"
35 #include "oal-gatt.h"
36
37 #define CHECK_MAX(max, x) (((max) > (x)) ? (x) : (max))
38
39 static const bt_interface_t * blued_api;
40
41 static bt_address_t local_address;
42 static char local_name[BT_DEVICE_NAME_LENGTH_MAX + 1] = {'O', 'A', 'L', 0};
43 static char local_version[BT_VERSION_STR_LEN_MAX + 1];
44 static bt_scan_mode_t scan_mode = BT_SCAN_MODE_NONE;
45 static int discoverable_timeout = 0;
46
47 /* Forward declarations */
48 oal_status_t convert_to_oal_status(bt_status_t status);
49 static gboolean retry_enable_adapter(gpointer data);
50 oal_status_t oal_mgr_init_internal(void);
51
52
53 /* Callback registered with Stack */
54 static void cb_adapter_state_change(bt_state_t status);
55 static void cb_adapter_discovery_state_changed(bt_discovery_state_t state);
56 static void cb_adapter_device_found(int num_properties, bt_property_t *properties);
57 static void cb_adapter_properties (bt_status_t status,
58                 int num_properties, bt_property_t *properties);
59 extern void cb_device_properties(bt_status_t status, bt_bdaddr_t *bd_addr,
60                 int num_properties, bt_property_t *properties);
61 extern void cb_device_bond_state_changed(bt_status_t status, bt_bdaddr_t *bd_addr,
62                                         bt_bond_state_t state);
63 extern void cb_device_acl_state_changed(bt_status_t status, bt_bdaddr_t *remote_bd_addr,
64                                             bt_acl_state_t state);
65 extern void cb_device_pin_request(bt_bdaddr_t *bd_addr, bt_bdname_t *bdname, uint32_t device_class);
66 extern void cb_device_ssp_request(bt_bdaddr_t *bd_addr, bt_bdname_t *bdname, uint32_t device_class,
67                         bt_ssp_variant_t pairing_variant, uint32_t pass_key);
68 extern void cb_device_authorize_request(bt_bdaddr_t *remote_bd_addr, bt_service_id_t service_d);
69 extern void cb_device_trust_state_changed(bt_bdaddr_t *remote_bd_addr, bt_device_trust_state_t trusted);
70 #ifdef TIZEN_BT_HAL
71 extern void cb_socket_conn_authorize_request(bt_bdaddr_t *remote_bd_addr, bt_uuid_t *uuid);
72 #endif
73
74 static bt_callbacks_t callbacks = {
75         sizeof(callbacks),
76         cb_adapter_state_change,
77         cb_adapter_properties,
78         cb_device_properties,
79         cb_adapter_device_found,
80         cb_adapter_discovery_state_changed,
81         cb_device_pin_request,
82         cb_device_ssp_request,
83         cb_device_bond_state_changed,
84         cb_device_acl_state_changed,
85         NULL, /* callback_thread_event */
86         NULL, /* dut_mode_recv_callback */
87         NULL, /* le_test_mode_callback*/
88         NULL, /* energy_info_callback */
89         cb_device_authorize_request,
90         cb_device_trust_state_changed,
91 #ifdef TIZEN_BT_HAL
92         cb_socket_conn_authorize_request,
93 #endif
94 };
95
96 oal_status_t adapter_mgr_init(const bt_interface_t * stack_if)
97 {
98         int ret;
99         blued_api = stack_if;
100
101         ret = blued_api->init(&callbacks);
102
103         if (ret != BT_STATUS_SUCCESS) {
104                 BT_ERR("Adapter callback registration failed: [%s]", status2string(ret));
105                 blued_api->cleanup();
106                 return convert_to_oal_status(ret);
107         }
108
109         return OAL_STATUS_SUCCESS;
110 }
111
112 const bt_interface_t* adapter_get_stack_interface(void)
113 {
114         return blued_api;
115 }
116
117 void adapter_mgr_cleanup(void)
118 {
119         /* Nothing to clean yet , do not set blued_api NULL as it will be used to clean Bluedroid states */
120         BT_DBG();
121 }
122
123 oal_status_t adapter_enable(void)
124 {
125         int ret = BT_STATUS_SUCCESS;
126
127         API_TRACE();
128         CHECK_OAL_INITIALIZED();
129         if (OAL_STATUS_SUCCESS != hw_is_module_ready()) {
130                 g_timeout_add(200, retry_enable_adapter, NULL);
131                 return OAL_STATUS_PENDING;
132         }
133
134         ret = blued_api->enable();
135
136         if (ret != BT_STATUS_SUCCESS) {
137                 BT_ERR("Enable failed: [%s]", status2string(ret));
138                 return convert_to_oal_status(ret);
139         }
140
141         return OAL_STATUS_SUCCESS;
142 }
143
144 oal_status_t adapter_disable(void)
145 {
146         int ret;
147
148         API_TRACE();
149
150         CHECK_OAL_INITIALIZED();
151
152         ret = blued_api->disable();
153
154         if (ret != BT_STATUS_SUCCESS) {
155                 BT_ERR("Disable failed: [%s]", status2string(ret));
156                 return convert_to_oal_status(ret);
157         }
158         return OAL_STATUS_SUCCESS;
159 }
160
161 oal_status_t adapter_start_inquiry(unsigned short duration)
162 {
163         int ret;
164
165         API_TRACE();
166
167         CHECK_OAL_INITIALIZED();
168
169         ret = blued_api->start_discovery();
170         if (ret != BT_STATUS_SUCCESS) {
171                 BT_ERR("start_discovery failed: [%s]", status2string(ret));
172                 return convert_to_oal_status(ret);
173         }
174
175         return OAL_STATUS_SUCCESS;
176 }
177
178 oal_status_t adapter_stop_inquiry(void)
179 {
180         int ret;
181
182         API_TRACE();
183
184         CHECK_OAL_INITIALIZED();
185
186         ret = blued_api->cancel_discovery();
187         if (ret != BT_STATUS_SUCCESS) {
188                 BT_ERR("cancel_discovery failed: [%s]", status2string(ret));
189                 return convert_to_oal_status(ret);
190         }
191
192         return OAL_STATUS_SUCCESS;
193 }
194
195 /* Callbacks from Stack */
196 static void cb_adapter_state_change(bt_state_t status)
197 {
198         BT_DBG("+");
199         oal_event_t event;
200
201         event = (BT_STATE_ON == status)?OAL_EVENT_ADAPTER_ENABLED:OAL_EVENT_ADAPTER_DISABLED;
202
203         send_event(event, NULL, 0);
204 }
205
206 static gboolean retry_enable_adapter(gpointer data)
207 {
208         adapter_enable();
209         return FALSE;
210 }
211
212 oal_status_t adapter_get_properties(void)
213 {
214         int ret;
215
216         API_TRACE();
217         CHECK_OAL_INITIALIZED();
218
219         ret = blued_api->get_adapter_properties();
220         if (ret != BT_STATUS_SUCCESS) {
221                 BT_ERR("get_adapter_properties failed: [%s]", status2string(ret));
222                 return convert_to_oal_status(ret);
223         }
224
225         return OAL_STATUS_SUCCESS;
226 }
227
228 oal_status_t adapter_get_address(void)
229 {
230         int ret;
231
232         API_TRACE();
233         CHECK_OAL_INITIALIZED();
234
235         ret = blued_api->get_adapter_property(BT_PROPERTY_BDADDR);
236         if (ret != BT_STATUS_SUCCESS) {
237                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
238                 return convert_to_oal_status(ret);
239         }
240
241         return OAL_STATUS_SUCCESS;
242 }
243
244 oal_status_t adapter_get_version(void)
245 {
246         int ret;
247
248         API_TRACE();
249         CHECK_OAL_INITIALIZED();
250
251         ret = blued_api->get_adapter_property(BT_PROPERTY_VERSION);
252         if (ret != BT_STATUS_SUCCESS) {
253                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
254                 return convert_to_oal_status(ret);
255         }
256
257         return OAL_STATUS_SUCCESS;
258 }
259
260 oal_status_t adapter_get_name(void)
261 {
262         int ret;
263
264         CHECK_OAL_INITIALIZED();
265
266         API_TRACE();
267
268         ret = blued_api->get_adapter_property(BT_PROPERTY_BDNAME);
269         if (ret != BT_STATUS_SUCCESS) {
270                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
271                 return convert_to_oal_status(ret);
272         }
273
274         return OAL_STATUS_SUCCESS;
275 }
276
277 oal_status_t adapter_set_name(char * name)
278 {
279         int ret;
280         bt_property_t prop;
281
282         CHECK_OAL_INITIALIZED();
283
284         OAL_CHECK_PARAMETER(name, return);
285         API_TRACE("Name: %s", name);
286
287         prop.type = BT_PROPERTY_BDNAME;
288         prop.len = strlen(name);
289         prop.val = name;
290
291         ret = blued_api->set_adapter_property(&prop);
292         if (ret != BT_STATUS_SUCCESS) {
293                 BT_ERR("set_adapter_property: [%s]", status2string(ret));
294                 ret = OAL_STATUS_INTERNAL_ERROR;
295         } else
296                 ret = OAL_STATUS_SUCCESS;
297
298         return ret;
299 }
300
301 oal_status_t adapter_is_discoverable(int *p_discoverable)
302 {
303         OAL_CHECK_PARAMETER(p_discoverable, return);
304
305         *p_discoverable = (scan_mode == BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE);
306
307         API_TRACE("%d", *p_discoverable);
308
309         return OAL_STATUS_SUCCESS;
310 }
311
312 oal_status_t adapter_is_connectable(int *p_connectable)
313 {
314         OAL_CHECK_PARAMETER(p_connectable, return);
315
316         *p_connectable = (scan_mode == BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE)
317                 ||(scan_mode == BT_SCAN_MODE_CONNECTABLE);
318
319         API_TRACE("%d", *p_connectable);
320
321         return OAL_STATUS_SUCCESS;
322 }
323
324 oal_status_t adapter_get_discoverable_timeout(int *p_timeout)
325 {
326         API_TRACE("%d", discoverable_timeout);
327
328         *p_timeout = discoverable_timeout;
329
330         return OAL_STATUS_SUCCESS;
331 }
332
333 oal_status_t adapter_get_service_uuids(void)
334 {
335         int ret;
336
337         CHECK_OAL_INITIALIZED();
338
339         API_TRACE();
340
341         ret = blued_api->get_adapter_property(BT_PROPERTY_UUIDS);
342         if (ret != BT_STATUS_SUCCESS) {
343                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
344                 return convert_to_oal_status(ret);
345         }
346
347         return OAL_STATUS_SUCCESS;
348 }
349
350 oal_status_t adapter_get_bonded_devices(void)
351 {
352         int ret;
353
354         CHECK_OAL_INITIALIZED();
355
356         API_TRACE();
357
358         ret = blued_api->get_adapter_property(BT_PROPERTY_ADAPTER_BONDED_DEVICES);
359         if (ret != BT_STATUS_SUCCESS) {
360                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
361                 return convert_to_oal_status(ret);
362         }
363
364         return OAL_STATUS_SUCCESS;
365 }
366
367 static oal_status_t set_scan_mode(bt_scan_mode_t mode)
368 {
369         bt_property_t prop;
370         int res;
371
372         BT_DBG("+");
373
374         CHECK_OAL_INITIALIZED();
375
376         prop.type = BT_PROPERTY_ADAPTER_SCAN_MODE;
377         prop.len = sizeof(bt_scan_mode_t);
378         prop.val = &mode;
379         res = blued_api->set_adapter_property(&prop);
380         if (res != BT_STATUS_SUCCESS) {
381                 BT_ERR("set scan mode failed [%s]", status2string(res));
382                 return convert_to_oal_status(res);
383         }
384
385         BT_DBG("-");
386         return OAL_STATUS_SUCCESS;
387 }
388
389 oal_status_t adapter_set_connectable(int connectable)
390 {
391         bt_scan_mode_t mode;
392
393         API_TRACE("%d", connectable);
394
395         CHECK_OAL_INITIALIZED();
396
397         mode = connectable ? BT_SCAN_MODE_CONNECTABLE : BT_SCAN_MODE_NONE;
398
399         return set_scan_mode(mode);
400 }
401
402 oal_status_t adapter_set_discoverable(void)
403 {
404         CHECK_OAL_INITIALIZED();
405         API_TRACE();
406
407         return set_scan_mode(BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE);
408 }
409
410 oal_status_t adapter_set_discoverable_timeout(int timeout)
411 {
412         bt_property_t prop;
413         int res;
414         uint32_t prop_val = timeout;
415
416         CHECK_OAL_INITIALIZED();
417         API_TRACE("%d", timeout);
418
419         prop.type = BT_PROPERTY_ADAPTER_DISCOVERY_TIMEOUT;
420         prop.len = sizeof(prop_val);
421         prop.val = &prop_val;
422         res = blued_api->set_adapter_property(&prop);
423         if (res != BT_STATUS_SUCCESS) {
424                 BT_ERR("set_adapter_property failed [%s]", status2string(res));
425                 return convert_to_oal_status(res);
426         }
427         return OAL_STATUS_SUCCESS;
428 }
429
430 oal_status_t adapter_ble_multi_adv_update(int Ins_id, int min_intv, int max_intv,
431                         int adv_type, int chnl_map, int tx_power, int timeout_s)
432 {
433         int res;
434         CHECK_OAL_INITIALIZED();
435         API_TRACE();
436
437         res = gatts_multi_adv_update(Ins_id, min_intv, max_intv,
438                         adv_type, chnl_map, tx_power, timeout_s);
439         if (res != OAL_STATUS_SUCCESS) {
440                 BT_ERR("gatts_multi_adv_update: [%d]", res);
441                 return res;
442         }
443         return OAL_STATUS_SUCCESS;
444 }
445
446 oal_status_t adapter_ble_multi_adv_set_inst_data(int instance_id,
447                         oal_ble_multi_adv_param_setup_t * adv_param_setup)
448 {
449         int res;
450         CHECK_OAL_INITIALIZED();
451         OAL_CHECK_PARAMETER(adv_param_setup, return);
452
453         API_TRACE();
454
455         res = gatts_multi_adv_set_inst_data(instance_id, adv_param_setup);
456         if (res != OAL_STATUS_SUCCESS) {
457                 BT_ERR("failed: [%d]", res);
458                 return res;
459         }
460         return OAL_STATUS_SUCCESS;
461 }
462
463 oal_status_t adapter_ble_multi_adv_enable(int instance_id)
464 {
465         int res;
466         CHECK_OAL_INITIALIZED();
467         API_TRACE();
468
469         res = gatts_multi_adv_enable(instance_id);
470         if (res != OAL_STATUS_SUCCESS) {
471                 BT_ERR("failed: [%d]", res);
472                 return res;
473         }
474
475         return OAL_STATUS_SUCCESS;
476 }
477
478 oal_status_t adapter_ble_multi_adv_disable(int instance_id)
479 {
480         int res;
481         CHECK_OAL_INITIALIZED();
482         API_TRACE();
483
484         res = gatts_multi_adv_disable(instance_id);
485         if (res != OAL_STATUS_SUCCESS) {
486                 BT_ERR("failed: [%d]", res);
487                 return res;
488         }
489
490         return OAL_STATUS_SUCCESS;
491 }
492
493 static void cb_adapter_properties(bt_status_t status,
494                                                int num_properties,
495                                                bt_property_t *properties)
496 {
497         int i;
498
499         BT_DBG("status: %d, count: %d", status, num_properties);
500
501         if (status != BT_STATUS_SUCCESS) {
502                 if (num_properties == 1) {
503                         BT_ERR("Adapter Prop failed: status: [%s], count: %d, prop: %d",
504                                 status2string(status), num_properties, properties[num_properties-1].type);
505                 } else {
506                         BT_ERR("Adapter Prop failed: status: [%s], count: %d", status2string(status), num_properties);
507                 }
508                 return;
509         }
510
511         for (i = 0; i < num_properties; i++) {
512                 BT_DBG("prop type %d, len %d", properties[i].type, properties[i].len);
513                 switch (properties[i].type) {
514                 case BT_PROPERTY_VERSION: {
515                         g_strlcpy(local_version, properties[i].val, BT_VERSION_STR_LEN_MAX);
516                         local_version[properties[i].len] = '\0';
517
518                         BT_DBG("Version: %s", local_version);
519                         /* Send event to application */
520                         if (num_properties == 1) {
521                                 char *adapter_ver = g_strdup(local_version);
522
523                                 /* Application has requested this property SET/GET hence send EVENT */
524                                 send_event(OAL_EVENT_ADAPTER_PROPERTY_VERSION, adapter_ver, strlen(adapter_ver));
525                         }
526                         break;
527                 }
528                 case BT_PROPERTY_BDNAME: {
529                         g_strlcpy(local_name, properties[i].val, BT_DEVICE_NAME_LENGTH_MAX);
530                         local_name[properties[i].len] = '\0';
531
532                         BT_DBG("Name: %s", local_name);
533                         /* Send event to application */
534                         if (num_properties == 1) {
535                                 char * adap_name = g_strdup(local_name);
536
537                                 /* Application has requested this property SET/GET hence send EVENT */
538                                 send_event(OAL_EVENT_ADAPTER_PROPERTY_NAME, adap_name, strlen(adap_name));
539                         }
540                         break;
541                 }
542                 case BT_PROPERTY_BDADDR: {
543                         bt_bdaddr_t * addr;
544
545                         addr =  properties[i].val;
546                         memcpy(local_address.addr, addr->address, 6);
547                         if (num_properties == 1) {
548                                 /* Application has requested this property SET/GET hence send EVENT */
549                                 send_event(OAL_EVENT_ADAPTER_PROPERTY_ADDRESS,
550                                                 g_memdup(&local_address, sizeof(local_address)),
551                                                 sizeof(local_address));
552                         }
553                         break;
554                 }
555                 case BT_PROPERTY_UUIDS: {
556                         int num_uuid;
557
558                         num_uuid = properties[i].len/sizeof(bt_uuid_t);
559
560                         BT_DBG("num_uuid: %d", num_uuid);
561
562                         /* Send event to application */
563                         if (num_properties == 1) {
564                                 event_adapter_services_t *uuids_event;
565
566                                 uuids_event = g_malloc(sizeof(event_adapter_services_t) + properties[i].len);
567                                 memcpy(uuids_event->service_list, properties[i].val, properties[i].len);
568                                 uuids_event->num = num_uuid;
569
570                                 /* Application has requested this property SET/GET hence send EVENT */
571                                 send_event(OAL_EVENT_ADAPTER_PROPERTY_SERVICES,
572                                                 uuids_event, (sizeof(event_adapter_services_t) + num_uuid * sizeof(bt_uuid_t)));
573                         }
574                         break;
575                 }
576                 case BT_PROPERTY_ADAPTER_SCAN_MODE: {
577                         bt_scan_mode_t cur_mode = *((bt_scan_mode_t *)properties[i].val);
578
579                         BT_INFO("Scan mode (%d)", cur_mode);
580
581                         scan_mode = cur_mode;
582
583                         /* Send event to application */
584                         if (num_properties == 1) {
585                                 oal_event_t event = OAL_EVENT_ADAPTER_MODE_NON_CONNECTABLE;
586
587                                 if (BT_SCAN_MODE_CONNECTABLE == cur_mode)
588                                         event = OAL_EVENT_ADAPTER_MODE_CONNECTABLE;
589                                 else if (BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE == cur_mode)
590                                         event = OAL_EVENT_ADAPTER_MODE_DISCOVERABLE;
591
592                                 /* Application has requested this property SET/GET hence send EVENT */
593                                 send_event(event, NULL, 0);
594                         }
595                         break;
596                 }
597                 case BT_PROPERTY_ADAPTER_DISCOVERY_TIMEOUT: {
598                         int timeout;
599
600                         timeout = *((uint32_t*)properties[i].val);
601
602                         BT_INFO("Discoverability timeout: %d", timeout);
603                         discoverable_timeout = timeout;
604
605                         send_event(OAL_EVENT_ADAPTER_MODE_DISCOVERABLE_TIMEOUT,
606                                         g_memdup(properties[i].val, sizeof(uint32_t)),
607                                         sizeof(uint32_t));
608                         break;
609                 }
610                 case BT_PROPERTY_ADAPTER_BONDED_DEVICES: {
611                         int j;
612                         int num_bonded;
613                         bt_bdaddr_t *bonded_addr_list;
614                         event_device_list_t *event_data;
615
616                         num_bonded = properties[i].len/sizeof(bt_bdaddr_t);
617                         BT_DBG("num_bonded %d", num_bonded);
618
619                         if (num_properties > 1) /* No explicit req for this prop, ignore */
620                                 break;
621
622                         bonded_addr_list = properties[i].val;
623                         event_data = g_malloc(sizeof(event_device_list_t) + num_bonded*sizeof(bt_address_t));
624                         event_data->num = num_bonded;
625
626                         for (j = 0; j < num_bonded; j++)
627                                 memcpy(event_data->devices[j].addr, bonded_addr_list[j].address, 6);
628
629                         send_event(OAL_EVENT_ADAPTER_BONDED_DEVICE_LIST,
630                                         event_data, (sizeof(event_device_list_t) + num_bonded * sizeof(bt_bdaddr_t)));
631                         break;
632                 }
633                 default:
634                          BT_WARN("Unhandled property: %d", properties[i].type);
635                          break;
636                 }
637         }
638 }
639
640 static void cb_adapter_discovery_state_changed(bt_discovery_state_t state)
641 {
642         oal_event_t event;
643
644         event = (BT_DISCOVERY_STARTED == state)?OAL_EVENT_ADAPTER_INQUIRY_STARTED:OAL_EVENT_ADAPTER_INQUIRY_FINISHED;
645
646         BT_DBG("%d", state);
647         send_event(event, NULL, 0);
648 }
649
650 static void cb_adapter_device_found(int num_properties, bt_property_t *properties)
651 {
652         remote_device_t dev_info;
653         ble_adv_data_t adv_info;
654         oal_event_t event;
655         gpointer event_data;
656         gsize size = 0;
657         BT_DBG("+");
658
659         if (num_properties == 0) {
660                 BT_ERR("Unexpected, properties count is zero!!");
661                 return;
662         }
663
664         memset(&dev_info, 0x00, sizeof(remote_device_t));
665         memset(&adv_info, 0x00, sizeof(ble_adv_data_t));
666
667         print_bt_properties(num_properties, properties);
668         parse_device_properties(num_properties, properties, &dev_info, &adv_info);
669
670         BT_INFO("number of properties= [%d] ", num_properties, size);
671
672         if (dev_info.type != DEV_TYPE_BREDR) {
673                 /* BLE Single or DUAL mode found, so it should have Adv data */
674                 event_ble_dev_found_t * ble_dev_event = g_new0(event_ble_dev_found_t, 1);
675
676                 ble_dev_event->adv_len = adv_info.len;
677
678                 if (adv_info.len > 0 && adv_info.adv_data) {
679                         memcpy(ble_dev_event->adv_data, adv_info.adv_data, adv_info.len);
680                         ble_dev_event->adv_len = adv_info.len;
681                 } else
682                         ble_dev_event->adv_len = 0;
683
684                 ble_dev_event->device_info = dev_info;
685
686                 event_data = ble_dev_event;
687                 size = sizeof(event_ble_dev_found_t);
688                 event = OAL_EVENT_ADAPTER_INQUIRY_RESULT_BLE;
689         } else {
690                 /* BREDR device, so No Adv data */
691                 event_dev_found_t * dev_event = g_new0(event_dev_found_t, 1);
692
693                 memcpy(dev_event, &dev_info, sizeof(remote_device_t));
694                 event_data = dev_event;
695                 size = sizeof(remote_device_t);
696                 event = OAL_EVENT_ADAPTER_INQUIRY_RESULT_BREDR_ONLY;
697         }
698
699         send_event(event, event_data, size);
700
701         BT_DBG("-");
702 }