aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/net/bluetooth/l2cap.h3
-rw-r--r--net/bluetooth/l2cap_core.c10
-rw-r--r--net/bluetooth/smp.c2
3 files changed, 11 insertions, 4 deletions
diff --git a/include/net/bluetooth/l2cap.h b/include/net/bluetooth/l2cap.h
index be25eddea615..ead99f032f7a 100644
--- a/include/net/bluetooth/l2cap.h
+++ b/include/net/bluetooth/l2cap.h
@@ -633,6 +633,8 @@ struct l2cap_conn {
633 struct sk_buff_head pending_rx; 633 struct sk_buff_head pending_rx;
634 struct work_struct pending_rx_work; 634 struct work_struct pending_rx_work;
635 635
636 struct work_struct id_addr_update_work;
637
636 __u8 disc_reason; 638 __u8 disc_reason;
637 639
638 struct l2cap_chan *smp; 640 struct l2cap_chan *smp;
@@ -937,7 +939,6 @@ int l2cap_ertm_init(struct l2cap_chan *chan);
937void l2cap_chan_add(struct l2cap_conn *conn, struct l2cap_chan *chan); 939void l2cap_chan_add(struct l2cap_conn *conn, struct l2cap_chan *chan);
938void __l2cap_chan_add(struct l2cap_conn *conn, struct l2cap_chan *chan); 940void __l2cap_chan_add(struct l2cap_conn *conn, struct l2cap_chan *chan);
939void l2cap_chan_del(struct l2cap_chan *chan, int err); 941void l2cap_chan_del(struct l2cap_chan *chan, int err);
940void l2cap_conn_update_id_addr(struct hci_conn *hcon);
941void l2cap_send_conn_req(struct l2cap_chan *chan); 942void l2cap_send_conn_req(struct l2cap_chan *chan);
942void l2cap_move_start(struct l2cap_chan *chan); 943void l2cap_move_start(struct l2cap_chan *chan);
943void l2cap_logical_cfm(struct l2cap_chan *chan, struct hci_chan *hchan, 944void l2cap_logical_cfm(struct l2cap_chan *chan, struct hci_chan *hchan,
diff --git a/net/bluetooth/l2cap_core.c b/net/bluetooth/l2cap_core.c
index ab405f0e53cb..b71430caab4a 100644
--- a/net/bluetooth/l2cap_core.c
+++ b/net/bluetooth/l2cap_core.c
@@ -631,9 +631,11 @@ void l2cap_chan_del(struct l2cap_chan *chan, int err)
631} 631}
632EXPORT_SYMBOL_GPL(l2cap_chan_del); 632EXPORT_SYMBOL_GPL(l2cap_chan_del);
633 633
634void l2cap_conn_update_id_addr(struct hci_conn *hcon) 634static void l2cap_conn_update_id_addr(struct work_struct *work)
635{ 635{
636 struct l2cap_conn *conn = hcon->l2cap_data; 636 struct l2cap_conn *conn = container_of(work, struct l2cap_conn,
637 id_addr_update_work);
638 struct hci_conn *hcon = conn->hcon;
637 struct l2cap_chan *chan; 639 struct l2cap_chan *chan;
638 640
639 mutex_lock(&conn->chan_lock); 641 mutex_lock(&conn->chan_lock);
@@ -1635,6 +1637,9 @@ static void l2cap_conn_del(struct hci_conn *hcon, int err)
1635 if (work_pending(&conn->pending_rx_work)) 1637 if (work_pending(&conn->pending_rx_work))
1636 cancel_work_sync(&conn->pending_rx_work); 1638 cancel_work_sync(&conn->pending_rx_work);
1637 1639
1640 if (work_pending(&conn->id_addr_update_work))
1641 cancel_work_sync(&conn->id_addr_update_work);
1642
1638 l2cap_unregister_all_users(conn); 1643 l2cap_unregister_all_users(conn);
1639 1644
1640 /* Force the connection to be immediately dropped */ 1645 /* Force the connection to be immediately dropped */
@@ -6927,6 +6932,7 @@ static struct l2cap_conn *l2cap_conn_add(struct hci_conn *hcon)
6927 6932
6928 skb_queue_head_init(&conn->pending_rx); 6933 skb_queue_head_init(&conn->pending_rx);
6929 INIT_WORK(&conn->pending_rx_work, process_pending_rx); 6934 INIT_WORK(&conn->pending_rx_work, process_pending_rx);
6935 INIT_WORK(&conn->id_addr_update_work, l2cap_conn_update_id_addr);
6930 6936
6931 conn->disc_reason = HCI_ERROR_REMOTE_USER_TERM; 6937 conn->disc_reason = HCI_ERROR_REMOTE_USER_TERM;
6932 6938
diff --git a/net/bluetooth/smp.c b/net/bluetooth/smp.c
index 9accb4739488..795c603bed30 100644
--- a/net/bluetooth/smp.c
+++ b/net/bluetooth/smp.c
@@ -654,7 +654,7 @@ static void smp_notify_keys(struct l2cap_conn *conn)
654 */ 654 */
655 bacpy(&hcon->dst, &smp->remote_irk->bdaddr); 655 bacpy(&hcon->dst, &smp->remote_irk->bdaddr);
656 hcon->dst_type = smp->remote_irk->addr_type; 656 hcon->dst_type = smp->remote_irk->addr_type;
657 l2cap_conn_update_id_addr(hcon); 657 queue_work(hdev->workqueue, &conn->id_addr_update_work);
658 658
659 /* When receiving an indentity resolving key for 659 /* When receiving an indentity resolving key for
660 * a remote device that does not use a resolvable 660 * a remote device that does not use a resolvable