[OAL] Add support for 'Reset Adapter'
[platform/core/connectivity/bluetooth-frwk.git] / bt-oal / oal-adapter-mgr.c
old mode 100755 (executable)
new mode 100644 (file)
index 8a4f8fd..7bc9d71
@@ -32,6 +32,7 @@
 #include "oal-hardware.h"
 #include "oal-common.h"
 #include "oal-utils.h"
+#include "oal-gatt.h"
 
 #define CHECK_MAX(max, x) (((max) > (x)) ? (x) : (max))
 
@@ -46,6 +47,9 @@ static int discoverable_timeout = 0;
 /* Forward declarations */
 oal_status_t convert_to_oal_status(bt_status_t status);
 static gboolean retry_enable_adapter(gpointer data);
+#ifdef TIZEN_BT_HAL
+static gboolean retry_enable_le(gpointer data);
+#endif
 oal_status_t oal_mgr_init_internal(void);
 
 
@@ -57,6 +61,19 @@ static void cb_adapter_properties (bt_status_t status,
                int num_properties, bt_property_t *properties);
 extern void cb_device_properties(bt_status_t status, bt_bdaddr_t *bd_addr,
                int num_properties, bt_property_t *properties);
+extern void cb_device_bond_state_changed(bt_status_t status, bt_bdaddr_t *bd_addr,
+                                        bt_bond_state_t state);
+extern void cb_device_acl_state_changed(bt_status_t status, bt_bdaddr_t *remote_bd_addr,
+                                            bt_acl_state_t state);
+extern void cb_device_pin_request(bt_bdaddr_t *bd_addr, bt_bdname_t *bdname, uint32_t device_class);
+extern void cb_device_ssp_request(bt_bdaddr_t *bd_addr, bt_bdname_t *bdname, uint32_t device_class,
+                       bt_ssp_variant_t pairing_variant, uint32_t pass_key);
+extern void cb_device_authorize_request(bt_bdaddr_t *remote_bd_addr, bt_service_id_t service_d);
+extern void cb_device_trust_state_changed(bt_bdaddr_t *remote_bd_addr, bt_device_trust_state_t trusted);
+#ifdef TIZEN_BT_HAL
+extern void cb_socket_conn_authorize_request(bt_bdaddr_t *remote_bd_addr, bt_uuid_t *uuid);
+static void cb_ble_state_change(bt_state_t status);
+#endif
 
 static bt_callbacks_t callbacks = {
        sizeof(callbacks),
@@ -65,14 +82,20 @@ static bt_callbacks_t callbacks = {
        cb_device_properties,
        cb_adapter_device_found,
        cb_adapter_discovery_state_changed,
-       NULL, /* pin_request_callback */
-       NULL, /* ssp_request_callback */
-       NULL, /* bond_state_changed_callback */
-       NULL, /* acl_state_changed_callback */
+       cb_device_pin_request,
+       cb_device_ssp_request,
+       cb_device_bond_state_changed,
+       cb_device_acl_state_changed,
        NULL, /* callback_thread_event */
        NULL, /* dut_mode_recv_callback */
        NULL, /* le_test_mode_callback*/
        NULL, /* energy_info_callback */
+       cb_device_authorize_request,
+       cb_device_trust_state_changed,
+#ifdef TIZEN_BT_HAL
+       cb_socket_conn_authorize_request,
+       cb_ble_state_change,
+#endif
 };
 
 oal_status_t adapter_mgr_init(const bt_interface_t * stack_if)
@@ -140,7 +163,100 @@ oal_status_t adapter_disable(void)
        return OAL_STATUS_SUCCESS;
 }
 
