aboutsummaryrefslogtreecommitdiffstats
path: root/net/bluetooth/mgmt.c
diff options
context:
space:
mode:
authorJohan Hedberg <johan.hedberg@intel.com>2014-05-29 12:36:53 -0400
committerMarcel Holtmann <marcel@holtmann.org>2014-05-31 00:23:29 -0400
commit61b433579b6ffecb1d3534fd482dcd48535277c8 (patch)
tree5ce7ede7192da000d2ef9d747a1c656b022d121f /net/bluetooth/mgmt.c
parent3abb56de8750675a2d70705687254c9e653ffd4c (diff)
Bluetooth: Fix properly ignoring LTKs of unknown types
In case there are new LTK types in the future we shouldn't just blindly assume that != MGMT_LTK_UNAUTHENTICATED means that the key is authenticated. This patch adds explicit checks for each allowed key type in the form of a switch statement and skips any key which has an unknown value. Signed-off-by: Johan Hedberg <johan.hedberg@intel.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org> Cc: stable@vger.kernel.org
Diffstat (limited to 'net/bluetooth/mgmt.c')
-rw-r--r--net/bluetooth/mgmt.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c
index 5e9c21a5525f..0fce54412ffd 100644
--- a/net/bluetooth/mgmt.c
+++ b/net/bluetooth/mgmt.c
@@ -4546,10 +4546,16 @@ static int load_long_term_keys(struct sock *sk, struct hci_dev *hdev,
4546 else 4546 else
4547 type = HCI_SMP_LTK_SLAVE; 4547 type = HCI_SMP_LTK_SLAVE;
4548 4548
4549 if (key->type == MGMT_LTK_UNAUTHENTICATED) 4549 switch (key->type) {
4550 case MGMT_LTK_UNAUTHENTICATED:
4550 authenticated = 0x00; 4551 authenticated = 0x00;
4551 else 4552 break;
4553 case MGMT_LTK_AUTHENTICATED:
4552 authenticated = 0x01; 4554 authenticated = 0x01;
4555 break;
4556 default:
4557 continue;
4558 }
4553 4559
4554 hci_add_ltk(hdev, &key->addr.bdaddr, addr_type, type, 4560 hci_add_ltk(hdev, &key->addr.bdaddr, addr_type, type,
4555 authenticated, key->val, key->enc_size, key->ediv, 4561 authenticated, key->val, key->enc_size, key->ediv,