This patch adds possibility to start BlueZ in LE or BR/EDR mode when having dual mode chip below. --- android/README | 4 ++++ android/bluetooth.c | 16 +++++++++++++++- android/hal-bluetooth.c | 19 ++++++++++++++++++- android/hal-msg.h | 2 ++ 4 files changed, 39 insertions(+), 2 deletions(-) diff --git a/android/README b/android/README index 6254d34..08c4413 100644 --- a/android/README +++ b/android/README @@ -166,6 +166,10 @@ options. Property Value Description ------------------------------------------- +mode bredr Enable BlueZ in BR/EDR mode + le Enable BlueZ in LE mode + <none> Enable BlueZ in default mode - enable BR/EDR/LE + if available. handsfree hfp Enable Handsfree Profile (HFP) with narrowband speech only hfp_wbs Enable Handsfree Profile (HFP) with narrowband diff --git a/android/bluetooth.c b/android/bluetooth.c index 93c7935..671b25b 100644 --- a/android/bluetooth.c +++ b/android/bluetooth.c @@ -3894,10 +3894,24 @@ static const struct ipc_handler cmd_handlers[] = { void bt_bluetooth_register(struct ipc *ipc, uint8_t mode) { - DBG(""); + DBG("mode 0x%x", mode); hal_ipc = ipc; + if (mode == HAL_MODE_DEFAULT) + goto done; + + if (settings2type() != HAL_TYPE_DUAL) { + info("Single mode chip already"); + goto done; + } + + if (mode == HAL_MODE_LE) + set_mode(MGMT_OP_SET_BREDR, 0x00); + else + set_mode(MGMT_OP_SET_LE, 0x00); + +done: ipc_register(hal_ipc, HAL_SERVICE_ID_BLUETOOTH, cmd_handlers, G_N_ELEMENTS(cmd_handlers)); } diff --git a/android/hal-bluetooth.c b/android/hal-bluetooth.c index 48d5ea2..1fa10e0 100644 --- a/android/hal-bluetooth.c +++ b/android/hal-bluetooth.c @@ -29,6 +29,8 @@ #include "hal-ipc.h" #include "hal-utils.h" +#define MODE_PROPERTY_NAME "persist.sys.bluetooth.mode" + static const bt_callbacks_t *bt_hal_cbacks = NULL; #define enum_prop_to_hal(prop, hal_prop, type) do { \ @@ -412,6 +414,21 @@ static const struct hal_ipc_handler ev_handlers[] = { } }; +static uint8_t get_mode(void) +{ + char value[PROPERTY_VALUE_MAX]; + + if (property_get(MODE_PROPERTY_NAME, value, "") > 0 && + (!strcasecmp(value, "bredr"))) + return HAL_MODE_BREDR; + + if (property_get(MODE_PROPERTY_NAME, value, "") > 0 && + (!strcasecmp(value, "le"))) + return HAL_MODE_LE; + + return HAL_MODE_DEFAULT; +} + static int init(bt_callbacks_t *callbacks) { struct hal_cmd_register_module cmd; @@ -433,7 +450,7 @@ static int init(bt_callbacks_t *callbacks) } cmd.service_id = HAL_SERVICE_ID_BLUETOOTH; - cmd.mode = HAL_MODE_DEFAULT; + cmd.mode = get_mode(); status = hal_ipc_cmd(HAL_SERVICE_ID_CORE, HAL_OP_REGISTER_MODULE, sizeof(cmd), &cmd, NULL, NULL, NULL); diff --git a/android/hal-msg.h b/android/hal-msg.h index ed0a67a..ee708cb 100644 --- a/android/hal-msg.h +++ b/android/hal-msg.h @@ -55,6 +55,8 @@ static const char BLUEZ_HAL_SK_PATH[] = "\0bluez_hal_socket"; #define HAL_OP_STATUS IPC_OP_STATUS #define HAL_MODE_DEFAULT 0x00 +#define HAL_MODE_BREDR 0x01 +#define HAL_MODE_LE 0x02 #define HAL_OP_REGISTER_MODULE 0x01 struct hal_cmd_register_module { -- 1.8.4 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html