Commit 2f2eb0c9 authored by Brian Gix's avatar Brian Gix Committed by Marcel Holtmann

Bluetooth: hci_sync: Convert MGMT_OP_SET_SECURE_CONN

Synchronous version of MGMT_OP_SET_SECURE_CONN.
Signed-off-by: default avatarBrian Gix <brian.gix@intel.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent 47db6b42
...@@ -69,6 +69,7 @@ int hci_update_passive_scan_sync(struct hci_dev *hdev); ...@@ -69,6 +69,7 @@ int hci_update_passive_scan_sync(struct hci_dev *hdev);
int hci_update_passive_scan(struct hci_dev *hdev); int hci_update_passive_scan(struct hci_dev *hdev);
int hci_read_rssi_sync(struct hci_dev *hdev, __le16 handle); int hci_read_rssi_sync(struct hci_dev *hdev, __le16 handle);
int hci_read_tx_power_sync(struct hci_dev *hdev, __le16 handle, u8 type); int hci_read_tx_power_sync(struct hci_dev *hdev, __le16 handle, u8 type);
int hci_write_sc_support_sync(struct hci_dev *hdev, u8 val);
int hci_write_fast_connectable_sync(struct hci_dev *hdev, bool enable); int hci_write_fast_connectable_sync(struct hci_dev *hdev, bool enable);
int hci_update_scan_sync(struct hci_dev *hdev); int hci_update_scan_sync(struct hci_dev *hdev);
......
...@@ -2104,13 +2104,27 @@ int hci_update_passive_scan(struct hci_dev *hdev) ...@@ -2104,13 +2104,27 @@ int hci_update_passive_scan(struct hci_dev *hdev)
return hci_cmd_sync_queue(hdev, update_passive_scan_sync, NULL, NULL); return hci_cmd_sync_queue(hdev, update_passive_scan_sync, NULL, NULL);
} }
static int hci_write_sc_support_sync(struct hci_dev *hdev, u8 val) int hci_write_sc_support_sync(struct hci_dev *hdev, u8 val)
{ {
int err;
if (!bredr_sc_enabled(hdev) || lmp_host_sc_capable(hdev)) if (!bredr_sc_enabled(hdev) || lmp_host_sc_capable(hdev))
return 0; return 0;
return __hci_cmd_sync_status(hdev, HCI_OP_WRITE_SC_SUPPORT, err = __hci_cmd_sync_status(hdev, HCI_OP_WRITE_SC_SUPPORT,
sizeof(val), &val, HCI_CMD_TIMEOUT); sizeof(val), &val, HCI_CMD_TIMEOUT);
if (!err) {
if (val) {
hdev->features[1][0] |= LMP_HOST_SC;
hci_dev_set_flag(hdev, HCI_SC_ENABLED);
} else {
hdev->features[1][0] &= ~LMP_HOST_SC;
hci_dev_clear_flag(hdev, HCI_SC_ENABLED);
}
}
return err;
} }
static int hci_write_ssp_mode_sync(struct hci_dev *hdev, u8 mode) static int hci_write_ssp_mode_sync(struct hci_dev *hdev, u8 mode)
......
...@@ -6094,23 +6094,18 @@ static int set_bredr(struct sock *sk, struct hci_dev *hdev, void *data, u16 len) ...@@ -6094,23 +6094,18 @@ static int set_bredr(struct sock *sk, struct hci_dev *hdev, void *data, u16 len)
return err; return err;
} }
static void sc_enable_complete(struct hci_dev *hdev, u8 status, u16 opcode) static void set_secure_conn_complete(struct hci_dev *hdev, void *data, int err)
{ {
struct mgmt_pending_cmd *cmd; struct mgmt_pending_cmd *cmd = data;
struct mgmt_mode *cp; struct mgmt_mode *cp;
bt_dev_dbg(hdev, "status %u", status); bt_dev_dbg(hdev, "err %d", err);
hci_dev_lock(hdev);
cmd = pending_find(MGMT_OP_SET_SECURE_CONN, hdev); if (err) {
if (!cmd) u8 mgmt_err = mgmt_status(err);
goto unlock;
if (status) { mgmt_cmd_status(cmd->sk, cmd->index, cmd->opcode, mgmt_err);
mgmt_cmd_status(cmd->sk, cmd->index, cmd->opcode, goto done;
mgmt_status(status));
goto remove;
} }
cp = cmd->param; cp = cmd->param;
...@@ -6130,13 +6125,23 @@ static void sc_enable_complete(struct hci_dev *hdev, u8 status, u16 opcode) ...@@ -6130,13 +6125,23 @@ static void sc_enable_complete(struct hci_dev *hdev, u8 status, u16 opcode)
break; break;
} }
send_settings_rsp(cmd->sk, MGMT_OP_SET_SECURE_CONN, hdev); send_settings_rsp(cmd->sk, cmd->opcode, hdev);
new_settings(hdev, cmd->sk); new_settings(hdev, cmd->sk);
remove: done:
mgmt_pending_remove(cmd); mgmt_pending_free(cmd);
unlock: }
hci_dev_unlock(hdev);
static int set_secure_conn_sync(struct hci_dev *hdev, void *data)
{
struct mgmt_pending_cmd *cmd = data;
struct mgmt_mode *cp = cmd->param;
u8 val = !!cp->val;
/* Force write of val */
hci_dev_set_flag(hdev, HCI_SC_ENABLED);
return hci_write_sc_support_sync(hdev, val);
} }
static int set_secure_conn(struct sock *sk, struct hci_dev *hdev, static int set_secure_conn(struct sock *sk, struct hci_dev *hdev,
...@@ -6144,7 +6149,6 @@ static int set_secure_conn(struct sock *sk, struct hci_dev *hdev, ...@@ -6144,7 +6149,6 @@ static int set_secure_conn(struct sock *sk, struct hci_dev *hdev,
{ {
struct mgmt_mode *cp = data; struct mgmt_mode *cp = data;
struct mgmt_pending_cmd *cmd; struct mgmt_pending_cmd *cmd;
struct hci_request req;
u8 val; u8 val;
int err; int err;
...@@ -6163,7 +6167,7 @@ static int set_secure_conn(struct sock *sk, struct hci_dev *hdev, ...@@ -6163,7 +6167,7 @@ static int set_secure_conn(struct sock *sk, struct hci_dev *hdev,
if (cp->val != 0x00 && cp->val != 0x01 && cp->val != 0x02) if (cp->val != 0x00 && cp->val != 0x01 && cp->val != 0x02)
return mgmt_cmd_status(sk, hdev->id, MGMT_OP_SET_SECURE_CONN, return mgmt_cmd_status(sk, hdev->id, MGMT_OP_SET_SECURE_CONN,
MGMT_STATUS_INVALID_PARAMS); MGMT_STATUS_INVALID_PARAMS);
hci_dev_lock(hdev); hci_dev_lock(hdev);
...@@ -6194,12 +6198,6 @@ static int set_secure_conn(struct sock *sk, struct hci_dev *hdev, ...@@ -6194,12 +6198,6 @@ static int set_secure_conn(struct sock *sk, struct hci_dev *hdev,
goto failed; goto failed;
} }
if (pending_find(MGMT_OP_SET_SECURE_CONN, hdev)) {
err = mgmt_cmd_status(sk, hdev->id, MGMT_OP_SET_SECURE_CONN,
MGMT_STATUS_BUSY);
goto failed;
}
val = !!cp->val; val = !!cp->val;
if (val == hci_dev_test_flag(hdev, HCI_SC_ENABLED) && if (val == hci_dev_test_flag(hdev, HCI_SC_ENABLED) &&
...@@ -6208,18 +6206,18 @@ static int set_secure_conn(struct sock *sk, struct hci_dev *hdev, ...@@ -6208,18 +6206,18 @@ static int set_secure_conn(struct sock *sk, struct hci_dev *hdev,
goto failed; goto failed;
} }
cmd = mgmt_pending_add(sk, MGMT_OP_SET_SECURE_CONN, hdev, data, len); cmd = mgmt_pending_new(sk, MGMT_OP_SET_SECURE_CONN, hdev, data, len);
if (!cmd) { if (!cmd)
err = -ENOMEM; err = -ENOMEM;
goto failed; else
} err = hci_cmd_sync_queue(hdev, set_secure_conn_sync, cmd,
set_secure_conn_complete);
hci_req_init(&req, hdev);
hci_req_add(&req, HCI_OP_WRITE_SC_SUPPORT, 1, &val);
err = hci_req_run(&req, sc_enable_complete);
if (err < 0) { if (err < 0) {
mgmt_pending_remove(cmd); mgmt_cmd_status(sk, hdev->id, MGMT_OP_SET_SECURE_CONN,
goto failed; MGMT_STATUS_FAILED);
if (cmd)
mgmt_pending_free(cmd);
} }
failed: failed:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment