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