aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
Diffstat (limited to 'net')
-rw-r--r--net/bluetooth/hci_conn.c20
-rw-r--r--net/bluetooth/hci_event.c36
-rw-r--r--net/bluetooth/l2cap_core.c2
-rw-r--r--net/bluetooth/smp.c19
4 files changed, 38 insertions, 39 deletions
diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c
index 3db432473ad5..8a4678a2c982 100644
--- a/net/bluetooth/hci_conn.c
+++ b/net/bluetooth/hci_conn.c
@@ -337,7 +337,7 @@ static void hci_conn_enter_sniff_mode(struct hci_conn *conn)
337 hci_send_cmd(hdev, HCI_OP_SNIFF_SUBRATE, sizeof(cp), &cp); 337 hci_send_cmd(hdev, HCI_OP_SNIFF_SUBRATE, sizeof(cp), &cp);
338 } 338 }
339 339
340 if (!test_and_set_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->pend)) { 340 if (!test_and_set_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->flags)) {
341 struct hci_cp_sniff_mode cp; 341 struct hci_cp_sniff_mode cp;
342 cp.handle = cpu_to_le16(conn->handle); 342 cp.handle = cpu_to_le16(conn->handle);
343 cp.max_interval = cpu_to_le16(hdev->sniff_max_interval); 343 cp.max_interval = cpu_to_le16(hdev->sniff_max_interval);
@@ -589,9 +589,9 @@ struct hci_conn *hci_connect(struct hci_dev *hdev, int type, bdaddr_t *dst, __u8
589 acl->power_save = 1; 589 acl->power_save = 1;
590 hci_conn_enter_active_mode(acl, BT_POWER_FORCE_ACTIVE_ON); 590 hci_conn_enter_active_mode(acl, BT_POWER_FORCE_ACTIVE_ON);
591 591
592 if (test_bit(HCI_CONN_MODE_CHANGE_PEND, &acl->pend)) { 592 if (test_bit(HCI_CONN_MODE_CHANGE_PEND, &acl->flags)) {
593 /* defer SCO setup until mode change completed */ 593 /* defer SCO setup until mode change completed */
594 set_bit(HCI_CONN_SCO_SETUP_PEND, &acl->pend); 594 set_bit(HCI_CONN_SCO_SETUP_PEND, &acl->flags);
595 return sco; 595 return sco;
596 } 596 }
597 597
@@ -633,13 +633,13 @@ static int hci_conn_auth(struct hci_conn *conn, __u8 sec_level, __u8 auth_type)
633 633
634 conn->auth_type = auth_type; 634 conn->auth_type = auth_type;
635 635
636 if (!test_and_set_bit(HCI_CONN_AUTH_PEND, &conn->pend)) { 636 if (!test_and_set_bit(HCI_CONN_AUTH_PEND, &conn->flags)) {
637 struct hci_cp_auth_requested cp; 637 struct hci_cp_auth_requested cp;
638 cp.handle = cpu_to_le16(conn->handle); 638 cp.handle = cpu_to_le16(conn->handle);
639 hci_send_cmd(conn->hdev, HCI_OP_AUTH_REQUESTED, 639 hci_send_cmd(conn->hdev, HCI_OP_AUTH_REQUESTED,
640 sizeof(cp), &cp); 640 sizeof(cp), &cp);
641 if (conn->key_type != 0xff) 641 if (conn->key_type != 0xff)
642 set_bit(HCI_CONN_REAUTH_PEND, &conn->pend); 642 set_bit(HCI_CONN_REAUTH_PEND, &conn->flags);
643 } 643 }
644 644
645 return 0; 645 return 0;
@@ -650,7 +650,7 @@ static void hci_conn_encrypt(struct hci_conn *conn)
650{ 650{
651 BT_DBG("conn %p", conn); 651 BT_DBG("conn %p", conn);
652 652
653 if (!test_and_set_bit(HCI_CONN_ENCRYPT_PEND, &conn->pend)) { 653 if (!test_and_set_bit(HCI_CONN_ENCRYPT_PEND, &conn->flags)) {
654 struct hci_cp_set_conn_encrypt cp; 654 struct hci_cp_set_conn_encrypt cp;
655 cp.handle = cpu_to_le16(conn->handle); 655 cp.handle = cpu_to_le16(conn->handle);
656 cp.encrypt = 0x01; 656 cp.encrypt = 0x01;
@@ -700,7 +700,7 @@ int hci_conn_security(struct hci_conn *conn, __u8 sec_level, __u8 auth_type)
700 goto encrypt; 700 goto encrypt;
701 701
702auth: 702auth:
703 if (test_bit(HCI_CONN_ENCRYPT_PEND, &conn->pend)) 703 if (test_bit(HCI_CONN_ENCRYPT_PEND, &conn->flags))
704 return 0; 704 return 0;
705 705
706 if (!hci_conn_auth(conn, sec_level, auth_type)) 706 if (!hci_conn_auth(conn, sec_level, auth_type))
@@ -735,7 +735,7 @@ int hci_conn_change_link_key(struct hci_conn *conn)
735{ 735{
736 BT_DBG("conn %p", conn); 736 BT_DBG("conn %p", conn);
737 737
738 if (!test_and_set_bit(HCI_CONN_AUTH_PEND, &conn->pend)) { 738 if (!test_and_set_bit(HCI_CONN_AUTH_PEND, &conn->flags)) {
739 struct hci_cp_change_conn_link_key cp; 739 struct hci_cp_change_conn_link_key cp;
740 cp.handle = cpu_to_le16(conn->handle); 740 cp.handle = cpu_to_le16(conn->handle);
741 hci_send_cmd(conn->hdev, HCI_OP_CHANGE_CONN_LINK_KEY, 741 hci_send_cmd(conn->hdev, HCI_OP_CHANGE_CONN_LINK_KEY,
@@ -754,7 +754,7 @@ int hci_conn_switch_role(struct hci_conn *conn, __u8 role)
754 if (!role && conn->link_mode & HCI_LM_MASTER) 754 if (!role && conn->link_mode & HCI_LM_MASTER)
755 return 1; 755 return 1;
756 756
757 if (!test_and_set_bit(HCI_CONN_RSWITCH_PEND, &conn->pend)) { 757 if (!test_and_set_bit(HCI_CONN_RSWITCH_PEND, &conn->flags)) {
758 struct hci_cp_switch_role cp; 758 struct hci_cp_switch_role cp;
759 bacpy(&cp.bdaddr, &conn->dst); 759 bacpy(&cp.bdaddr, &conn->dst);
760 cp.role = role; 760 cp.role = role;
@@ -781,7 +781,7 @@ void hci_conn_enter_active_mode(struct hci_conn *conn, __u8 force_active)
781 if (!conn->power_save && !force_active) 781 if (!conn->power_save && !force_active)
782 goto timer; 782 goto timer;
783 783
784 if (!test_and_set_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->pend)) { 784 if (!test_and_set_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->flags)) {
785 struct hci_cp_exit_sniff_mode cp; 785 struct hci_cp_exit_sniff_mode cp;
786 cp.handle = cpu_to_le16(conn->handle); 786 cp.handle = cpu_to_le16(conn->handle);
787 hci_send_cmd(hdev, HCI_OP_EXIT_SNIFF_MODE, sizeof(cp), &cp); 787 hci_send_cmd(hdev, HCI_OP_EXIT_SNIFF_MODE, sizeof(cp), &cp);
diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c
index e93afebdcf84..d9a8618ae156 100644
--- a/net/bluetooth/hci_event.c
+++ b/net/bluetooth/hci_event.c
@@ -1344,7 +1344,7 @@ static void hci_cs_remote_name_req(struct hci_dev *hdev, __u8 status)
1344 if (!hci_outgoing_auth_needed(hdev, conn)) 1344 if (!hci_outgoing_auth_needed(hdev, conn))
1345 goto unlock; 1345 goto unlock;
1346 1346
1347 if (!test_and_set_bit(HCI_CONN_AUTH_PEND, &conn->pend)) { 1347 if (!test_and_set_bit(HCI_CONN_AUTH_PEND, &conn->flags)) {
1348 struct hci_cp_auth_requested cp; 1348 struct hci_cp_auth_requested cp;
1349 cp.handle = __cpu_to_le16(conn->handle); 1349 cp.handle = __cpu_to_le16(conn->handle);
1350 hci_send_cmd(hdev, HCI_OP_AUTH_REQUESTED, sizeof(cp), &cp); 1350 hci_send_cmd(hdev, HCI_OP_AUTH_REQUESTED, sizeof(cp), &cp);
@@ -1461,9 +1461,9 @@ static void hci_cs_sniff_mode(struct hci_dev *hdev, __u8 status)
1461 1461
1462 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); 1462 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle));
1463 if (conn) { 1463 if (conn) {
1464 clear_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->pend); 1464 clear_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->flags);
1465 1465
1466 if (test_and_clear_bit(HCI_CONN_SCO_SETUP_PEND, &conn->pend)) 1466 if (test_and_clear_bit(HCI_CONN_SCO_SETUP_PEND, &conn->flags))
1467 hci_sco_setup(conn, status); 1467 hci_sco_setup(conn, status);
1468 } 1468 }
1469 1469
@@ -1488,9 +1488,9 @@ static void hci_cs_exit_sniff_mode(struct hci_dev *hdev, __u8 status)
1488 1488
1489 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); 1489 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle));
1490 if (conn) { 1490 if (conn) {
1491 clear_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->pend); 1491 clear_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->flags);
1492 1492
1493 if (test_and_clear_bit(HCI_CONN_SCO_SETUP_PEND, &conn->pend)) 1493 if (test_and_clear_bit(HCI_CONN_SCO_SETUP_PEND, &conn->flags))
1494 hci_sco_setup(conn, status); 1494 hci_sco_setup(conn, status);
1495 } 1495 }
1496 1496
@@ -1817,7 +1817,7 @@ static inline void hci_auth_complete_evt(struct hci_dev *hdev, struct sk_buff *s
1817 1817
1818 if (!ev->status) { 1818 if (!ev->status) {
1819 if (!(conn->ssp_mode > 0 && hdev->ssp_mode > 0) && 1819 if (!(conn->ssp_mode > 0 && hdev->ssp_mode > 0) &&
1820 test_bit(HCI_CONN_REAUTH_PEND, &conn->pend)) { 1820 test_bit(HCI_CONN_REAUTH_PEND, &conn->flags)) {
1821 BT_INFO("re-auth of legacy device is not possible."); 1821 BT_INFO("re-auth of legacy device is not possible.");
1822 } else { 1822 } else {
1823 conn->link_mode |= HCI_LM_AUTH; 1823 conn->link_mode |= HCI_LM_AUTH;
@@ -1827,8 +1827,8 @@ static inline void hci_auth_complete_evt(struct hci_dev *hdev, struct sk_buff *s
1827 mgmt_auth_failed(hdev, &conn->dst, ev->status); 1827 mgmt_auth_failed(hdev, &conn->dst, ev->status);
1828 } 1828 }
1829 1829
1830 clear_bit(HCI_CONN_AUTH_PEND, &conn->pend); 1830 clear_bit(HCI_CONN_AUTH_PEND, &conn->flags);
1831 clear_bit(HCI_CONN_REAUTH_PEND, &conn->pend); 1831 clear_bit(HCI_CONN_REAUTH_PEND, &conn->flags);
1832 1832
1833 if (conn->state == BT_CONFIG) { 1833 if (conn->state == BT_CONFIG) {
1834 if (!ev->status && hdev->ssp_mode > 0 && conn->ssp_mode > 0) { 1834 if (!ev->status && hdev->ssp_mode > 0 && conn->ssp_mode > 0) {
@@ -1850,7 +1850,7 @@ static inline void hci_auth_complete_evt(struct hci_dev *hdev, struct sk_buff *s
1850 hci_conn_put(conn); 1850 hci_conn_put(conn);
1851 } 1851 }
1852 1852
1853 if (test_bit(HCI_CONN_ENCRYPT_PEND, &conn->pend)) { 1853 if (test_bit(HCI_CONN_ENCRYPT_PEND, &conn->flags)) {
1854 if (!ev->status) { 1854 if (!ev->status) {
1855 struct hci_cp_set_conn_encrypt cp; 1855 struct hci_cp_set_conn_encrypt cp;
1856 cp.handle = ev->handle; 1856 cp.handle = ev->handle;
@@ -1858,7 +1858,7 @@ static inline void hci_auth_complete_evt(struct hci_dev *hdev, struct sk_buff *s
1858 hci_send_cmd(hdev, HCI_OP_SET_CONN_ENCRYPT, sizeof(cp), 1858 hci_send_cmd(hdev, HCI_OP_SET_CONN_ENCRYPT, sizeof(cp),
1859 &cp); 1859 &cp);
1860 } else { 1860 } else {
1861 clear_bit(HCI_CONN_ENCRYPT_PEND, &conn->pend); 1861 clear_bit(HCI_CONN_ENCRYPT_PEND, &conn->flags);
1862 hci_encrypt_cfm(conn, ev->status, 0x00); 1862 hci_encrypt_cfm(conn, ev->status, 0x00);
1863 } 1863 }
1864 } 1864 }
@@ -1892,7 +1892,7 @@ static inline void hci_remote_name_evt(struct hci_dev *hdev, struct sk_buff *skb
1892 if (!hci_outgoing_auth_needed(hdev, conn)) 1892 if (!hci_outgoing_auth_needed(hdev, conn))
1893 goto unlock; 1893 goto unlock;
1894 1894
1895 if (!test_and_set_bit(HCI_CONN_AUTH_PEND, &conn->pend)) { 1895 if (!test_and_set_bit(HCI_CONN_AUTH_PEND, &conn->flags)) {
1896 struct hci_cp_auth_requested cp; 1896 struct hci_cp_auth_requested cp;
1897 cp.handle = __cpu_to_le16(conn->handle); 1897 cp.handle = __cpu_to_le16(conn->handle);
1898 hci_send_cmd(hdev, HCI_OP_AUTH_REQUESTED, sizeof(cp), &cp); 1898 hci_send_cmd(hdev, HCI_OP_AUTH_REQUESTED, sizeof(cp), &cp);
@@ -1923,7 +1923,7 @@ static inline void hci_encrypt_change_evt(struct hci_dev *hdev, struct sk_buff *
1923 conn->link_mode &= ~HCI_LM_ENCRYPT; 1923 conn->link_mode &= ~HCI_LM_ENCRYPT;
1924 } 1924 }
1925 1925
1926 clear_bit(HCI_CONN_ENCRYPT_PEND, &conn->pend); 1926 clear_bit(HCI_CONN_ENCRYPT_PEND, &conn->flags);
1927 1927
1928 if (conn->state == BT_CONFIG) { 1928 if (conn->state == BT_CONFIG) {
1929 if (!ev->status) 1929 if (!ev->status)
@@ -1952,7 +1952,7 @@ static inline void hci_change_link_key_complete_evt(struct hci_dev *hdev, struct
1952 if (!ev->status) 1952 if (!ev->status)
1953 conn->link_mode |= HCI_LM_SECURE; 1953 conn->link_mode |= HCI_LM_SECURE;
1954 1954
1955 clear_bit(HCI_CONN_AUTH_PEND, &conn->pend); 1955 clear_bit(HCI_CONN_AUTH_PEND, &conn->flags);
1956 1956
1957 hci_key_change_cfm(conn, ev->status); 1957 hci_key_change_cfm(conn, ev->status);
1958 } 1958 }
@@ -2336,7 +2336,7 @@ static inline void hci_role_change_evt(struct hci_dev *hdev, struct sk_buff *skb
2336 conn->link_mode |= HCI_LM_MASTER; 2336 conn->link_mode |= HCI_LM_MASTER;
2337 } 2337 }
2338 2338
2339 clear_bit(HCI_CONN_RSWITCH_PEND, &conn->pend); 2339 clear_bit(HCI_CONN_RSWITCH_PEND, &conn->flags);
2340 2340
2341 hci_role_switch_cfm(conn, ev->status, ev->role); 2341 hci_role_switch_cfm(conn, ev->status, ev->role);
2342 } 2342 }
@@ -2474,14 +2474,14 @@ static inline void hci_mode_change_evt(struct hci_dev *hdev, struct sk_buff *skb
2474 conn->mode = ev->mode; 2474 conn->mode = ev->mode;
2475 conn->interval = __le16_to_cpu(ev->interval); 2475 conn->interval = __le16_to_cpu(ev->interval);
2476 2476
2477 if (!test_and_clear_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->pend)) { 2477 if (!test_and_clear_bit(HCI_CONN_MODE_CHANGE_PEND, &conn->flags)) {
2478 if (conn->mode == HCI_CM_ACTIVE) 2478 if (conn->mode == HCI_CM_ACTIVE)
2479 conn->power_save = 1; 2479 conn->power_save = 1;
2480 else 2480 else
2481 conn->power_save = 0; 2481 conn->power_save = 0;
2482 } 2482 }
2483 2483
2484 if (test_and_clear_bit(HCI_CONN_SCO_SETUP_PEND, &conn->pend)) 2484 if (test_and_clear_bit(HCI_CONN_SCO_SETUP_PEND, &conn->flags))
2485 hci_sco_setup(conn, ev->status); 2485 hci_sco_setup(conn, ev->status);
2486 } 2486 }
2487 2487
@@ -3013,7 +3013,7 @@ static inline void hci_user_confirm_request_evt(struct hci_dev *hdev,
3013 /* If we're not the initiators request authorization to 3013 /* If we're not the initiators request authorization to
3014 * proceed from user space (mgmt_user_confirm with 3014 * proceed from user space (mgmt_user_confirm with
3015 * confirm_hint set to 1). */ 3015 * confirm_hint set to 1). */
3016 if (!test_bit(HCI_CONN_AUTH_PEND, &conn->pend)) { 3016 if (!test_bit(HCI_CONN_AUTH_PEND, &conn->flags)) {
3017 BT_DBG("Confirming auto-accept as acceptor"); 3017 BT_DBG("Confirming auto-accept as acceptor");
3018 confirm_hint = 1; 3018 confirm_hint = 1;
3019 goto confirm; 3019 goto confirm;
@@ -3074,7 +3074,7 @@ static inline void hci_simple_pair_complete_evt(struct hci_dev *hdev, struct sk_
3074 * initiated the authentication. A traditional auth_complete 3074 * initiated the authentication. A traditional auth_complete
3075 * event gets always produced as initiator and is also mapped to 3075 * event gets always produced as initiator and is also mapped to
3076 * the mgmt_auth_failed event */ 3076 * the mgmt_auth_failed event */
3077 if (!test_bit(HCI_CONN_AUTH_PEND, &conn->pend) && ev->status != 0) 3077 if (!test_bit(HCI_CONN_AUTH_PEND, &conn->flags) && ev->status != 0)
3078 mgmt_auth_failed(hdev, &conn->dst, ev->status); 3078 mgmt_auth_failed(hdev, &conn->dst, ev->status);
3079 3079
3080 hci_conn_put(conn); 3080 hci_conn_put(conn);
diff --git a/net/bluetooth/l2cap_core.c b/net/bluetooth/l2cap_core.c
index a66e5ec9adef..27b72d954436 100644
--- a/net/bluetooth/l2cap_core.c
+++ b/net/bluetooth/l2cap_core.c
@@ -1020,7 +1020,7 @@ static void l2cap_conn_del(struct hci_conn *hcon, int err)
1020 if (conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_SENT) 1020 if (conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_SENT)
1021 __cancel_delayed_work(&conn->info_timer); 1021 __cancel_delayed_work(&conn->info_timer);
1022 1022
1023 if (test_and_clear_bit(HCI_CONN_LE_SMP_PEND, &hcon->pend)) { 1023 if (test_and_clear_bit(HCI_CONN_LE_SMP_PEND, &hcon->flags)) {
1024 __cancel_delayed_work(&conn->security_timer); 1024 __cancel_delayed_work(&conn->security_timer);
1025 smp_chan_destroy(conn); 1025 smp_chan_destroy(conn);
1026 } 1026 }
diff --git a/net/bluetooth/smp.c b/net/bluetooth/smp.c
index 65a90242d990..e08fe6c9c9c9 100644
--- a/net/bluetooth/smp.c
+++ b/net/bluetooth/smp.c
@@ -261,7 +261,7 @@ static void smp_failure(struct l2cap_conn *conn, u8 reason, u8 send)
261 smp_send_cmd(conn, SMP_CMD_PAIRING_FAIL, sizeof(reason), 261 smp_send_cmd(conn, SMP_CMD_PAIRING_FAIL, sizeof(reason),
262 &reason); 262 &reason);
263 263
264 clear_bit(HCI_CONN_ENCRYPT_PEND, &conn->hcon->pend); 264 clear_bit(HCI_CONN_ENCRYPT_PEND, &conn->hcon->flags);
265 mgmt_auth_failed(conn->hcon->hdev, conn->dst, reason); 265 mgmt_auth_failed(conn->hcon->hdev, conn->dst, reason);
266 cancel_delayed_work_sync(&conn->security_timer); 266 cancel_delayed_work_sync(&conn->security_timer);
267 smp_chan_destroy(conn); 267 smp_chan_destroy(conn);
@@ -449,7 +449,7 @@ static void random_work(struct work_struct *work)
449 memset(stk + smp->smp_key_size, 0, 449 memset(stk + smp->smp_key_size, 0,
450 SMP_MAX_ENC_KEY_SIZE - smp->smp_key_size); 450 SMP_MAX_ENC_KEY_SIZE - smp->smp_key_size);
451 451
452 if (test_and_set_bit(HCI_CONN_ENCRYPT_PEND, &hcon->pend)) { 452 if (test_and_set_bit(HCI_CONN_ENCRYPT_PEND, &hcon->flags)) {
453 reason = SMP_UNSPECIFIED; 453 reason = SMP_UNSPECIFIED;
454 goto error; 454 goto error;
455 } 455 }
@@ -506,7 +506,7 @@ void smp_chan_destroy(struct l2cap_conn *conn)
506{ 506{
507 struct smp_chan *smp = conn->smp_chan; 507 struct smp_chan *smp = conn->smp_chan;
508 508
509 clear_bit(HCI_CONN_LE_SMP_PEND, &conn->hcon->pend); 509 clear_bit(HCI_CONN_LE_SMP_PEND, &conn->hcon->flags);
510 510
511 if (smp->tfm) 511 if (smp->tfm)
512 crypto_free_blkcipher(smp->tfm); 512 crypto_free_blkcipher(smp->tfm);
@@ -571,7 +571,7 @@ static u8 smp_cmd_pairing_req(struct l2cap_conn *conn, struct sk_buff *skb)
571 if (conn->hcon->link_mode & HCI_LM_MASTER) 571 if (conn->hcon->link_mode & HCI_LM_MASTER)
572 return SMP_CMD_NOTSUPP; 572 return SMP_CMD_NOTSUPP;
573 573
574 if (!test_and_set_bit(HCI_CONN_LE_SMP_PEND, &conn->hcon->pend)) 574 if (!test_and_set_bit(HCI_CONN_LE_SMP_PEND, &conn->hcon->flags))
575 smp = smp_chan_create(conn); 575 smp = smp_chan_create(conn);
576 576
577 smp = conn->smp_chan; 577 smp = conn->smp_chan;
@@ -707,8 +707,7 @@ static u8 smp_ltk_encrypt(struct l2cap_conn *conn)
707 if (!key) 707 if (!key)
708 return 0; 708 return 0;
709 709
710 if (test_and_set_bit(HCI_CONN_ENCRYPT_PEND, 710 if (test_and_set_bit(HCI_CONN_ENCRYPT_PEND, &hcon->flags))
711 &hcon->pend))
712 return 1; 711 return 1;
713 712
714 master = (void *) key->data; 713 master = (void *) key->data;
@@ -733,7 +732,7 @@ static u8 smp_cmd_security_req(struct l2cap_conn *conn, struct sk_buff *skb)
733 if (smp_ltk_encrypt(conn)) 732 if (smp_ltk_encrypt(conn))
734 return 0; 733 return 0;
735 734
736 if (test_and_set_bit(HCI_CONN_LE_SMP_PEND, &hcon->pend)) 735 if (test_and_set_bit(HCI_CONN_LE_SMP_PEND, &hcon->flags))
737 return 0; 736 return 0;
738 737
739 smp = smp_chan_create(conn); 738 smp = smp_chan_create(conn);
@@ -772,7 +771,7 @@ int smp_conn_security(struct l2cap_conn *conn, __u8 sec_level)
772 if (smp_ltk_encrypt(conn)) 771 if (smp_ltk_encrypt(conn))
773 goto done; 772 goto done;
774 773
775 if (test_and_set_bit(HCI_CONN_LE_SMP_PEND, &hcon->pend)) 774 if (test_and_set_bit(HCI_CONN_LE_SMP_PEND, &hcon->flags))
776 return 0; 775 return 0;
777 776
778 smp = smp_chan_create(conn); 777 smp = smp_chan_create(conn);
@@ -908,7 +907,7 @@ int smp_distribute_keys(struct l2cap_conn *conn, __u8 force)
908 907
909 BT_DBG("conn %p force %d", conn, force); 908 BT_DBG("conn %p force %d", conn, force);
910 909
911 if (!test_bit(HCI_CONN_LE_SMP_PEND, &conn->hcon->pend)) 910 if (!test_bit(HCI_CONN_LE_SMP_PEND, &conn->hcon->flags))
912 return 0; 911 return 0;
913 912
914 rsp = (void *) &smp->prsp[1]; 913 rsp = (void *) &smp->prsp[1];
@@ -982,7 +981,7 @@ int smp_distribute_keys(struct l2cap_conn *conn, __u8 force)
982 } 981 }
983 982
984 if (conn->hcon->out || force) { 983 if (conn->hcon->out || force) {
985 clear_bit(HCI_CONN_LE_SMP_PEND, &conn->hcon->pend); 984 clear_bit(HCI_CONN_LE_SMP_PEND, &conn->hcon->flags);
986 cancel_delayed_work_sync(&conn->security_timer); 985 cancel_delayed_work_sync(&conn->security_timer);
987 smp_chan_destroy(conn); 986 smp_chan_destroy(conn);
988 } 987 }