-oal_status_t adapter_start_inquiry(void)
+oal_status_t le_enable(void)
+{
+       int ret = BT_STATUS_SUCCESS;
+
+       API_TRACE();
+       CHECK_OAL_INITIALIZED();
+
+#ifdef TIZEN_BT_HAL
+       if (OAL_STATUS_SUCCESS != hw_is_module_ready()) {
+               g_timeout_add(200, retry_enable_le, NULL);
+               return OAL_STATUS_PENDING;
+       }
+
+       ret = blued_api->le_enable();
+
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("Enable failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+#else
+       BT_INFO("Not Supported");
+       ret = OAL_STATUS_NOT_SUPPORT;
+#endif
+
+       return ret;
+}
+
+oal_status_t le_disable(void)
+{
+       int ret;
+
+       API_TRACE();
+
+       CHECK_OAL_INITIALIZED();
+
+#ifdef TIZEN_BT_HAL
+       ret = blued_api->le_disable();
+
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("Disable failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+#else
+       BT_INFO("Not Supported");
+       ret = OAL_STATUS_NOT_SUPPORT;
+#endif
+       return ret;
+}
+
+oal_status_t adapter_start_custom_inquiry(discovery_type_t disc_type)
+{
+       int ret;
+
+       API_TRACE();
+
+       CHECK_OAL_INITIALIZED();
+       BT_INFO("Custom Discovery Type [0x%x]", disc_type);
+
+#ifdef TIZEN_BT_HAL
+       ret = blued_api->start_custom_discovery(disc_type);
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("start_custom_discovery failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+#else
+       BT_INFO("Not Supported");
+       ret = OAL_STATUS_NOT_SUPPORT;
+#endif
+       return ret;
+}
+
+oal_status_t adapter_reset(void)
+{
+       int ret;
+
+       API_TRACE();
+
+       CHECK_OAL_INITIALIZED();
+       BT_INFO("Adapter Reset");
+
+#ifdef TIZEN_BT_HAL
+       ret = blued_api->reset();
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("Adapter Reset failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+#else
+       BT_INFO("Not Supported");
+       ret = OAL_STATUS_NOT_SUPPORT;
+#endif
+       return ret;
+}
+
+oal_status_t adapter_start_inquiry(unsigned short duration)
 {
        int ret;
 
@@ -185,12 +301,48 @@ static void cb_adapter_state_change(bt_state_t status)
        send_event(event, NULL, 0);
 }
 
+#ifdef TIZEN_BT_HAL
+/* Callbacks from Stack */
+static void cb_ble_state_change(bt_state_t status)
+{
+       BT_DBG("+");
+       oal_event_t event;
+
+       event = (BT_STATE_ON == status)?OAL_EVENT_BLE_ENABLED:OAL_EVENT_BLE_DISABLED;
+
+       send_event(event, NULL, 0);
+}
+#endif
+
 static gboolean retry_enable_adapter(gpointer data)
 {
        adapter_enable();
        return FALSE;
 }
 
+#ifdef TIZEN_BT_HAL
+static gboolean retry_enable_le(gpointer data)
+{
+       le_enable();
+       return FALSE;
+}
+#endif
+oal_status_t adapter_get_properties(void)
+{
+       int ret;
+
+       API_TRACE();
+       CHECK_OAL_INITIALIZED();
+
+       ret = blued_api->get_adapter_properties();
+       if (ret != BT_STATUS_SUCCESS) {
+               BT_ERR("get_adapter_properties failed: [%s]", status2string(ret));
+               return convert_to_oal_status(ret);
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
 oal_status_t adapter_get_address(void)
 {
        int ret;
@@ -393,6 +545,69 @@ oal_status_t adapter_set_discoverable_timeout(int timeout)
        return OAL_STATUS_SUCCESS;
 }
 
+oal_status_t adapter_ble_multi_adv_update(int Ins_id, int min_intv, int max_intv,
+                       int adv_type, int chnl_map, int tx_power, int timeout_s)
+{
+       int res;
+       CHECK_OAL_INITIALIZED();
+       API_TRACE();
+
+       res = gatts_multi_adv_update(Ins_id, min_intv, max_intv,
+                       adv_type, chnl_map, tx_power, timeout_s);
+       if (res != OAL_STATUS_SUCCESS) {
+               BT_ERR("gatts_multi_adv_update: [%d]", res);
+               return res;
+       }
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_ble_multi_adv_set_inst_data(int instance_id,
+                       oal_ble_multi_adv_param_setup_t * adv_param_setup)
+{
+       int res;
+       CHECK_OAL_INITIALIZED();
+       OAL_CHECK_PARAMETER(adv_param_setup, return);
+
+       API_TRACE();
+
+       res = gatts_multi_adv_set_inst_data(instance_id, adv_param_setup);
+       if (res != OAL_STATUS_SUCCESS) {
+               BT_ERR("failed: [%d]", res);
+               return res;
+       }
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_ble_multi_adv_enable(int instance_id)
+{
+       int res;
+       CHECK_OAL_INITIALIZED();
+       API_TRACE();
+
+       res = gatts_multi_adv_enable(instance_id);
+       if (res != OAL_STATUS_SUCCESS) {
+               BT_ERR("failed: [%d]", res);
+               return res;
+       }
+
+       return OAL_STATUS_SUCCESS;
+}
+
+oal_status_t adapter_ble_multi_adv_disable(int instance_id)
+{
+        int res;
+        CHECK_OAL_INITIALIZED();
+        API_TRACE();
+
+        res = gatts_multi_adv_disable(instance_id);
+        if (res != OAL_STATUS_SUCCESS) {
+                BT_ERR("failed: [%d]", res);
+                return res;
+        }
+
+        return OAL_STATUS_SUCCESS;
+}
+
 static void cb_adapter_properties(bt_status_t status,
                                                int num_properties,
                                                bt_property_t *properties)
@@ -472,7 +687,7 @@ static void cb_adapter_properties(bt_status_t status,
 
                                /* Application has requested this property SET/GET hence send EVENT */
                                send_event(OAL_EVENT_ADAPTER_PROPERTY_SERVICES,
-                                               uuids_event, (num_uuid * sizeof(bt_uuid_t)));
+                                               uuids_event, (sizeof(event_adapter_services_t) + num_uuid * sizeof(bt_uuid_t)));
                        }
                        break;
                }
@@ -530,7 +745,7 @@ static void cb_adapter_properties(bt_status_t status,
                                memcpy(event_data->devices[j].addr, bonded_addr_list[j].address, 6);
 
                        send_event(OAL_EVENT_ADAPTER_BONDED_DEVICE_LIST,
-                                       event_data, (num_bonded * sizeof(bt_bdaddr_t)));
+                                       event_data, (sizeof(event_device_list_t) + num_bonded * sizeof(bt_bdaddr_t)));
                        break;
                }
                default: