7fa21df6d824f86ae98bae8fde5749f246e249dc
[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, uint8_t *name, uint8_t *path, uint32_t fd);
75 static void cb_ble_state_change(bt_state_t status);
76 extern void cb_device_le_conn_state_changed(bt_status_t status, bt_bdaddr_t *bd_addr,
77                 bt_le_conn_state_t state);
78 extern void cb_device_trusted_profiles_changed(bt_bdaddr_t *bd_addr, uint32_t trust_val);
79 extern void cb_rssi_monitor_state_changed(bt_bdaddr_t *bd_addr, int32_t link_type, uint8_t state);
80 extern void cb_rssi_alert(bt_bdaddr_t *bd_addr, int32_t link_type, int32_t alert_type, int32_t rssi);
81 extern void cb_raw_rssi_received(bt_bdaddr_t *bd_addr, int32_t link_type, int32_t rssi);
82 #endif
83
84 static bt_callbacks_t callbacks = {
85         .size = sizeof(callbacks),
86         .adapter_state_changed_cb = cb_adapter_state_change,
87         .adapter_properties_cb = cb_adapter_properties,
88         .remote_device_properties_cb = cb_device_properties,
89         .device_found_cb = cb_adapter_device_found,
90         .discovery_state_changed_cb = cb_adapter_discovery_state_changed,
91         .pin_request_cb = cb_device_pin_request,
92         .ssp_request_cb = cb_device_ssp_request,
93         .bond_state_changed_cb = cb_device_bond_state_changed,
94         .acl_state_changed_cb = cb_device_acl_state_changed,
95         .thread_evt_cb = NULL,
96         .dut_mode_recv_cb = NULL,
97         .le_test_mode_cb = NULL,
98         .energy_info_cb = NULL,
99         .authorize_request_cb = cb_device_authorize_request,
100         .device_trust_state_changed_cb = cb_device_trust_state_changed,
101 #ifdef TIZEN_BT_HAL
102         .socket_authorize_request_cb = cb_socket_conn_authorize_request,
103         .le_state_changed_cb = cb_ble_state_change,
104         .le_conn_state_changed_cb = cb_device_le_conn_state_changed,
105         .device_trusted_profiles_changed_cb = cb_device_trusted_profiles_changed,
106         .rssi_monitor_state_changed_cb = cb_rssi_monitor_state_changed,
107         .rssi_alert_cb = cb_rssi_alert,
108         .raw_rssi_received_cb = cb_raw_rssi_received,
109 #endif
110 };
111
112 oal_status_t adapter_mgr_init(const bt_interface_t * stack_if)
113 {
114         int ret;
115         blued_api = stack_if;
116
117         ret = blued_api->init(&callbacks);
118
119         if (ret != BT_STATUS_SUCCESS) {
120                 BT_ERR("Adapter callback registration failed: [%s]", status2string(ret));
121                 blued_api->cleanup();
122                 return convert_to_oal_status(ret);
123         }
124
125         return OAL_STATUS_SUCCESS;
126 }
127
128 const bt_interface_t* adapter_get_stack_interface(void)
129 {
130         return blued_api;
131 }
132
133 void adapter_mgr_cleanup(void)
134 {
135         /* Nothing to clean yet , do not set blued_api NULL as it will be used to clean Bluedroid states */
136         BT_DBG();
137 }
138
139 #ifdef TIZEN_BT_HAL
140 int oal_set_adapter_request_state(int enable)
141 {
142         return blued_api->set_hal_adapter_request_state(enable);
143 }
144
145 int oal_set_le_request_state(int enable)
146 {
147         return blued_api->set_hal_le_request_state(enable);
148 }
149 #endif
150
151 oal_status_t adapter_enable(void)
152 {
153         int ret = BT_STATUS_SUCCESS;
154
155         API_TRACE();
156         CHECK_OAL_INITIALIZED();
157         if (OAL_STATUS_SUCCESS != hw_is_module_ready()) {
158                 g_timeout_add(200, retry_enable_adapter, NULL);
159                 return OAL_STATUS_PENDING;
160         }
161
162         ret = blued_api->enable();
163
164         if (ret != BT_STATUS_SUCCESS) {
165                 BT_ERR("Enable failed: [%s]", status2string(ret));
166                 return convert_to_oal_status(ret);
167         }
168
169         return OAL_STATUS_SUCCESS;
170 }
171
172 oal_status_t adapter_disable(void)
173 {
174         int ret;
175
176         API_TRACE();
177
178         CHECK_OAL_INITIALIZED();
179
180         ret = blued_api->disable();
181
182         if (ret != BT_STATUS_SUCCESS) {
183                 BT_ERR("Disable failed: [%s]", status2string(ret));
184                 return convert_to_oal_status(ret);
185         }
186         return OAL_STATUS_SUCCESS;
187 }
188
189 oal_status_t le_enable(void)
190 {
191         int ret = BT_STATUS_SUCCESS;
192
193         API_TRACE();
194         CHECK_OAL_INITIALIZED();
195
196 #ifdef TIZEN_BT_HAL
197         if (OAL_STATUS_SUCCESS != hw_is_module_ready()) {
198                 g_timeout_add(200, retry_enable_le, NULL);
199                 return OAL_STATUS_PENDING;
200         }
201
202         ret = blued_api->le_enable();
203
204         if (ret != BT_STATUS_SUCCESS) {
205                 BT_ERR("Enable failed: [%s]", status2string(ret));
206                 return convert_to_oal_status(ret);
207         }
208 #else
209         BT_INFO("Not Supported");
210         ret = OAL_STATUS_NOT_SUPPORT;
211 #endif
212
213         return ret;
214 }
215
216 oal_status_t le_disable(void)
217 {
218         int ret;
219
220         API_TRACE();
221
222         CHECK_OAL_INITIALIZED();
223
224 #ifdef TIZEN_BT_HAL
225         ret = blued_api->le_disable();
226
227         if (ret != BT_STATUS_SUCCESS) {
228                 BT_ERR("Disable failed: [%s]", status2string(ret));
229                 return convert_to_oal_status(ret);
230         }
231 #else
232         BT_INFO("Not Supported");
233         ret = OAL_STATUS_NOT_SUPPORT;
234 #endif
235         return ret;
236 }
237
238 oal_status_t le_init(void)
239 {
240         int ret = BT_STATUS_SUCCESS;
241         API_TRACE();
242         CHECK_OAL_INITIALIZED();
243 #ifdef TIZEN_BT_HAL
244         if (OAL_STATUS_SUCCESS != hw_is_module_ready()) {
245                 g_timeout_add(200, retry_enable_le, NULL);
246                 return OAL_STATUS_PENDING;
247         }
248         ret = blued_api->le_init();
249         if (ret != BT_STATUS_SUCCESS) {
250                 BT_ERR("Enable failed: [%s]", status2string(ret));
251                 return convert_to_oal_status(ret);
252         }
253 #else
254         BT_INFO("Not Supported");
255         ret = OAL_STATUS_NOT_SUPPORT;
256 #endif
257         return ret;
258 }
259 oal_status_t le_deinit(void)
260 {
261         int ret = BT_STATUS_SUCCESS;
262         API_TRACE();
263         CHECK_OAL_INITIALIZED();
264 #ifdef TIZEN_BT_HAL
265         if (OAL_STATUS_SUCCESS != hw_is_module_ready()) {
266                 g_timeout_add(200, retry_enable_le, NULL);
267                 return OAL_STATUS_PENDING;
268         }
269         blued_api->le_deinit();
270 #else
271         BT_INFO("Not Supported");
272         ret = OAL_STATUS_NOT_SUPPORT;
273 #endif
274         return ret;
275 }
276 oal_status_t is_advertising(void)
277 {
278         int ret = BT_STATUS_SUCCESS;
279         API_TRACE();
280         CHECK_OAL_INITIALIZED();
281 #ifdef TIZEN_BT_HAL
282         if (OAL_STATUS_SUCCESS != hw_is_module_ready()) {
283                 g_timeout_add(200, retry_enable_le, NULL);
284                 return OAL_STATUS_PENDING;
285         }
286         int r = blued_api->is_advertising();
287         if (r == TRUE)
288                 ret = BT_STATUS_SUCCESS;
289         else
290                 ret = BT_STATUS_FAIL;
291 #else
292         BT_INFO("Not Supported");
293         ret = OAL_STATUS_NOT_SUPPORT;
294 #endif
295         return ret;
296 }
297 oal_status_t adapter_start_custom_inquiry(discovery_type_t disc_type)
298 {
299         int ret;
300
301         API_TRACE();
302
303         CHECK_OAL_INITIALIZED();
304         BT_INFO("Custom Discovery Type [0x%x]", disc_type);
305
306 #ifdef TIZEN_BT_HAL
307         ret = blued_api->start_custom_discovery(disc_type);
308         if (ret != BT_STATUS_SUCCESS) {
309                 BT_ERR("start_custom_discovery failed: [%s]", status2string(ret));
310                 return convert_to_oal_status(ret);
311         }
312 #else
313         BT_INFO("Not Supported");
314         ret = OAL_STATUS_NOT_SUPPORT;
315 #endif
316         return ret;
317 }
318
319 oal_status_t adapter_get_powered_status(gboolean *status)
320 {
321         int ret;
322         unsigned char powered = 0;
323
324         API_TRACE();
325
326         CHECK_OAL_INITIALIZED();
327
328         OAL_CHECK_PARAMETER(status, return);
329         BT_INFO("Get Adapter Powered status");
330
331 #ifdef TIZEN_BT_HAL
332         ret = blued_api->get_adapter_powered_status(&powered);
333         if (ret != BT_STATUS_SUCCESS) {
334                 BT_ERR("adapter_get_powered_status failed: [%s]", status2string(ret));
335                 *status = FALSE;
336                 return convert_to_oal_status(ret);
337         }
338         if (powered == 1)
339                 *status = TRUE;
340         else
341                 *status = FALSE;
342 #else
343         BT_INFO("Not Supported");
344         ret = OAL_STATUS_NOT_SUPPORT;
345 #endif
346         return ret;
347 }
348
349 oal_status_t adapter_reset(void)
350 {
351         int ret;
352
353         API_TRACE();
354
355         CHECK_OAL_INITIALIZED();
356         BT_INFO("Adapter Reset");
357
358 #ifdef TIZEN_BT_HAL
359         ret = blued_api->reset();
360         if (ret != BT_STATUS_SUCCESS) {
361                 BT_ERR("Adapter Reset failed: [%s]", status2string(ret));
362                 return convert_to_oal_status(ret);
363         }
364 #else
365         BT_INFO("Not Supported");
366         ret = OAL_STATUS_NOT_SUPPORT;
367 #endif
368         return ret;
369 }
370
371 oal_status_t adapter_start_inquiry(unsigned short duration)
372 {
373         int ret;
374
375         API_TRACE();
376
377         CHECK_OAL_INITIALIZED();
378
379         ret = blued_api->start_discovery();
380         if (ret != BT_STATUS_SUCCESS) {
381                 BT_ERR("start_discovery failed: [%s]", status2string(ret));
382                 return convert_to_oal_status(ret);
383         }
384
385         return OAL_STATUS_SUCCESS;
386 }
387
388 oal_status_t adapter_stop_inquiry(void)
389 {
390         int ret;
391
392         API_TRACE();
393
394         CHECK_OAL_INITIALIZED();
395
396         ret = blued_api->cancel_discovery();
397         if (ret != BT_STATUS_SUCCESS) {
398                 BT_ERR("cancel_discovery failed: [%s]", status2string(ret));
399                 return convert_to_oal_status(ret);
400         }
401
402         return OAL_STATUS_SUCCESS;
403 }
404
405 /* Callbacks from Stack */
406 static void cb_adapter_state_change(bt_state_t status)
407 {
408         BT_DBG("+");
409         oal_event_t event;
410
411         event = (BT_STATE_ON == status) ? OAL_EVENT_ADAPTER_ENABLED : OAL_EVENT_ADAPTER_DISABLED;
412
413         send_event(event, NULL, 0);
414 }
415
416 #ifdef TIZEN_BT_HAL
417 /* Callbacks from Stack */
418 static void cb_ble_state_change(bt_state_t status)
419 {
420         BT_DBG("+");
421         oal_event_t event;
422
423         event = (BT_STATE_ON == status) ? OAL_EVENT_BLE_ENABLED : OAL_EVENT_BLE_DISABLED;
424
425         send_event(event, NULL, 0);
426 }
427 #endif
428
429 static gboolean retry_enable_adapter(gpointer data)
430 {
431         adapter_enable();
432         return FALSE;
433 }
434
435 #ifdef TIZEN_BT_HAL
436 static gboolean retry_enable_le(gpointer data)
437 {
438         le_enable();
439         return FALSE;
440 }
441 #endif
442 oal_status_t adapter_get_properties(void)
443 {
444         int ret;
445
446         API_TRACE();
447         CHECK_OAL_INITIALIZED();
448
449         ret = blued_api->get_adapter_properties();
450         if (ret != BT_STATUS_SUCCESS) {
451                 BT_ERR("get_adapter_properties failed: [%s]", status2string(ret));
452                 return convert_to_oal_status(ret);
453         }
454
455         return OAL_STATUS_SUCCESS;
456 }
457
458 oal_status_t adapter_get_address(void)
459 {
460         int ret;
461
462         API_TRACE();
463         CHECK_OAL_INITIALIZED();
464
465         ret = blued_api->get_adapter_property(BT_PROPERTY_BDADDR);
466         if (ret != BT_STATUS_SUCCESS) {
467                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
468                 return convert_to_oal_status(ret);
469         }
470
471         return OAL_STATUS_SUCCESS;
472 }
473
474 oal_status_t adapter_get_version(void)
475 {
476         int ret;
477
478         API_TRACE();
479         CHECK_OAL_INITIALIZED();
480
481         ret = blued_api->get_adapter_property(BT_PROPERTY_VERSION);
482         if (ret != BT_STATUS_SUCCESS) {
483                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
484                 return convert_to_oal_status(ret);
485         }
486
487         return OAL_STATUS_SUCCESS;
488 }
489
490 oal_status_t adapter_get_name(void)
491 {
492         int ret;
493
494         CHECK_OAL_INITIALIZED();
495
496         API_TRACE();
497
498         ret = blued_api->get_adapter_property(BT_PROPERTY_BDNAME);
499         if (ret != BT_STATUS_SUCCESS) {
500                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
501                 return convert_to_oal_status(ret);
502         }
503
504         return OAL_STATUS_SUCCESS;
505 }
506
507 oal_status_t adapter_set_name(char * name)
508 {
509         int ret;
510         bt_property_t prop;
511
512         CHECK_OAL_INITIALIZED();
513
514         OAL_CHECK_PARAMETER(name, return);
515         API_TRACE("Name: %s", name);
516
517         prop.type = BT_PROPERTY_BDNAME;
518         prop.len = strlen(name);
519         prop.val = name;
520
521         ret = blued_api->set_adapter_property(&prop);
522         if (ret != BT_STATUS_SUCCESS) {
523                 BT_ERR("set_adapter_property: [%s]", status2string(ret));
524                 ret = OAL_STATUS_INTERNAL_ERROR;
525         } else
526                 ret = OAL_STATUS_SUCCESS;
527
528         return ret;
529 }
530
531 oal_status_t adapter_is_discoverable(int *p_discoverable)
532 {
533         OAL_CHECK_PARAMETER(p_discoverable, return);
534
535         *p_discoverable = (scan_mode == BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE);
536
537         API_TRACE("%d", *p_discoverable);
538
539         return OAL_STATUS_SUCCESS;
540 }
541
542 oal_status_t adapter_is_connectable(int *p_connectable)
543 {
544         OAL_CHECK_PARAMETER(p_connectable, return);
545
546         *p_connectable = (scan_mode == BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE)
547                 || (scan_mode == BT_SCAN_MODE_CONNECTABLE);
548
549         API_TRACE("%d", *p_connectable);
550
551         return OAL_STATUS_SUCCESS;
552 }
553
554 oal_status_t adapter_get_discoverable_timeout(int *p_timeout)
555 {
556         API_TRACE("%d", discoverable_timeout);
557
558         *p_timeout = discoverable_timeout;
559
560         return OAL_STATUS_SUCCESS;
561 }
562
563 oal_status_t adapter_get_service_uuids(void)
564 {
565         int ret;
566
567         CHECK_OAL_INITIALIZED();
568
569         API_TRACE();
570         ret = blued_api->get_adapter_property(BT_PROPERTY_UUIDS);
571         if (ret != BT_STATUS_SUCCESS) {
572                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
573                 return convert_to_oal_status(ret);
574         }
575         return OAL_STATUS_SUCCESS;
576 }
577
578 oal_status_t adapter_get_bonded_devices(void)
579 {
580         int ret;
581
582         CHECK_OAL_INITIALIZED();
583
584         API_TRACE();
585
586         ret = blued_api->get_adapter_property(BT_PROPERTY_ADAPTER_BONDED_DEVICES);
587         if (ret != BT_STATUS_SUCCESS) {
588                 BT_ERR("get_adapter_property failed: [%s]", status2string(ret));
589                 return convert_to_oal_status(ret);
590         }
591
592         return OAL_STATUS_SUCCESS;
593 }
594
595 static oal_status_t set_scan_mode(bt_scan_mode_t mode)
596 {
597         bt_property_t prop;
598         int res;
599
600         BT_DBG("+");
601
602         CHECK_OAL_INITIALIZED();
603
604         prop.type = BT_PROPERTY_ADAPTER_SCAN_MODE;
605         prop.len = sizeof(bt_scan_mode_t);
606         prop.val = &mode;
607         res = blued_api->set_adapter_property(&prop);
608         if (res != BT_STATUS_SUCCESS) {
609                 BT_ERR("set scan mode failed [%s]", status2string(res));
610                 return convert_to_oal_status(res);
611         }
612
613         BT_DBG("-");
614         return OAL_STATUS_SUCCESS;
615 }
616
617 oal_status_t adapter_set_connectable(int connectable)
618 {
619         bt_scan_mode_t mode;
620
621         API_TRACE("%d", connectable);
622
623         CHECK_OAL_INITIALIZED();
624
625         mode = connectable ? BT_SCAN_MODE_CONNECTABLE : BT_SCAN_MODE_NONE;
626
627         return set_scan_mode(mode);
628 }
629
630 oal_status_t adapter_set_discoverable(void)
631 {
632         CHECK_OAL_INITIALIZED();
633         API_TRACE();
634
635         return set_scan_mode(BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE);
636 }
637
638 oal_status_t adapter_set_discoverable_timeout(int timeout)
639 {
640         bt_property_t prop;
641         int res;
642         uint32_t prop_val = timeout;
643
644         CHECK_OAL_INITIALIZED();
645         API_TRACE("%d", timeout);
646
647         prop.type = BT_PROPERTY_ADAPTER_DISCOVERY_TIMEOUT;
648         prop.len = sizeof(prop_val);
649         prop.val = &prop_val;
650         res = blued_api->set_adapter_property(&prop);
651         if (res != BT_STATUS_SUCCESS) {
652                 BT_ERR("set_adapter_property failed [%s]", status2string(res));
653                 return convert_to_oal_status(res);
654         }
655         return OAL_STATUS_SUCCESS;
656 }
657
658 oal_status_t adapter_ble_multi_adv_update(int Ins_id, int min_intv, int max_intv,
659                         int adv_type, int chnl_map, int tx_power, int timeout_s)
660 {
661         int res;
662         CHECK_OAL_INITIALIZED();
663         API_TRACE();
664
665         res = gatts_multi_adv_update(Ins_id, min_intv, max_intv,
666                         adv_type, chnl_map, tx_power, timeout_s);
667         if (res != OAL_STATUS_SUCCESS) {
668                 BT_ERR("gatts_multi_adv_update: [%d]", res);
669                 return res;
670         }
671         return OAL_STATUS_SUCCESS;
672 }
673
674 oal_status_t adapter_ble_multi_adv_set_inst_data(int instance_id,
675                         oal_ble_multi_adv_param_setup_t * adv_param_setup)
676 {
677         int res;
678         CHECK_OAL_INITIALIZED();
679         OAL_CHECK_PARAMETER(adv_param_setup, return);
680
681         API_TRACE();
682
683         res = gatts_multi_adv_set_inst_data(instance_id, adv_param_setup);
684         if (res != OAL_STATUS_SUCCESS) {
685                 BT_ERR("failed: [%d]", res);
686                 return res;
687         }
688         return OAL_STATUS_SUCCESS;
689 }
690
691 oal_status_t adapter_ble_multi_adv_enable(int instance_id)
692 {
693         int res;
694         CHECK_OAL_INITIALIZED();
695         API_TRACE();
696
697         res = gatts_multi_adv_enable(instance_id);
698         if (res != OAL_STATUS_SUCCESS) {
699                 BT_ERR("failed: [%d]", res);
700                 return res;
701         }
702
703         return OAL_STATUS_SUCCESS;
704 }
705
706 oal_status_t adapter_ble_multi_adv_disable(int instance_id)
707 {
708         int res;
709         CHECK_OAL_INITIALIZED();
710         API_TRACE();
711
712         res = gatts_multi_adv_disable(instance_id);
713         if (res != OAL_STATUS_SUCCESS) {
714                 BT_ERR("failed: [%d]", res);
715                 return res;
716         }
717
718         return OAL_STATUS_SUCCESS;
719 }
720
721 oal_status_t adapter_set_le_static_random_address(int enable)
722 {
723         int ret;
724
725         CHECK_OAL_INITIALIZED();
726         API_TRACE("%d", enable);
727
728 #ifdef TIZEN_BT_HAL
729         ret = blued_api->set_le_static_random_address((enable ? 1 : 0));
730         if (ret != BT_STATUS_SUCCESS)
731                 BT_ERR("Static address set failed: [%s]", status2string(ret));
732         ret = convert_to_oal_status(ret);
733 #else
734         BT_INFO("Not Supported");
735         ret = OAL_STATUS_NOT_SUPPORT;
736 #endif
737
738         return ret;
739 }
740
741 oal_status_t adapter_set_manufacturer_data(oal_manufacturer_data_t *m_data)
742 {
743         int ret;
744
745         CHECK_OAL_INITIALIZED();
746         API_TRACE();
747
748         OAL_CHECK_PARAMETER(m_data, return);
749         ret = blued_api->adapter_le_set_manufacturer_data((bt_manufacturer_data_t*)m_data);
750         if (ret != BT_STATUS_SUCCESS)
751                 BT_ERR("Setting manufacturer data Failed: [%s]",status2string(ret));
752
753         ret = convert_to_oal_status(ret);
754         return ret;
755 }
756
757 oal_status_t adapter_set_white_list(bt_address_t *device_address, int address_type, bool is_add)
758 {
759         int ret;
760         bdstr_t bdstr;
761
762         CHECK_OAL_INITIALIZED();
763         API_TRACE();
764
765         BT_INFO("BT remote device Address: %s", bdt_bd2str(device_address, &bdstr));
766
767         ret = blued_api->adapter_le_set_white_list((bt_bdaddr_t*)device_address, address_type, is_add);
768         if (ret != BT_STATUS_SUCCESS) {
769                 if(is_add)
770                         BT_ERR("Add to White List Failed: [%s]",status2string(ret));
771                 else
772                         BT_ERR("Remove from White List Failed: [%s]",status2string(ret));
773         }
774         ret = convert_to_oal_status(ret);
775         return ret;
776 }
777
778 oal_status_t adapter_ble_set_privacy(int set_privacy)
779 {
780         int res;
781
782         CHECK_OAL_INITIALIZED();
783         API_TRACE();
784
785         res = blued_api->adapter_le_set_privacy(set_privacy);
786         if (res != BT_STATUS_SUCCESS)
787                 BT_ERR("Setting LE Privacy Failed: [%s]", status2string(res));
788         res = convert_to_oal_status(res);
789
790         return res;
791 }
792
793 static void cb_adapter_properties(bt_status_t status,
794                 int num_properties,
795                 bt_property_t *properties)
796 {
797         int i;
798
799         BT_DBG("status: %d, count: %d", status, num_properties);
800
801         print_bt_properties(num_properties, properties);
802
803         if (status != BT_STATUS_SUCCESS) {
804                 if (num_properties == 1) {
805                         BT_ERR("Adapter Prop failed: status: [%s], count: %d, prop: %d",
806                                 status2string(status), num_properties, properties[num_properties-1].type);
807                 } else {
808                         BT_ERR("Adapter Prop failed: status: [%s], count: %d", status2string(status), num_properties);
809                 }
810                 return;
811         }
812
813         for (i = 0; i < num_properties; i++) {
814                 BT_DBG("prop type %d, len %d", properties[i].type, properties[i].len);
815                 switch (properties[i].type) {
816                 case BT_PROPERTY_VERSION: {
817                         g_strlcpy(local_version, properties[i].val, BT_VERSION_STR_LEN_MAX);
818                         local_version[properties[i].len] = '\0';
819
820                         BT_DBG("Version: %s", local_version);
821                         /* Send event to application */
822                         if (num_properties == 1) {
823                                 char *adapter_ver = g_strdup(local_version);
824
825                                 /* Application has requested this property SET/GET hence send EVENT */
826                                 send_event(OAL_EVENT_ADAPTER_PROPERTY_VERSION, adapter_ver, strlen(adapter_ver));
827                         }
828                         break;
829                 }
830                 case BT_PROPERTY_BDNAME: {
831                         g_strlcpy(local_name, properties[i].val, BT_DEVICE_NAME_LENGTH_MAX);
832                         local_name[properties[i].len] = '\0';
833
834                         BT_DBG("Name: %s", local_name);
835                         /* Send event to application */
836                         if (num_properties == 1) {
837                                 char * adap_name = g_strdup(local_name);
838
839                                 /* Application has requested this property SET/GET hence send EVENT */
840                                 send_event(OAL_EVENT_ADAPTER_PROPERTY_NAME, adap_name, strlen(adap_name)+1);
841                         }
842                         break;
843                 }
844                 case BT_PROPERTY_BDADDR: {
845                         bt_bdaddr_t * addr;
846
847                         addr =  properties[i].val;
848                         memcpy(local_address.addr, addr->address, 6);
849                         if (num_properties == 1) {
850                                 /* Application has requested this property SET/GET hence send EVENT */
851                                 send_event(OAL_EVENT_ADAPTER_PROPERTY_ADDRESS,
852                                                 g_memdup(&local_address, sizeof(local_address)),
853                                                 sizeof(local_address));
854                         }
855                         break;
856                 }
857                 case BT_PROPERTY_UUIDS: {
858                         int num_uuid;
859
860                         num_uuid = properties[i].len/sizeof(bt_uuid_t);
861
862                         BT_DBG("num_uuid: %d", num_uuid);
863
864                         /* Send event to application */
865                         if (num_properties == 1) {
866                                 event_adapter_services_t *uuids_event;
867
868                                 uuids_event = g_malloc(sizeof(event_adapter_services_t) + properties[i].len);
869                                 memcpy(uuids_event->service_list, properties[i].val, properties[i].len);
870                                 uuids_event->num = num_uuid;
871
872                                 /* Application has requested this property SET/GET hence send EVENT */
873                                 send_event(OAL_EVENT_ADAPTER_PROPERTY_SERVICES,
874                                                 uuids_event, (sizeof(event_adapter_services_t) + num_uuid * sizeof(bt_uuid_t)));
875                         }
876                         break;
877                 }
878                 case BT_PROPERTY_ADAPTER_SCAN_MODE: {
879                         bt_scan_mode_t cur_mode = *((bt_scan_mode_t *)properties[i].val);
880
881                         BT_INFO("Scan mode (%d)", cur_mode);
882
883                         scan_mode = cur_mode;
884
885                         /* Send event to application */
886                         if (num_properties == 1) {
887                                 oal_event_t event = OAL_EVENT_ADAPTER_MODE_NON_CONNECTABLE;
888
889                                 if (BT_SCAN_MODE_CONNECTABLE == cur_mode)
890                                         event = OAL_EVENT_ADAPTER_MODE_CONNECTABLE;
891                                 else if (BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE == cur_mode)
892                                         event = OAL_EVENT_ADAPTER_MODE_DISCOVERABLE;
893
894                                 /* Application has requested this property SET/GET hence send EVENT */
895                                 send_event(event, NULL, 0);
896                         }
897                         break;
898                 }
899                 case BT_PROPERTY_ADAPTER_DISCOVERY_TIMEOUT: {
900                         int timeout;
901
902                         timeout = *((uint32_t*)properties[i].val);
903
904                         BT_INFO("Discoverability timeout: %d", timeout);
905                         discoverable_timeout = timeout;
906
907                         send_event(OAL_EVENT_ADAPTER_MODE_DISCOVERABLE_TIMEOUT,
908                                         g_memdup(properties[i].val, sizeof(uint32_t)),
909                                         sizeof(uint32_t));
910                         break;
911                 }
912                 case BT_PROPERTY_ADAPTER_BONDED_DEVICES: {
913                         int j;
914                         int num_bonded;
915                         bt_bdaddr_t *bonded_addr_list;
916                         event_device_list_t *event_data;
917
918                         num_bonded = properties[i].len/sizeof(bt_bdaddr_t);
919                         BT_DBG("num_bonded %d", num_bonded);
920
921                         if (num_properties > 1) /* No explicit req for this prop, ignore */
922                                 break;
923
924                         bonded_addr_list = properties[i].val;
925                         event_data = g_malloc(sizeof(event_device_list_t) + num_bonded*sizeof(bt_address_t));
926                         event_data->num = num_bonded;
927
928                         for (j = 0; j < num_bonded; j++)
929                                 memcpy(event_data->devices[j].addr, bonded_addr_list[j].address, 6);
930
931                         send_event(OAL_EVENT_ADAPTER_BONDED_DEVICE_LIST,
932                                         event_data, (sizeof(event_device_list_t) + num_bonded * sizeof(bt_bdaddr_t)));
933                         break;
934                 }
935                 case BT_PROPERTY_A2DP_ROLE: {
936                         unsigned int a2dp_role;
937
938                         a2dp_role = *((uint32_t*)properties[i].val);
939
940                         BT_INFO("A2DP role: %u", a2dp_role);
941
942                         send_event(OAL_EVENT_ADAPTER_PROPERTY_A2DP_ROLE,
943                                         g_memdup(properties[i].val, sizeof(uint32_t)),
944                                         sizeof(uint32_t));
945                         break;
946                 }
947                 case BT_PROPERTY_LOCAL_LE_FEATURES: {
948                         event_adapter_le_features_t *le_features;
949
950                         le_features = g_malloc(sizeof(event_adapter_le_features_t));
951
952                         le_features->max_adv_instance = ((bt_local_le_features_t *)(properties[i].val))->max_adv_instance;
953                         le_features->rpa_offloading = ((bt_local_le_features_t *)(properties[i].val))->rpa_offload_supported;
954                         le_features->max_adv_filter = ((bt_local_le_features_t *)(properties[i].val))->max_adv_filter_supported;
955                         le_features->le_2m_phy_support = ((bt_local_le_features_t *)(properties[i].val))->le_2m_phy_supported;
956                         le_features->le_coded_phy_support = ((bt_local_le_features_t *)(properties[i].val))->le_2m_phy_supported;
957
958                         BT_INFO("LE 2M PHY Support (%d)", le_features->le_2m_phy_support);
959                         BT_INFO("LE CODED PHY Support (%d)", le_features->le_coded_phy_support);
960
961                         send_event(OAL_EVENT_BLE_LOCAL_FEATURES,
962                                         le_features,
963                                         sizeof(event_adapter_le_features_t));
964                         break;
965                 }
966                 case BT_PROPERTY_ADAPTER_LE_DISCOVERY_STARTED: {
967                         BT_INFO("LE Discovery started");
968                         send_event(OAL_EVENT_BLE_DISCOVERY_STARTED, NULL, 0);
969                         break;
970                 }
971                 case BT_PROPERTY_ADAPTER_LE_DISCOVERY_STOPPED: {
972                         BT_INFO("LE Discovery stopped");
973                         send_event(OAL_EVENT_BLE_DISCOVERY_STOPPED, NULL, 0);
974                         break;
975                 }
976                 default:
977                          BT_WARN("Unhandled property: %d", properties[i].type);
978                          break;
979                 }
980         }
981 }
982
983 static void cb_adapter_discovery_state_changed(bt_discovery_state_t state)
984 {
985         oal_event_t event;
986
987         event = (BT_DISCOVERY_STARTED == state) ? OAL_EVENT_ADAPTER_INQUIRY_STARTED : OAL_EVENT_ADAPTER_INQUIRY_FINISHED;
988
989         BT_DBG("%d", state);
990         send_event(event, NULL, 0);
991 }
992
993 static void cb_adapter_device_found(int num_properties, bt_property_t *properties)
994 {
995         remote_device_t dev_info;
996         ble_adv_data_t adv_info;
997         oal_event_t event;
998         gpointer event_data;
999         gsize size = 0;
1000         BT_DBG("+");
1001
1002         if (num_properties == 0) {
1003                 BT_ERR("Unexpected, properties count is zero!!");
1004                 return;
1005         }
1006
1007         memset(&dev_info, 0x00, sizeof(remote_device_t));
1008         memset(&adv_info, 0x00, sizeof(ble_adv_data_t));
1009
1010         print_bt_properties(num_properties, properties);
1011         parse_device_properties(num_properties, properties, &dev_info, &adv_info);
1012
1013         BT_INFO("number of properties= [%d] ", num_properties);
1014
1015         if (dev_info.type != DEV_TYPE_BREDR) {
1016                 /* BLE Single or DUAL mode found, so it should have Adv data */
1017                 event_ble_dev_found_t * ble_dev_event = g_new0(event_ble_dev_found_t, 1);
1018
1019                 ble_dev_event->adv_len = adv_info.len;
1020
1021                 if (adv_info.len > 0 && adv_info.adv_data) {
1022                         memcpy(ble_dev_event->adv_data, adv_info.adv_data, adv_info.len);
1023                         ble_dev_event->adv_len = adv_info.len;
1024                 } else
1025                         ble_dev_event->adv_len = 0;
1026
1027                 ble_dev_event->device_info = dev_info;
1028
1029                 event_data = ble_dev_event;
1030                 size = sizeof(event_ble_dev_found_t);
1031                 event = OAL_EVENT_ADAPTER_INQUIRY_RESULT_BLE;
1032         } else {
1033                 /* BREDR device, so No Adv data */
1034                 event_dev_found_t * dev_event = g_new0(event_dev_found_t, 1);
1035
1036                 memcpy(dev_event, &dev_info, sizeof(remote_device_t));
1037                 event_data = dev_event;
1038                 size = sizeof(remote_device_t);
1039                 event = OAL_EVENT_ADAPTER_INQUIRY_RESULT_BREDR_ONLY;
1040         }
1041
1042         send_event(event, event_data, size);
1043
1044         BT_DBG("-");
1045 }