Bluetooth: Fix checking for exact values of boolean mgmt parameters
All mgmt_set_* commands that take a boolean value encoded in the form of a byte should only accept the values 0x00 and 0x01. This patch adds the necessary checks for this and returns "invalid params" responses if anything else is provided as the value. Signed-off-by: Johan Hedberg <johan.hedberg@intel.com> Acked-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
This commit is contained in:
Родитель
13ecd8b662
Коммит
a7e80f25ae
|
@ -777,6 +777,10 @@ static int set_powered(struct sock *sk, struct hci_dev *hdev, void *data,
|
||||||
|
|
||||||
BT_DBG("request for %s", hdev->name);
|
BT_DBG("request for %s", hdev->name);
|
||||||
|
|
||||||
|
if (cp->val != 0x00 && cp->val != 0x01)
|
||||||
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_POWERED,
|
||||||
|
MGMT_STATUS_INVALID_PARAMS);
|
||||||
|
|
||||||
hci_dev_lock(hdev);
|
hci_dev_lock(hdev);
|
||||||
|
|
||||||
if (test_and_clear_bit(HCI_AUTO_OFF, &hdev->dev_flags)) {
|
if (test_and_clear_bit(HCI_AUTO_OFF, &hdev->dev_flags)) {
|
||||||
|
@ -872,6 +876,10 @@ static int set_discoverable(struct sock *sk, struct hci_dev *hdev, void *data,
|
||||||
return cmd_status(sk, hdev->id, MGMT_OP_SET_DISCOVERABLE,
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_DISCOVERABLE,
|
||||||
MGMT_STATUS_NOT_SUPPORTED);
|
MGMT_STATUS_NOT_SUPPORTED);
|
||||||
|
|
||||||
|
if (cp->val != 0x00 && cp->val != 0x01)
|
||||||
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_DISCOVERABLE,
|
||||||
|
MGMT_STATUS_INVALID_PARAMS);
|
||||||
|
|
||||||
timeout = __le16_to_cpu(cp->timeout);
|
timeout = __le16_to_cpu(cp->timeout);
|
||||||
if (!cp->val && timeout > 0)
|
if (!cp->val && timeout > 0)
|
||||||
return cmd_status(sk, hdev->id, MGMT_OP_SET_DISCOVERABLE,
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_DISCOVERABLE,
|
||||||
|
@ -971,6 +979,10 @@ static int set_connectable(struct sock *sk, struct hci_dev *hdev, void *data,
|
||||||
return cmd_status(sk, hdev->id, MGMT_OP_SET_CONNECTABLE,
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_CONNECTABLE,
|
||||||
MGMT_STATUS_NOT_SUPPORTED);
|
MGMT_STATUS_NOT_SUPPORTED);
|
||||||
|
|
||||||
|
if (cp->val != 0x00 && cp->val != 0x01)
|
||||||
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_CONNECTABLE,
|
||||||
|
MGMT_STATUS_INVALID_PARAMS);
|
||||||
|
|
||||||
hci_dev_lock(hdev);
|
hci_dev_lock(hdev);
|
||||||
|
|
||||||
if (!hdev_is_powered(hdev)) {
|
if (!hdev_is_powered(hdev)) {
|
||||||
|
@ -1041,6 +1053,10 @@ static int set_pairable(struct sock *sk, struct hci_dev *hdev, void *data,
|
||||||
|
|
||||||
BT_DBG("request for %s", hdev->name);
|
BT_DBG("request for %s", hdev->name);
|
||||||
|
|
||||||
|
if (cp->val != 0x00 && cp->val != 0x01)
|
||||||
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_PAIRABLE,
|
||||||
|
MGMT_STATUS_INVALID_PARAMS);
|
||||||
|
|
||||||
hci_dev_lock(hdev);
|
hci_dev_lock(hdev);
|
||||||
|
|
||||||
if (cp->val)
|
if (cp->val)
|
||||||
|
@ -1073,6 +1089,10 @@ static int set_link_security(struct sock *sk, struct hci_dev *hdev, void *data,
|
||||||
return cmd_status(sk, hdev->id, MGMT_OP_SET_LINK_SECURITY,
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_LINK_SECURITY,
|
||||||
MGMT_STATUS_NOT_SUPPORTED);
|
MGMT_STATUS_NOT_SUPPORTED);
|
||||||
|
|
||||||
|
if (cp->val != 0x00 && cp->val != 0x01)
|
||||||
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_LINK_SECURITY,
|
||||||
|
MGMT_STATUS_INVALID_PARAMS);
|
||||||
|
|
||||||
hci_dev_lock(hdev);
|
hci_dev_lock(hdev);
|
||||||
|
|
||||||
if (!hdev_is_powered(hdev)) {
|
if (!hdev_is_powered(hdev)) {
|
||||||
|
@ -1137,6 +1157,10 @@ static int set_ssp(struct sock *sk, struct hci_dev *hdev, void *data, u16 len)
|
||||||
return cmd_status(sk, hdev->id, MGMT_OP_SET_SSP,
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_SSP,
|
||||||
MGMT_STATUS_NOT_SUPPORTED);
|
MGMT_STATUS_NOT_SUPPORTED);
|
||||||
|
|
||||||
|
if (cp->val != 0x00 && cp->val != 0x01)
|
||||||
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_SSP,
|
||||||
|
MGMT_STATUS_INVALID_PARAMS);
|
||||||
|
|
||||||
hci_dev_lock(hdev);
|
hci_dev_lock(hdev);
|
||||||
|
|
||||||
val = !!cp->val;
|
val = !!cp->val;
|
||||||
|
@ -1197,6 +1221,10 @@ static int set_hs(struct sock *sk, struct hci_dev *hdev, void *data, u16 len)
|
||||||
return cmd_status(sk, hdev->id, MGMT_OP_SET_HS,
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_HS,
|
||||||
MGMT_STATUS_NOT_SUPPORTED);
|
MGMT_STATUS_NOT_SUPPORTED);
|
||||||
|
|
||||||
|
if (cp->val != 0x00 && cp->val != 0x01)
|
||||||
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_HS,
|
||||||
|
MGMT_STATUS_INVALID_PARAMS);
|
||||||
|
|
||||||
if (cp->val)
|
if (cp->val)
|
||||||
set_bit(HCI_HS_ENABLED, &hdev->dev_flags);
|
set_bit(HCI_HS_ENABLED, &hdev->dev_flags);
|
||||||
else
|
else
|
||||||
|
@ -1219,6 +1247,10 @@ static int set_le(struct sock *sk, struct hci_dev *hdev, void *data, u16 len)
|
||||||
return cmd_status(sk, hdev->id, MGMT_OP_SET_LE,
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_LE,
|
||||||
MGMT_STATUS_NOT_SUPPORTED);
|
MGMT_STATUS_NOT_SUPPORTED);
|
||||||
|
|
||||||
|
if (cp->val != 0x00 && cp->val != 0x01)
|
||||||
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_LE,
|
||||||
|
MGMT_STATUS_INVALID_PARAMS);
|
||||||
|
|
||||||
hci_dev_lock(hdev);
|
hci_dev_lock(hdev);
|
||||||
|
|
||||||
val = !!cp->val;
|
val = !!cp->val;
|
||||||
|
@ -2598,6 +2630,10 @@ static int set_fast_connectable(struct sock *sk, struct hci_dev *hdev,
|
||||||
return cmd_status(sk, hdev->id, MGMT_OP_SET_FAST_CONNECTABLE,
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_FAST_CONNECTABLE,
|
||||||
MGMT_STATUS_NOT_SUPPORTED);
|
MGMT_STATUS_NOT_SUPPORTED);
|
||||||
|
|
||||||
|
if (cp->val != 0x00 && cp->val != 0x01)
|
||||||
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_FAST_CONNECTABLE,
|
||||||
|
MGMT_STATUS_INVALID_PARAMS);
|
||||||
|
|
||||||
if (!hdev_is_powered(hdev))
|
if (!hdev_is_powered(hdev))
|
||||||
return cmd_status(sk, hdev->id, MGMT_OP_SET_FAST_CONNECTABLE,
|
return cmd_status(sk, hdev->id, MGMT_OP_SET_FAST_CONNECTABLE,
|
||||||
MGMT_STATUS_NOT_POWERED);
|
MGMT_STATUS_NOT_POWERED);
|
||||||
|
|
Загрузка…
Ссылка в новой задаче