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