4 * Copyright (c) 2015 -2016 Samsung Electronics Co., Ltd All Rights Reserved.
6 * Contact: Anupam Roy <anupam.r@samsung.com>
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
29 #include "bt-hal-log.h"
30 #include "bt-hal-msg.h"
31 #include "bt-hal-utils.h"
33 #include <bt-hal-adapter-dbus-handler.h>
34 #include <bt-hal-device-dbus-handler.h>
35 #include <bt-hal-hidhost.h>
36 #include <bt-hal-socket.h>
37 #include <bt-hal-av.h>
38 #include <bt-hal-hf.h>
39 #include <bt-hal-hdp.h>
40 #include <bt-hal-a2dp-sink.h>
41 #include <bt-hal-avrcp-tg.h>
42 #include <bt-hal-avrcp-ctrl.h>
43 #include <bt-hal-gatt.h>
45 #include <bt-hal-adapter-le.h>
46 #include <bt-hal-agent.h>
49 #define enum_prop_to_hal(prop, hal_prop, type) do { \
52 prop.len = sizeof(e); \
53 e = *((uint8_t *) (hal_prop->val)); \
56 static const bt_callbacks_t *bt_hal_cbacks = NULL;
59 /* Forward declarations */
60 static void __bt_adapter_props_to_hal(bt_property_t *send_props, struct hal_property *prop, uint8_t num_props, uint16_t len);
61 static void __bt_device_props_to_hal(bt_property_t *send_props,
62 struct hal_property *prop, uint8_t num_props,
64 static void __bt_hal_handle_adapter_state_changed(void *buf, uint16_t len);
65 static void __bt_hal_handle_adapter_property_changed(void *buf, uint16_t len);
66 static void __bt_hal_handle_stack_messages(int message, void *buf, uint16_t len);
67 static void __bt_hal_handle_adapter_discovery_state_changed(void *buf, uint16_t len);
68 static void __bt_hal_handle_device_found_event(void *buf, uint16_t len);
69 static void __bt_hal_handle_bond_state_changed_event(void *buf, uint16_t len);
70 static void __bt_hal_handle_device_acl_state_changed_event(void *buf, uint16_t len);
71 static void __bt_hal_handle_ssp_request_event(void *buf, uint16_t len);
72 static void __bt_hal_handle_pin_request_event(void *buf, uint16_t len);
74 static void __bt_hal_handle_device_trust_state_changed_event(void *buf, uint16_t len);
76 static bool interface_ready(void)
78 return bt_hal_cbacks != NULL;
81 static int init(bt_callbacks_t *callbacks)
84 DBG("HAL library Initialization..");
86 if (interface_ready())
87 return BT_STATUS_DONE;
89 bt_hal_cbacks = callbacks;
90 DBG("Store HAL stack msg handler callback");
91 _bt_hal_dbus_store_stack_msg_cb(__bt_hal_handle_stack_messages);
92 ret = _bt_hal_initialize_event_receiver(__bt_hal_handle_stack_messages);
94 if (ret == BT_STATUS_SUCCESS)
95 return BT_STATUS_SUCCESS;
97 return BT_STATUS_FAIL;
100 return BT_STATUS_SUCCESS;
104 static int enable(void)
106 return _bt_hal_dbus_enable_adapter();
109 /* Disable Adapter */
110 static int disable(void)
112 return _bt_hal_dbus_disable_adapter();
116 /* Tizen Specific Reset Adapter */
117 static int reset(void)
119 return _bt_hal_dbus_reset_adapter();
123 static void cleanup(void)
129 /* Tizen Specific Get Powered state */
130 static int get_adapter_powered_status(uint8_t *state)
133 ERR("Invalid param");
134 return BT_STATUS_PARM_INVALID;
137 return _bt_hal_get_adapter_powered_state(state);
141 static int get_adapter_properties(void)
143 return _bt_hal_dbus_get_adapter_properties();
146 static int get_adapter_property(bt_property_type_t type)
148 return _bt_hal_dbus_get_adapter_property(type);
151 static int set_adapter_property(const bt_property_t *property)
154 ERR("Invalid param");
155 return BT_STATUS_PARM_INVALID;
158 return _bt_hal_dbus_set_adapter_property(property);
161 static int get_remote_device_properties(bt_bdaddr_t *remote_addr)
164 ERR("Invalid param");
165 return BT_STATUS_PARM_INVALID;
168 return _bt_hal_dbus_get_remote_device_properties(remote_addr);
171 static int get_remote_device_property(bt_bdaddr_t *remote_addr,
172 bt_property_type_t type)
174 return BT_STATUS_UNSUPPORTED;
177 static int set_remote_device_property(bt_bdaddr_t *remote_addr,
178 const bt_property_t *property)
180 return _bt_hal_dbus_set_remote_device_property(remote_addr, property);
183 static int get_remote_service_record(bt_bdaddr_t *remote_addr, bt_uuid_t *uuid)
185 return BT_STATUS_UNSUPPORTED;
188 static int get_remote_services(bt_bdaddr_t *remote_addr)
191 ERR("Invalid param");
192 return BT_STATUS_PARM_INVALID;
194 return _bt_hal_dbus_get_remote_device_services(remote_addr);
197 static int start_discovery(void)
199 return _bt_hal_dbus_start_discovery(false, 0x00);
203 static int start_custom_discovery(bt_disc_role_type_t disc_type)
205 return _bt_hal_dbus_start_discovery(true, disc_type);
209 static int cancel_discovery(void)
211 return _bt_hal_dbus_stop_discovery();
214 static int create_bond(const bt_bdaddr_t *bd_addr, int transport)
217 return _bt_hal_device_create_bond(bd_addr, transport);
220 static int cancel_bond(const bt_bdaddr_t *bd_addr)
222 return _bt_hal_device_cancel_bond(bd_addr);
225 static int remove_bond(const bt_bdaddr_t *bd_addr)
228 return _bt_hal_device_remove_bond(bd_addr);
231 static int pin_reply(const bt_bdaddr_t *bd_addr, uint8_t accept,
232 uint8_t pin_len, bt_pin_code_t *pin_code)
234 return _bt_hal_device_legacy_pin_reply(bd_addr, accept, pin_len, (char*)pin_code);
237 static int ssp_reply(const bt_bdaddr_t *bd_addr, bt_ssp_variant_t variant,
238 uint8_t accept, uint32_t passkey)
240 return _bt_hal_device_ssp_reply(bd_addr, variant, accept, passkey);
243 static const void *get_profile_interface(const char *profile_id)
245 /*TODO: Profile interfaces to be included later*/
246 DBG("%s", profile_id);
248 if (!interface_ready())
251 if (!strncmp(profile_id, BT_PROFILE_HIDHOST_ID, strlen(profile_id)))
252 return bt_get_hidhost_interface();
254 if (!strcmp(profile_id, BT_PROFILE_SOCKETS_ID))
255 return bt_get_socket_interface();
257 if (!strcmp(profile_id, BT_PROFILE_PAN_ID))
260 if (!strcmp(profile_id, BT_PROFILE_ADVANCED_AUDIO_ID))
261 return bt_get_av_interface();
263 if (!strcmp(profile_id, BT_PROFILE_AV_RC_ID))
264 return bt_get_avrcp_tg_interface();
266 if (!strcmp(profile_id, BT_PROFILE_HANDSFREE_ID))
267 return bt_get_hf_interface();
269 if (!strcmp(profile_id, BT_PROFILE_GATT_ID))
270 return bt_get_gatt_interface();
272 if (!strcmp(profile_id, BT_PROFILE_HEALTH_ID))
273 return bt_get_hl_interface();
275 if (!strcmp(profile_id, BT_PROFILE_AV_RC_CTRL_ID))
276 return bt_get_avrcp_ctrl_interface();
278 if (!strcmp(profile_id, BT_PROFILE_HANDSFREE_CLIENT_ID))
281 if (!strcmp(profile_id, BT_PROFILE_MAP_CLIENT_ID))
284 if (!strcmp(profile_id, BT_PROFILE_ADVANCED_AUDIO_SINK_ID))
285 return bt_get_a2dp_sink_interface();
290 static int dut_mode_configure(uint8_t enable)
292 return BT_STATUS_UNSUPPORTED;
295 static int dut_mode_send(uint16_t opcode, uint8_t *buf, uint8_t buf_len)
297 return BT_STATUS_UNSUPPORTED;
300 static int le_test_mode(uint16_t opcode, uint8_t *buf, uint8_t buf_len)
302 return BT_STATUS_UNSUPPORTED;
305 static int config_hci_snoop_log(uint8_t enable)
307 return BT_STATUS_UNSUPPORTED;
310 static int get_connection_state(const bt_bdaddr_t *bd_addr)
313 return _bt_hal_device_get_connection_state(bd_addr);
316 static int set_os_callouts(bt_os_callouts_t *callouts)
318 DBG("callouts: %p", callouts);
320 /* TODO: implement */
322 return BT_STATUS_UNSUPPORTED;
325 static int read_energy_info(void)
327 return BT_STATUS_UNSUPPORTED;
330 static int authorize_response(const bt_bdaddr_t *bd_addr, bt_service_id_t service_id,
331 uint8_t authorize, uint8_t save_settings)
334 return _bt_hal_device_authorize_response(bd_addr, service_id, authorize, save_settings);
337 int set_authorization(bt_bdaddr_t *bd_addr, uint8_t auth)
340 return _bt_hal_device_set_trust(bd_addr, auth);
344 static int get_service_connection_state(const bt_bdaddr_t *bd_addr, bt_service_id_t rem_svc_id)
347 return _bt_hal_device_get_service_connection_state(bd_addr, rem_svc_id);
350 static int set_agent_osp_server(uint32_t type, uint8_t enable)
353 return _bt_hal_device_set_osp_server(type, enable);
356 static int set_trusted_profile(bt_bdaddr_t *bd_addr, bt_trusted_profile_t profile, uint8_t trust)
359 return _bt_hal_device_set_trusted_profile(bd_addr, profile, trust);
362 static int get_trusted_profile(bt_bdaddr_t *bd_addr, bt_trusted_profile_t profile, uint32_t *trusted)
365 return _bt_hal_device_get_trusted_profile(bd_addr, profile, trusted);
368 static int get_connected_link_rssi_strength(bt_bdaddr_t *bd_addr, uint32_t conn_link_type)
371 return _bt_hal_device_get_connected_link_rssi_strength(bd_addr, conn_link_type);
374 static int enable_rssi_monitoring(bt_bdaddr_t *bd_addr, uint32_t conn_link_type,
375 int low_threshold, int in_range_threshold, int high_threshold)
378 return _bt_hal_device_enable_rssi_monitoring(bd_addr, conn_link_type,
379 low_threshold, in_range_threshold, high_threshold);
382 static int enable_gap_auth_notifications(uint32_t type, uint8_t enable)
385 _bt_hal_enable_gap_auth_notifications(type, ((enable == 0) ? FALSE : TRUE));
386 return BT_STATUS_SUCCESS;
389 static int set_hal_adapter_request_state(int enable)
392 _bt_hal_set_adapter_request_state(enable);
393 return BT_STATUS_SUCCESS;
396 static int set_hal_le_request_state(int enable)
399 _bt_hal_set_le_request_state(enable);
400 return BT_STATUS_SUCCESS;
404 static const bt_interface_t bluetooth_if = {
405 .size = sizeof(bt_interface_t),
414 .le_enable = _bt_hal_le_enable,
415 .le_disable = _bt_hal_le_disable,
416 .le_init = _bt_hal_le_init,
417 .le_deinit = _bt_hal_le_deinit,
418 .is_advertising = _bt_hal_is_advertising,
422 .get_adapter_powered_status = get_adapter_powered_status,
424 .get_adapter_properties = get_adapter_properties,
425 .get_adapter_property = get_adapter_property,
426 .set_adapter_property = set_adapter_property,
427 .get_remote_device_properties = get_remote_device_properties,
428 .get_remote_device_property = get_remote_device_property,
429 .set_remote_device_property = set_remote_device_property,
430 .get_remote_service_record = get_remote_service_record,
431 .get_remote_services = get_remote_services,
432 .start_discovery = start_discovery,
434 .start_custom_discovery = start_custom_discovery,
436 .cancel_discovery = cancel_discovery,
437 .create_bond = create_bond,
438 .remove_bond = remove_bond,
439 .cancel_bond = cancel_bond,
440 .pin_reply = pin_reply,
441 .ssp_reply = ssp_reply,
442 .get_profile_interface = get_profile_interface,
443 .dut_mode_configure = dut_mode_configure,
444 .dut_mode_send = dut_mode_send,
445 .le_test_mode = le_test_mode,
446 .config_hci_snoop_log = config_hci_snoop_log,
447 .get_connection_state = get_connection_state,
448 .set_os_callouts = set_os_callouts,
449 .read_energy_info = read_energy_info,
450 /* Tizen Specific API's*/
451 .authorize_response = authorize_response,
452 .set_authorization = set_authorization,
454 .get_service_connection_state = get_service_connection_state,
455 .set_agent_osp_server = set_agent_osp_server,
456 .set_trusted_profile = set_trusted_profile,
457 .get_trusted_profile = get_trusted_profile,
458 .enable_rssi_monitoring = enable_rssi_monitoring,
459 .get_connected_link_rssi_strength = get_connected_link_rssi_strength,
460 .enable_gap_auth_notifications = enable_gap_auth_notifications,
461 .set_le_static_random_address = _bt_hal_set_le_static_random_address,
462 .set_hal_adapter_request_state = set_hal_adapter_request_state,
463 .set_hal_le_request_state = set_hal_le_request_state,
464 .adapter_le_set_white_list = _bt_hal_adapter_le_set_white_list,
465 .adapter_le_set_privacy = _bt_hal_adapter_le_set_privacy,
469 static const bt_interface_t *get_bluetooth_interface(void)
472 return &bluetooth_if;
475 static int close_bluetooth(struct hw_device_t *device)
483 static int open_bluetooth(const struct hw_module_t *module, char const *name,
484 struct hw_device_t **device)
486 bluetooth_device_t *dev = g_malloc0(sizeof(bluetooth_device_t));
490 memset(dev, 0, sizeof(bluetooth_device_t));
491 dev->common.tag = HARDWARE_DEVICE_TAG;
492 dev->common.version = 0;
493 dev->common.module = (struct hw_module_t *) module;
494 dev->common.close = close_bluetooth;
495 dev->get_bluetooth_interface = get_bluetooth_interface;
497 *device = (struct hw_device_t *) dev;
502 static struct hw_module_methods_t bluetooth_module_methods = {
503 .open = open_bluetooth,
506 struct hw_module_t HAL_MODULE_INFO_SYM = {
507 .tag = HARDWARE_MODULE_TAG,
510 .id = BT_HARDWARE_MODULE_ID,
511 .name = "Bluetooth stack",
512 .author = "Intel Corporation",
513 .methods = &bluetooth_module_methods
516 static void __bt_hal_handle_adapter_state_changed(void *buf, uint16_t len)
518 struct hal_ev_adapter_state_changed *ev = buf;
520 DBG("Adapter State: %d", ev->state);
522 if (bt_hal_cbacks->adapter_state_changed_cb)
523 bt_hal_cbacks->adapter_state_changed_cb(ev->state);
527 static void __bt_hal_handle_le_state_changed(void *buf, uint16_t len)
529 struct hal_ev_le_state_changed *ev = buf;
531 DBG("Adapter State: %d", ev->state);
533 if (bt_hal_cbacks->le_state_changed_cb)
534 bt_hal_cbacks->le_state_changed_cb(ev->state);
538 static void __bt_adapter_props_to_hal(bt_property_t *send_props, struct hal_property *prop,
539 uint8_t num_props, uint16_t len)
544 for (i = 0; i < num_props; i++) {
545 if (sizeof(*prop) + prop->len > len) {
546 ERR("invalid adapter properties(%zu > %u), cant process further properties!!!",
547 sizeof(*prop) + prop->len, len);
551 send_props[i].type = prop->type;
553 switch (prop->type) {
554 /* TODO: Add Adapter Properties */
556 send_props[i].len = prop->len;
557 send_props[i].val = prop->val;
561 DBG("prop[%d]: %s", i, btproperty2str(&send_props[i]));
563 len -= sizeof(*prop) + prop->len;
564 buf += sizeof(*prop) + prop->len;
572 static void __bt_device_props_to_hal(bt_property_t *send_props,
573 struct hal_property *prop, uint8_t num_props,
581 for (i = 0; i < num_props; i++) {
583 if (sizeof(*prop) + prop->len > len) {
584 ERR("invalid device properties (%zu > %u), cant process further properties!!!",
585 sizeof(*prop) + prop->len, len);
589 send_props[i].type = prop->type;
591 DBG("HAL prop Type [%d]", prop->type);
593 switch (prop->type) {
594 case HAL_PROP_DEVICE_TYPE:
596 DBG("Device property:HAL_PROP_DEVICE_TYPE:");
597 enum_prop_to_hal(send_props[i], prop,
601 case HAL_PROP_DEVICE_VERSION_INFO:
603 DBG("Device property: HAL_PROP_DEVICE_VERSION_INFO");
604 static bt_remote_version_t e;
605 const struct hal_prop_device_info *p;
606 send_props[i].val = &e;
607 send_props[i].len = sizeof(e);
608 p = (struct hal_prop_device_info *) prop->val;
609 e.manufacturer = p->manufacturer;
610 e.sub_ver = p->sub_version;
611 e.version = p->version;
614 case HAL_PROP_DEVICE_SERVICE_REC:
616 DBG("Device property: HAL_PROP_DEVICE_SERVICE_REC");
617 static bt_service_record_t e;
618 const struct hal_prop_device_service_rec *p;
619 send_props[i].val = &e;
620 send_props[i].len = sizeof(e);
621 p = (struct hal_prop_device_service_rec *) prop->val;
622 memset(&e, 0, sizeof(e));
623 memcpy(&e.channel, &p->channel, sizeof(e.channel));
624 memcpy(e.uuid.uu, p->uuid, sizeof(e.uuid.uu));
625 memcpy(e.name, p->name, p->name_len);
629 send_props[i].len = prop->len;
630 send_props[i].val = prop->val;
634 DBG("prop[%d]: %s, len: %d", i, btproperty2str(&send_props[i]), prop->len);
635 len -= sizeof(*prop) + prop->len;
636 buf += sizeof(*prop) + prop->len;
646 ERR("invalid device properties (%u bytes left), ", len);
649 static void __bt_hal_handle_adapter_property_changed(void *buf, uint16_t len)
651 struct hal_ev_adapter_props_changed *ev = (struct hal_ev_adapter_props_changed *)buf;
652 bt_property_t props[ev->num_props];
655 if (!bt_hal_cbacks->adapter_properties_cb)
659 __bt_adapter_props_to_hal(props, ev->props, ev->num_props, len);
661 if (bt_hal_cbacks->adapter_properties_cb)
662 bt_hal_cbacks->adapter_properties_cb(ev->status, ev->num_props, props);
665 static void __bt_hal_handle_adapter_discovery_state_changed(void *buf, uint16_t len)
667 struct hal_ev_discovery_state_changed *ev = (struct hal_ev_discovery_state_changed *)buf;
671 if (bt_hal_cbacks->discovery_state_changed_cb)
672 bt_hal_cbacks->discovery_state_changed_cb(ev->state);
675 static void __bt_hal_handle_device_found_event(void *buf, uint16_t len)
677 struct hal_ev_device_found *ev = (struct hal_ev_device_found *) buf;
678 bt_property_t props[ev->num_props];
681 if (!bt_hal_cbacks->device_found_cb)
685 __bt_device_props_to_hal(props, ev->props, ev->num_props, len);
687 bt_hal_cbacks->device_found_cb(ev->num_props, props);
690 static void __bt_hal_handle_remote_device_properties_event(void *buf, uint16_t len)
692 struct hal_ev_remote_device_props *ev = (struct hal_ev_remote_device_props *) buf;
694 bt_property_t props[ev->num_props];
698 if (!bt_hal_cbacks->remote_device_properties_cb)
702 __bt_device_props_to_hal(props, ev->props, ev->num_props, len);
703 memcpy(bd_addr.address, ev->bdaddr, 6);
704 bt_hal_cbacks->remote_device_properties_cb(
705 ev->status, &bd_addr, ev->num_props, props);
709 static void __bt_hal_handle_bond_state_changed_event(void *buf, uint16_t len)
712 struct hal_ev_bond_state_changed *ev = (struct hal_ev_bond_state_changed *)buf;
716 memcpy(bd_addr.address, ev->bdaddr, 6);
718 DBG("[0x%x]", bd_addr.address[0]);
719 DBG("[0x%x]", bd_addr.address[1]);
720 DBG("[0x%x]", bd_addr.address[2]);
721 DBG("[0x%x]", bd_addr.address[3]);
722 DBG("[0x%x]", bd_addr.address[4]);
723 DBG("[0x%x]", bd_addr.address[5]);
725 DBG("Bonding State changed Status [0x%x]", ev->status);
726 DBG("Bonding State [0x%x]", ev->state);
728 if (!bt_hal_cbacks->bond_state_changed_cb) {
729 ERR("HAL User bond_state_changed_callback is not set!!");
733 bt_hal_cbacks->bond_state_changed_cb(ev->status, &bd_addr, ev->state);
737 static void __bt_hal_handle_device_acl_state_changed_event(void *buf, uint16_t len)
739 struct hal_ev_acl_state_changed *ev = (struct hal_ev_acl_state_changed*)buf;
743 memcpy(bd_addr.address, ev->bdaddr, 6);
745 DBG("[0x%x]", bd_addr.address[0]);
746 DBG("[0x%x]", bd_addr.address[1]);
747 DBG("[0x%x]", bd_addr.address[2]);
748 DBG("[0x%x]", bd_addr.address[3]);
749 DBG("[0x%x]", bd_addr.address[4]);
750 DBG("[0x%x]", bd_addr.address[5]);
752 DBG("ACL Status [0x%x]", ev->status);
753 DBG("ACL State [0x%x]", ev->state);
755 if (!bt_hal_cbacks->acl_state_changed_cb) {
756 ERR("HAL User acl_state_changed_cb is not set!!");
760 bt_hal_cbacks->acl_state_changed_cb(ev->status, &bd_addr, ev->state);
764 static void __bt_hal_handle_device_le_conn_state_changed_event(void *buf, uint16_t len)
766 struct hal_ev_acl_state_changed *ev = (struct hal_ev_acl_state_changed*)buf;
770 memcpy(bd_addr.address, ev->bdaddr, 6);
772 DBG("Address: [%02X:%02X:%02X:%02X:%02X:%02X]", bd_addr.address[0],
773 bd_addr.address[1], bd_addr.address[2], bd_addr.address[3],
774 bd_addr.address[4], bd_addr.address[5]);
775 DBG("LE conn Status [0x%x]", ev->status);
776 DBG("LE conn State [0x%x]", ev->state);
779 if (!bt_hal_cbacks->le_conn_state_changed_cb) {
780 ERR("HAL User le_conn_state_changed_cb is not set!!");
784 bt_hal_cbacks->le_conn_state_changed_cb(ev->status, &bd_addr, ev->state);
789 static void __bt_hal_handle_authorize_request_event(void *buf, uint16_t len)
791 struct hal_ev_authorize_request *ev = (struct hal_ev_authorize_request *)buf;
796 memcpy(bd_addr.address, ev->bdaddr, 6);
799 DBG("[0x%x]", bd_addr.address[0]);
800 DBG("[0x%x]", bd_addr.address[1]);
801 DBG("[0x%x]", bd_addr.address[2]);
802 DBG("[0x%x]", bd_addr.address[3]);
803 DBG("[0x%x]", bd_addr.address[4]);
804 DBG("[0x%x]", bd_addr.address[5]);
806 DBG("Service Id: [%u]", ev->service_id);
808 if (!bt_hal_cbacks->authorize_request_cb) {
809 ERR("HAL User authorize_request_cb is not set!!");
813 bt_hal_cbacks->authorize_request_cb(&bd_addr, ev->service_id);
818 static void __bt_hal_handle_socket_authorize_request_event(void *buf, uint16_t len)
820 struct hal_ev_sock_conn_auth *ev = buf;
826 memcpy(bd_addr.address, ev->bdaddr, 6);
827 memcpy(uuid.uu, ev->uuid, 16);
829 if (!bt_hal_cbacks->socket_authorize_request_cb) {
830 ERR("HAL User socket_authorize_request_cb is not set!!");
834 bt_hal_cbacks->socket_authorize_request_cb(&bd_addr, &uuid);
839 static void __bt_hal_handle_ssp_request_event(void *buf, uint16_t len)
841 struct hal_ev_ssp_request *ev = (struct hal_ev_ssp_request *)buf;
846 memcpy(bd_addr.address, ev->bdaddr, 6);
847 memcpy(bd_name.name, ev->name, 248);
850 DBG("[0x%x]", bd_addr.address[0]);
851 DBG("[0x%x]", bd_addr.address[1]);
852 DBG("[0x%x]", bd_addr.address[2]);
853 DBG("[0x%x]", bd_addr.address[3]);
854 DBG("[0x%x]", bd_addr.address[4]);
855 DBG("[0x%x]", bd_addr.address[5]);
857 DBG("COD [%d]", ev->class_of_dev);
858 DBG("pairing variant [%d]", ev->pairing_variant);
859 DBG("passkey [%d]", ev->passkey);
861 if (!bt_hal_cbacks->ssp_request_cb) {
862 ERR("HAL User ssp_request_cb is not set!!");
866 bt_hal_cbacks->ssp_request_cb(&bd_addr, &bd_name,
868 ev->pairing_variant, ev->passkey);
872 static void __bt_hal_handle_pin_request_event(void *buf, uint16_t len)
874 struct hal_ev_pin_request *ev = (struct hal_ev_pin_request *)buf;
879 memcpy(bd_addr.address, ev->bdaddr, 6);
880 memcpy(bd_name.name, ev->name, 248);
883 DBG("[0x%x]", bd_addr.address[0]);
884 DBG("[0x%x]", bd_addr.address[1]);
885 DBG("[0x%x]", bd_addr.address[2]);
886 DBG("[0x%x]", bd_addr.address[3]);
887 DBG("[0x%x]", bd_addr.address[4]);
888 DBG("[0x%x]", bd_addr.address[5]);
890 DBG("COD [%u]", ev->class_of_dev);
892 if (!bt_hal_cbacks->pin_request_cb) {
893 ERR("HAL User pin_request_cb is not set!!");
897 bt_hal_cbacks->pin_request_cb(&bd_addr, &bd_name,
902 static void __bt_hal_handle_device_trust_state_changed_event(void *buf, uint16_t len)
904 struct hal_ev_device_trust_state_changed *ev = (struct hal_ev_device_trust_state_changed*)buf;
908 memcpy(bd_addr.address, ev->bdaddr, 6);
910 DBG("[0x%x]", bd_addr.address[0]);
911 DBG("[0x%x]", bd_addr.address[1]);
912 DBG("[0x%x]", bd_addr.address[2]);
913 DBG("[0x%x]", bd_addr.address[3]);
914 DBG("[0x%x]", bd_addr.address[4]);
915 DBG("[0x%x]", bd_addr.address[5]);
917 DBG("Device Trusted? [0x%x]", ev->trust);
919 if (!bt_hal_cbacks->device_trust_state_changed_cb) {
920 ERR("HAL User device_trust_state_changed_cb is not set!!");
924 bt_hal_cbacks->device_trust_state_changed_cb(&bd_addr, ev->trust);
928 static void __bt_hal_handle_device_trusted_profiles_changed_event(void *buf, uint16_t len)
930 struct hal_ev_device_trusted_profiles_changed *ev = buf;
935 memcpy(bd_addr.address, ev->bdaddr, 6);
936 DBG("[0x%02X:%02X:%02X:%02X:%02X:%02X]",
937 bd_addr.address[0], bd_addr.address[1],
938 bd_addr.address[2], bd_addr.address[3],
939 bd_addr.address[4], bd_addr.address[5]);
941 if (!bt_hal_cbacks->device_trusted_profiles_changed_cb) {
942 ERR("device_trusted_profiles_changed_cb is NULL");
946 bt_hal_cbacks->device_trusted_profiles_changed_cb(&bd_addr, ev->trust_val);
951 static void __bt_handle_rssi_monitor_state_changed(void *buf, uint16_t len)
953 struct hal_ev_rssi_monitor_state_changed *ev = buf;
958 memcpy(bd_addr.address, ev->bdaddr, 6);
959 DBG("[0x%02X:%02X:%02X:%02X:%02X:%02X]",
960 bd_addr.address[0], bd_addr.address[1],
961 bd_addr.address[2], bd_addr.address[3],
962 bd_addr.address[4], bd_addr.address[5]);
964 if (bt_hal_cbacks->rssi_monitor_state_changed_cb)
965 bt_hal_cbacks->rssi_monitor_state_changed_cb(
966 &bd_addr, ev->link_type, ev->state);
971 static void __bt_handle_rssi_alert_recieved(void *buf, uint16_t len)
973 struct hal_ev_rssi_alert_recieved *ev = buf;
978 memcpy(bd_addr.address, ev->bdaddr, 6);
979 DBG("[0x%02X:%02X:%02X:%02X:%02X:%02X]",
980 bd_addr.address[0], bd_addr.address[1],
981 bd_addr.address[2], bd_addr.address[3],
982 bd_addr.address[4], bd_addr.address[5]);
984 if (bt_hal_cbacks->rssi_alert_cb)
985 bt_hal_cbacks->rssi_alert_cb(
986 &bd_addr, ev->link_type, ev->alert_type, ev->rssi);
991 static void __bt_handle_raw_rssi_recieved(void *buf, uint16_t len)
993 struct hal_ev_raw_rssi_recieved *ev = buf;
998 memcpy(bd_addr.address, ev->bdaddr, 6);
999 DBG("[0x%02X:%02X:%02X:%02X:%02X:%02X]",
1000 bd_addr.address[0], bd_addr.address[1],
1001 bd_addr.address[2], bd_addr.address[3],
1002 bd_addr.address[4], bd_addr.address[5]);
1004 if (bt_hal_cbacks->raw_rssi_received_cb)
1005 bt_hal_cbacks->raw_rssi_received_cb(
1006 &bd_addr, ev->link_type, ev->rssi);
1011 static void __bt_hal_handle_stack_messages(int message, void *buf, uint16_t len)
1015 case HAL_EV_ADAPTER_STATE_CHANGED:
1016 DBG("Event: HAL_EV_ADAPTER_STATE_CHANGED");
1017 __bt_hal_handle_adapter_state_changed(buf, len);
1019 case HAL_EV_ADAPTER_PROPS_CHANGED:
1020 DBG("Event: HAL_EV_ADAPTER_PROPS_CHANGED");
1021 __bt_hal_handle_adapter_property_changed(buf, len);
1023 case HAL_EV_DISCOVERY_STATE_CHANGED:
1024 DBG("Event: HAL_EV_DISCOVERY_STATE_CHANGED");
1025 __bt_hal_handle_adapter_discovery_state_changed(buf, len);
1027 case HAL_EV_DEVICE_FOUND:
1028 DBG("Event: HAL_EV_DEVICE_FOUND");
1029 __bt_hal_handle_device_found_event(buf, len);
1031 case HAL_EV_REMOTE_DEVICE_PROPS:
1032 DBG("Event: HAL_EV_REMOTE_DEVICE_PROPS");
1033 __bt_hal_handle_remote_device_properties_event(buf, len);
1035 case HAL_EV_BOND_STATE_CHANGED:
1036 DBG("Event: HAL_EV_BOND_STATE_CHANGED:");
1037 __bt_hal_handle_bond_state_changed_event(buf, len);
1039 case HAL_EV_ACL_STATE_CHANGED:
1040 DBG("Event: HAL_ACL_STATE_CONNECTED or Disconnected");
1041 __bt_hal_handle_device_acl_state_changed_event(buf, len);
1043 case HAL_EV_LE_CONN_STATE_CHANGED:
1044 DBG("Event: HAL_LE_CONN_STATE_CONNECTED or Disconnected");
1045 __bt_hal_handle_device_le_conn_state_changed_event(buf, len);
1047 case HAL_EV_SSP_REQUEST:
1048 DBG("Event: HAL_EV_SSP_REQUEST");
1049 __bt_hal_handle_ssp_request_event(buf, len);
1051 case HAL_EV_PIN_REQUEST:
1052 DBG("Event: HAL_EV_PIN_REQUEST");
1053 __bt_hal_handle_pin_request_event(buf, len);
1055 case HAL_EV_AUTHORIZE_REQUEST:
1056 DBG("Event: HAL_EV_AUTHORIZE_REQUEST");
1057 __bt_hal_handle_authorize_request_event(buf, len);
1059 case HAL_EV_DEVICE_TRUST_CHANGED:
1060 DBG("Event: HAL_EV_DEVICE_TRUST_CHANGED");
1061 __bt_hal_handle_device_trust_state_changed_event(buf, len);
1064 case HAL_EV_SOCK_AUTHORIZE_REQUEST:
1065 DBG("Event: HAL_EV_AUTHORIZE_REQUEST");
1066 __bt_hal_handle_socket_authorize_request_event(buf, len);
1068 case HAL_EV_LE_STATE_CHANGED:
1069 DBG("Event: HAL_EV_LE_STATE_CHANGED");
1070 __bt_hal_handle_le_state_changed(buf, len);
1073 case HAL_EV_DEVICE_TRUSTED_PROFILES_CHANGED:
1074 DBG("Event: HAL_EV_DEVICE_TRUST_CHANGED");
1075 __bt_hal_handle_device_trusted_profiles_changed_event(buf, len);
1077 case HAL_EV_RSSI_MONITOR_STATE_CHANGED:
1078 DBG("Event: HAL_EV_RSSI_MONITOR_STATE_CHANGED");
1079 __bt_handle_rssi_monitor_state_changed(buf, len);
1081 case HAL_EV_RSSI_ALERT_RECIEVED:
1082 DBG("Event: HAL_EV_RSSI_ALERT_RECIEVED");
1083 __bt_handle_rssi_alert_recieved(buf, len);
1085 case HAL_EV_RAW_RSSI_RECIEVED:
1086 DBG("Event: HAL_EV_RAW_RSSI_RECIEVED");
1087 __bt_handle_raw_rssi_recieved(buf, len);
1090 DBG("Event Currently not handled!!");