diff options
author | Waldemar Rymarkiewicz <waldemar.rymarkiewicz@tieto.com> | 2011-04-28 06:07:53 -0400 |
---|---|---|
committer | Gustavo F. Padovan <padovan@profusion.mobi> | 2011-04-28 14:02:04 -0400 |
commit | b6020ba055c7f1ca901dc8751ecc7c9de58164db (patch) | |
tree | 340b7ce9c901125eaf7303b15c7ca17232fc001b | |
parent | 314b2381a79c6bfe3ddc4ba3806ecb6aec27a3db (diff) |
Bluetooth: Add definitions for link key types
Introduce the link key types defs and use them instead of magic numbers.
Signed-off-by: Waldemar Rymarkiewicz <waldemar.rymarkiewicz@tieto.com>
Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
-rw-r--r-- | include/net/bluetooth/hci.h | 9 | ||||
-rw-r--r-- | net/bluetooth/hci_core.c | 2 | ||||
-rw-r--r-- | net/bluetooth/hci_event.c | 7 |
3 files changed, 14 insertions, 4 deletions
diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h index 6138e313d175..e0a3cf1234b2 100644 --- a/include/net/bluetooth/hci.h +++ b/include/net/bluetooth/hci.h | |||
@@ -246,6 +246,15 @@ enum { | |||
246 | #define HCI_AT_GENERAL_BONDING 0x04 | 246 | #define HCI_AT_GENERAL_BONDING 0x04 |
247 | #define HCI_AT_GENERAL_BONDING_MITM 0x05 | 247 | #define HCI_AT_GENERAL_BONDING_MITM 0x05 |
248 | 248 | ||
249 | /* Link Key types */ | ||
250 | #define HCI_LK_COMBINATION 0x00 | ||
251 | #define HCI_LK_LOCAL_UNIT 0x01 | ||
252 | #define HCI_LK_REMOTE_UNIT 0x02 | ||
253 | #define HCI_LK_DEBUG_COMBINATION 0x03 | ||
254 | #define HCI_LK_UNAUTH_COMBINATION 0x04 | ||
255 | #define HCI_LK_AUTH_COMBINATION 0x05 | ||
256 | #define HCI_LK_CHANGED_COMBINATION 0x06 | ||
257 | |||
249 | /* ----- HCI Commands ---- */ | 258 | /* ----- HCI Commands ---- */ |
250 | #define HCI_OP_NOP 0x0000 | 259 | #define HCI_OP_NOP 0x0000 |
251 | 260 | ||
diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c index 98aa24b92c58..07d0ba35b9a5 100644 --- a/net/bluetooth/hci_core.c +++ b/net/bluetooth/hci_core.c | |||
@@ -1050,7 +1050,7 @@ int hci_add_link_key(struct hci_dev *hdev, int new_key, bdaddr_t *bdaddr, | |||
1050 | if (new_key) | 1050 | if (new_key) |
1051 | mgmt_new_key(hdev->id, key, old_key_type); | 1051 | mgmt_new_key(hdev->id, key, old_key_type); |
1052 | 1052 | ||
1053 | if (type == 0x06) | 1053 | if (type == HCI_LK_CHANGED_COMBINATION) |
1054 | key->type = old_key_type; | 1054 | key->type = old_key_type; |
1055 | 1055 | ||
1056 | return 0; | 1056 | return 0; |
diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c index e64a3de70d77..fbbb63f8a897 100644 --- a/net/bluetooth/hci_event.c +++ b/net/bluetooth/hci_event.c | |||
@@ -2053,15 +2053,16 @@ static inline void hci_link_key_request_evt(struct hci_dev *hdev, struct sk_buff | |||
2053 | BT_DBG("%s found key type %u for %s", hdev->name, key->type, | 2053 | BT_DBG("%s found key type %u for %s", hdev->name, key->type, |
2054 | batostr(&ev->bdaddr)); | 2054 | batostr(&ev->bdaddr)); |
2055 | 2055 | ||
2056 | if (!test_bit(HCI_DEBUG_KEYS, &hdev->flags) && key->type == 0x03) { | 2056 | if (!test_bit(HCI_DEBUG_KEYS, &hdev->flags) && |
2057 | key->type == HCI_LK_DEBUG_COMBINATION) { | ||
2057 | BT_DBG("%s ignoring debug key", hdev->name); | 2058 | BT_DBG("%s ignoring debug key", hdev->name); |
2058 | goto not_found; | 2059 | goto not_found; |
2059 | } | 2060 | } |
2060 | 2061 | ||
2061 | conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); | 2062 | conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); |
2062 | 2063 | ||
2063 | if (key->type == 0x04 && conn && conn->auth_type != 0xff && | 2064 | if (key->type == HCI_LK_UNAUTH_COMBINATION && conn && |
2064 | (conn->auth_type & 0x01)) { | 2065 | conn->auth_type != 0xff && (conn->auth_type & 0x01)) { |
2065 | BT_DBG("%s ignoring unauthenticated key", hdev->name); | 2066 | BT_DBG("%s ignoring unauthenticated key", hdev->name); |
2066 | goto not_found; | 2067 | goto not_found; |
2067 | } | 2068 | } |