summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--android/hal-bluetooth.c44
1 files changed, 27 insertions, 17 deletions
diff --git a/android/hal-bluetooth.c b/android/hal-bluetooth.c
index 65432a855..a01229a25 100644
--- a/android/hal-bluetooth.c
+++ b/android/hal-bluetooth.c
@@ -525,8 +525,9 @@ static int get_adapter_property(bt_property_type_t type)
static int set_adapter_property(const bt_property_t *property)
{
- char buf[sizeof(struct hal_cmd_set_adapter_prop) + property->len];
+ char buf[BLUEZ_HAL_MTU];
struct hal_cmd_set_adapter_prop *cmd = (void *) buf;
+ size_t len;
DBG("prop: %s", btproperty2str(property));
@@ -535,8 +536,10 @@ static int set_adapter_property(const bt_property_t *property)
adapter_prop_from_hal(property, &cmd->type, &cmd->len, cmd->val);
+ len = sizeof(*cmd) + cmd->len;
+
return hal_ipc_cmd(HAL_SERVICE_ID_BLUETOOTH, HAL_OP_SET_ADAPTER_PROP,
- sizeof(*cmd) + cmd->len, cmd, 0, NULL, NULL);
+ len, cmd, 0, NULL, NULL);
}
static int get_remote_device_properties(bt_bdaddr_t *remote_addr)
@@ -579,8 +582,9 @@ static int get_remote_device_property(bt_bdaddr_t *remote_addr,
static int set_remote_device_property(bt_bdaddr_t *remote_addr,
const bt_property_t *property)
{
- struct hal_cmd_set_remote_device_prop *cmd;
- uint8_t buf[sizeof(*cmd) + property->len];
+ char buf[BLUEZ_HAL_MTU];
+ struct hal_cmd_set_remote_device_prop *cmd = (void *) buf;
+ size_t len;
DBG("bdaddr: %s prop: %s", bdaddr2str(remote_addr),
bt_property_type_t2str(property->type));
@@ -588,8 +592,6 @@ static int set_remote_device_property(bt_bdaddr_t *remote_addr,
if (!interface_ready())
return BT_STATUS_NOT_READY;
- cmd = (void *) buf;
-
memcpy(cmd->bdaddr, remote_addr, sizeof(cmd->bdaddr));
/* type match IPC type */
@@ -597,9 +599,11 @@ static int set_remote_device_property(bt_bdaddr_t *remote_addr,
cmd->len = property->len;
memcpy(cmd->val, property->val, property->len);
+ len = sizeof(*cmd) + cmd->len;
+
return hal_ipc_cmd(HAL_SERVICE_ID_BLUETOOTH,
HAL_OP_SET_REMOTE_DEVICE_PROP,
- sizeof(buf), cmd, 0, NULL, NULL);
+ len, cmd, 0, NULL, NULL);
}
static int get_remote_service_record(bt_bdaddr_t *remote_addr, bt_uuid_t *uuid)
@@ -786,40 +790,46 @@ static int dut_mode_configure(uint8_t enable)
sizeof(cmd), &cmd, 0, NULL, NULL);
}
-static int dut_mode_send(uint16_t opcode, uint8_t *buf, uint8_t len)
+static int dut_mode_send(uint16_t opcode, uint8_t *buf, uint8_t buf_len)
{
- uint8_t cmd_buf[sizeof(struct hal_cmd_dut_mode_send) + len];
+ char cmd_buf[BLUEZ_HAL_MTU];
struct hal_cmd_dut_mode_send *cmd = (void *) cmd_buf;
+ size_t len;
- DBG("opcode %u len %u", opcode, len);
+ DBG("opcode %u len %u", opcode, buf_len);
if (!interface_ready())
return BT_STATUS_NOT_READY;
cmd->opcode = opcode;
- cmd->len = len;
+ cmd->len = buf_len;
memcpy(cmd->data, buf, cmd->len);
+ len = sizeof(*cmd) + cmd->len;
+
return hal_ipc_cmd(HAL_SERVICE_ID_BLUETOOTH, HAL_OP_DUT_MODE_SEND,
- sizeof(cmd_buf), cmd, 0, NULL, NULL);
+ len, cmd, 0, NULL, NULL);
}
-static int le_test_mode(uint16_t opcode, uint8_t *buf, uint8_t len)
+static int le_test_mode(uint16_t opcode, uint8_t *buf, uint8_t buf_len)
{
- uint8_t cmd_buf[sizeof(struct hal_cmd_le_test_mode) + len];
+ char cmd_buf[BLUEZ_HAL_MTU];
struct hal_cmd_le_test_mode *cmd = (void *) cmd_buf;
+ size_t len;
- DBG("opcode %u len %u", opcode, len);
+ DBG("opcode %u len %u", opcode, buf_len);
if (!interface_ready())
return BT_STATUS_NOT_READY;
cmd->opcode = opcode;
- cmd->len = len;
+ cmd->len = buf_len;
memcpy(cmd->data, buf, cmd->len);
+ len = sizeof(*cmd) + cmd->len;
+
return hal_ipc_cmd(HAL_SERVICE_ID_BLUETOOTH, HAL_OP_LE_TEST_MODE,
- sizeof(cmd_buf), cmd, 0, NULL, NULL);
+ len, cmd, 0, NULL, NULL);
}
static int config_hci_snoop_log(uint8_t enable)