aboutsummaryrefslogtreecommitdiffstats
path: root/net/nfc
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2012-08-22 19:22:16 -0400
committerSamuel Ortiz <sameo@linux.intel.com>2012-09-24 18:17:23 -0400
commit474fee3db16c63bc440bfb93b57f72ecfc4246f0 (patch)
treef5fed7f3b40408f21fa3b9edc67d5ac0b869149f /net/nfc
parent5db327f96daa2401b9afec6cd80cebe6c6475bb1 (diff)
NFC: Use system_nrt_wq instead of custom ones
NFC is using a number of custom ordered workqueues w/ WQ_MEM_RECLAIM. WQ_MEM_RECLAIM is unnecessary unless NFC is gonna be used as transport for storage device, and all use cases match one work item to one ordered workqueue - IOW, there's no actual ordering going on at all and using system_nrt_wq gives the same behavior. There's nothing to be gained by using custom workqueues. Use system_nrt_wq instead and drop all the custom ones. Signed-off-by: Tejun Heo <tj@kernel.org> Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
Diffstat (limited to 'net/nfc')
-rw-r--r--net/nfc/core.c13
-rw-r--r--net/nfc/hci/core.c42
-rw-r--r--net/nfc/hci/hcp.c2
-rw-r--r--net/nfc/hci/shdlc.c27
-rw-r--r--net/nfc/llcp/llcp.c57
-rw-r--r--net/nfc/llcp/llcp.h3
6 files changed, 26 insertions, 118 deletions
diff --git a/net/nfc/core.c b/net/nfc/core.c
index ff749794bc5b..c9eacc1f145f 100644
--- a/net/nfc/core.c
+++ b/net/nfc/core.c
@@ -679,7 +679,7 @@ static void nfc_release(struct device *d)
679 679
680 if (dev->ops->check_presence) { 680 if (dev->ops->check_presence) {
681 del_timer_sync(&dev->check_pres_timer); 681 del_timer_sync(&dev->check_pres_timer);
682 destroy_workqueue(dev->check_pres_wq); 682 cancel_work_sync(&dev->check_pres_work);
683 } 683 }
684 684
685 nfc_genl_data_exit(&dev->genl_data); 685 nfc_genl_data_exit(&dev->genl_data);
@@ -715,7 +715,7 @@ static void nfc_check_pres_timeout(unsigned long data)
715{ 715{
716 struct nfc_dev *dev = (struct nfc_dev *)data; 716 struct nfc_dev *dev = (struct nfc_dev *)data;
717 717
718 queue_work(dev->check_pres_wq, &dev->check_pres_work); 718 queue_work(system_nrt_wq, &dev->check_pres_work);
719} 719}
720 720
721struct class nfc_class = { 721struct class nfc_class = {
@@ -784,20 +784,11 @@ struct nfc_dev *nfc_allocate_device(struct nfc_ops *ops,
784 dev->targets_generation = 1; 784 dev->targets_generation = 1;
785 785
786 if (ops->check_presence) { 786 if (ops->check_presence) {
787 char name[32];
788 init_timer(&dev->check_pres_timer); 787 init_timer(&dev->check_pres_timer);
789 dev->check_pres_timer.data = (unsigned long)dev; 788 dev->check_pres_timer.data = (unsigned long)dev;
790 dev->check_pres_timer.function = nfc_check_pres_timeout; 789 dev->check_pres_timer.function = nfc_check_pres_timeout;
791 790
792 INIT_WORK(&dev->check_pres_work, nfc_check_pres_work); 791 INIT_WORK(&dev->check_pres_work, nfc_check_pres_work);
793 snprintf(name, sizeof(name), "nfc%d_check_pres_wq", dev->idx);
794 dev->check_pres_wq = alloc_workqueue(name, WQ_NON_REENTRANT |
795 WQ_UNBOUND |
796 WQ_MEM_RECLAIM, 1);
797 if (dev->check_pres_wq == NULL) {
798 kfree(dev);
799 return NULL;
800 }
801 } 792 }
802 793
803 return dev; 794 return dev;
diff --git a/net/nfc/hci/core.c b/net/nfc/hci/core.c
index 1ac7b3fac6c9..03646beb3a73 100644
--- a/net/nfc/hci/core.c
+++ b/net/nfc/hci/core.c
@@ -141,7 +141,7 @@ static void __nfc_hci_cmd_completion(struct nfc_hci_dev *hdev, int err,
141 kfree(hdev->cmd_pending_msg); 141 kfree(hdev->cmd_pending_msg);
142 hdev->cmd_pending_msg = NULL; 142 hdev->cmd_pending_msg = NULL;
143 143
144 queue_work(hdev->msg_tx_wq, &hdev->msg_tx_work); 144 queue_work(system_nrt_wq, &hdev->msg_tx_work);
145} 145}
146 146
147void nfc_hci_resp_received(struct nfc_hci_dev *hdev, u8 result, 147void nfc_hci_resp_received(struct nfc_hci_dev *hdev, u8 result,
@@ -326,7 +326,7 @@ static void nfc_hci_cmd_timeout(unsigned long data)
326{ 326{
327 struct nfc_hci_dev *hdev = (struct nfc_hci_dev *)data; 327 struct nfc_hci_dev *hdev = (struct nfc_hci_dev *)data;
328 328
329 queue_work(hdev->msg_tx_wq, &hdev->msg_tx_work); 329 queue_work(system_nrt_wq, &hdev->msg_tx_work);
330} 330}
331 331
332static int hci_dev_connect_gates(struct nfc_hci_dev *hdev, u8 gate_count, 332static int hci_dev_connect_gates(struct nfc_hci_dev *hdev, u8 gate_count,
@@ -659,23 +659,11 @@ EXPORT_SYMBOL(nfc_hci_free_device);
659 659
660int nfc_hci_register_device(struct nfc_hci_dev *hdev) 660int nfc_hci_register_device(struct nfc_hci_dev *hdev)
661{ 661{
662 struct device *dev = &hdev->ndev->dev;
663 const char *devname = dev_name(dev);
664 char name[32];
665 int r = 0;
666
667 mutex_init(&hdev->msg_tx_mutex); 662 mutex_init(&hdev->msg_tx_mutex);
668 663
669 INIT_LIST_HEAD(&hdev->msg_tx_queue); 664 INIT_LIST_HEAD(&hdev->msg_tx_queue);
670 665
671 INIT_WORK(&hdev->msg_tx_work, nfc_hci_msg_tx_work); 666 INIT_WORK(&hdev->msg_tx_work, nfc_hci_msg_tx_work);
672 snprintf(name, sizeof(name), "%s_hci_msg_tx_wq", devname);
673 hdev->msg_tx_wq = alloc_workqueue(name, WQ_NON_REENTRANT | WQ_UNBOUND |
674 WQ_MEM_RECLAIM, 1);
675 if (hdev->msg_tx_wq == NULL) {
676 r = -ENOMEM;
677 goto exit;
678 }
679 667
680 init_timer(&hdev->cmd_timer); 668 init_timer(&hdev->cmd_timer);
681 hdev->cmd_timer.data = (unsigned long)hdev; 669 hdev->cmd_timer.data = (unsigned long)hdev;
@@ -684,27 +672,10 @@ int nfc_hci_register_device(struct nfc_hci_dev *hdev)
684 skb_queue_head_init(&hdev->rx_hcp_frags); 672 skb_queue_head_init(&hdev->rx_hcp_frags);
685 673
686 INIT_WORK(&hdev->msg_rx_work, nfc_hci_msg_rx_work); 674 INIT_WORK(&hdev->msg_rx_work, nfc_hci_msg_rx_work);
687 snprintf(name, sizeof(name), "%s_hci_msg_rx_wq", devname);
688 hdev->msg_rx_wq = alloc_workqueue(name, WQ_NON_REENTRANT | WQ_UNBOUND |
689 WQ_MEM_RECLAIM, 1);
690 if (hdev->msg_rx_wq == NULL) {
691 r = -ENOMEM;
692 goto exit;
693 }
694 675
695 skb_queue_head_init(&hdev->msg_rx_queue); 676 skb_queue_head_init(&hdev->msg_rx_queue);
696 677
697 r = nfc_register_device(hdev->ndev); 678 return nfc_register_device(hdev->ndev);
698
699exit:
700 if (r < 0) {
701 if (hdev->msg_tx_wq)
702 destroy_workqueue(hdev->msg_tx_wq);
703 if (hdev->msg_rx_wq)
704 destroy_workqueue(hdev->msg_rx_wq);
705 }
706
707 return r;
708} 679}
709EXPORT_SYMBOL(nfc_hci_register_device); 680EXPORT_SYMBOL(nfc_hci_register_device);
710 681
@@ -725,9 +696,8 @@ void nfc_hci_unregister_device(struct nfc_hci_dev *hdev)
725 696
726 nfc_unregister_device(hdev->ndev); 697 nfc_unregister_device(hdev->ndev);
727 698
728 destroy_workqueue(hdev->msg_tx_wq); 699 cancel_work_sync(&hdev->msg_tx_work);
729 700 cancel_work_sync(&hdev->msg_rx_work);
730 destroy_workqueue(hdev->msg_rx_wq);
731} 701}
732EXPORT_SYMBOL(nfc_hci_unregister_device); 702EXPORT_SYMBOL(nfc_hci_unregister_device);
733 703
@@ -827,7 +797,7 @@ void nfc_hci_recv_frame(struct nfc_hci_dev *hdev, struct sk_buff *skb)
827 nfc_hci_hcp_message_rx(hdev, pipe, type, instruction, hcp_skb); 797 nfc_hci_hcp_message_rx(hdev, pipe, type, instruction, hcp_skb);
828 } else { 798 } else {
829 skb_queue_tail(&hdev->msg_rx_queue, hcp_skb); 799 skb_queue_tail(&hdev->msg_rx_queue, hcp_skb);
830 queue_work(hdev->msg_rx_wq, &hdev->msg_rx_work); 800 queue_work(system_nrt_wq, &hdev->msg_rx_work);
831 } 801 }
832} 802}
833EXPORT_SYMBOL(nfc_hci_recv_frame); 803EXPORT_SYMBOL(nfc_hci_recv_frame);
diff --git a/net/nfc/hci/hcp.c b/net/nfc/hci/hcp.c
index f4dad1a89740..2372b558abe9 100644
--- a/net/nfc/hci/hcp.c
+++ b/net/nfc/hci/hcp.c
@@ -108,7 +108,7 @@ int nfc_hci_hcp_message_tx(struct nfc_hci_dev *hdev, u8 pipe,
108 list_add_tail(&cmd->msg_l, &hdev->msg_tx_queue); 108 list_add_tail(&cmd->msg_l, &hdev->msg_tx_queue);
109 mutex_unlock(&hdev->msg_tx_mutex); 109 mutex_unlock(&hdev->msg_tx_mutex);
110 110
111 queue_work(hdev->msg_tx_wq, &hdev->msg_tx_work); 111 queue_work(system_nrt_wq, &hdev->msg_tx_work);
112 112
113 return 0; 113 return 0;
114 114
diff --git a/net/nfc/hci/shdlc.c b/net/nfc/hci/shdlc.c
index 6f840c18c892..39b51eacc391 100644
--- a/net/nfc/hci/shdlc.c
+++ b/net/nfc/hci/shdlc.c
@@ -540,7 +540,7 @@ static void nfc_shdlc_connect_timeout(unsigned long data)
540 540
541 pr_debug("\n"); 541 pr_debug("\n");
542 542
543 queue_work(shdlc->sm_wq, &shdlc->sm_work); 543 queue_work(system_nrt_wq, &shdlc->sm_work);
544} 544}
545 545
546static void nfc_shdlc_t1_timeout(unsigned long data) 546static void nfc_shdlc_t1_timeout(unsigned long data)
@@ -549,7 +549,7 @@ static void nfc_shdlc_t1_timeout(unsigned long data)
549 549
550 pr_debug("SoftIRQ: need to send ack\n"); 550 pr_debug("SoftIRQ: need to send ack\n");
551 551
552 queue_work(shdlc->sm_wq, &shdlc->sm_work); 552 queue_work(system_nrt_wq, &shdlc->sm_work);
553} 553}
554 554
555static void nfc_shdlc_t2_timeout(unsigned long data) 555static void nfc_shdlc_t2_timeout(unsigned long data)
@@ -558,7 +558,7 @@ static void nfc_shdlc_t2_timeout(unsigned long data)
558 558
559 pr_debug("SoftIRQ: need to retransmit\n"); 559 pr_debug("SoftIRQ: need to retransmit\n");
560 560
561 queue_work(shdlc->sm_wq, &shdlc->sm_work); 561 queue_work(system_nrt_wq, &shdlc->sm_work);
562} 562}
563 563
564static void nfc_shdlc_sm_work(struct work_struct *work) 564static void nfc_shdlc_sm_work(struct work_struct *work)
@@ -598,7 +598,7 @@ static void nfc_shdlc_sm_work(struct work_struct *work)
598 case SHDLC_NEGOCIATING: 598 case SHDLC_NEGOCIATING:
599 if (timer_pending(&shdlc->connect_timer) == 0) { 599 if (timer_pending(&shdlc->connect_timer) == 0) {
600 shdlc->state = SHDLC_CONNECTING; 600 shdlc->state = SHDLC_CONNECTING;
601 queue_work(shdlc->sm_wq, &shdlc->sm_work); 601 queue_work(system_nrt_wq, &shdlc->sm_work);
602 } 602 }
603 603
604 nfc_shdlc_handle_rcv_queue(shdlc); 604 nfc_shdlc_handle_rcv_queue(shdlc);
@@ -662,7 +662,7 @@ static int nfc_shdlc_connect(struct nfc_shdlc *shdlc)
662 662
663 mutex_unlock(&shdlc->state_mutex); 663 mutex_unlock(&shdlc->state_mutex);
664 664
665 queue_work(shdlc->sm_wq, &shdlc->sm_work); 665 queue_work(system_nrt_wq, &shdlc->sm_work);
666 666
667 wait_event(connect_wq, shdlc->connect_result != 1); 667 wait_event(connect_wq, shdlc->connect_result != 1);
668 668
@@ -679,7 +679,7 @@ static void nfc_shdlc_disconnect(struct nfc_shdlc *shdlc)
679 679
680 mutex_unlock(&shdlc->state_mutex); 680 mutex_unlock(&shdlc->state_mutex);
681 681
682 queue_work(shdlc->sm_wq, &shdlc->sm_work); 682 queue_work(system_nrt_wq, &shdlc->sm_work);
683} 683}
684 684
685/* 685/*
@@ -697,7 +697,7 @@ void nfc_shdlc_recv_frame(struct nfc_shdlc *shdlc, struct sk_buff *skb)
697 skb_queue_tail(&shdlc->rcv_q, skb); 697 skb_queue_tail(&shdlc->rcv_q, skb);
698 } 698 }
699 699
700 queue_work(shdlc->sm_wq, &shdlc->sm_work); 700 queue_work(system_nrt_wq, &shdlc->sm_work);
701} 701}
702EXPORT_SYMBOL(nfc_shdlc_recv_frame); 702EXPORT_SYMBOL(nfc_shdlc_recv_frame);
703 703
@@ -754,7 +754,7 @@ static int nfc_shdlc_xmit(struct nfc_hci_dev *hdev, struct sk_buff *skb)
754 754
755 skb_queue_tail(&shdlc->send_q, skb); 755 skb_queue_tail(&shdlc->send_q, skb);
756 756
757 queue_work(shdlc->sm_wq, &shdlc->sm_work); 757 queue_work(system_nrt_wq, &shdlc->sm_work);
758 758
759 return 0; 759 return 0;
760} 760}
@@ -843,7 +843,6 @@ struct nfc_shdlc *nfc_shdlc_allocate(struct nfc_shdlc_ops *ops,
843{ 843{
844 struct nfc_shdlc *shdlc; 844 struct nfc_shdlc *shdlc;
845 int r; 845 int r;
846 char name[32];
847 846
848 if (ops->xmit == NULL) 847 if (ops->xmit == NULL)
849 return NULL; 848 return NULL;
@@ -876,11 +875,6 @@ struct nfc_shdlc *nfc_shdlc_allocate(struct nfc_shdlc_ops *ops,
876 skb_queue_head_init(&shdlc->ack_pending_q); 875 skb_queue_head_init(&shdlc->ack_pending_q);
877 876
878 INIT_WORK(&shdlc->sm_work, nfc_shdlc_sm_work); 877 INIT_WORK(&shdlc->sm_work, nfc_shdlc_sm_work);
879 snprintf(name, sizeof(name), "%s_shdlc_sm_wq", devname);
880 shdlc->sm_wq = alloc_workqueue(name, WQ_NON_REENTRANT | WQ_UNBOUND |
881 WQ_MEM_RECLAIM, 1);
882 if (shdlc->sm_wq == NULL)
883 goto err_allocwq;
884 878
885 shdlc->client_headroom = tx_headroom; 879 shdlc->client_headroom = tx_headroom;
886 shdlc->client_tailroom = tx_tailroom; 880 shdlc->client_tailroom = tx_tailroom;
@@ -904,9 +898,6 @@ err_regdev:
904 nfc_hci_free_device(shdlc->hdev); 898 nfc_hci_free_device(shdlc->hdev);
905 899
906err_allocdev: 900err_allocdev:
907 destroy_workqueue(shdlc->sm_wq);
908
909err_allocwq:
910 kfree(shdlc); 901 kfree(shdlc);
911 902
912 return NULL; 903 return NULL;
@@ -920,7 +911,7 @@ void nfc_shdlc_free(struct nfc_shdlc *shdlc)
920 nfc_hci_unregister_device(shdlc->hdev); 911 nfc_hci_unregister_device(shdlc->hdev);
921 nfc_hci_free_device(shdlc->hdev); 912 nfc_hci_free_device(shdlc->hdev);
922 913
923 destroy_workqueue(shdlc->sm_wq); 914 cancel_work_sync(&shdlc->sm_work);
924 915
925 skb_queue_purge(&shdlc->rcv_q); 916 skb_queue_purge(&shdlc->rcv_q);
926 skb_queue_purge(&shdlc->send_q); 917 skb_queue_purge(&shdlc->send_q);
diff --git a/net/nfc/llcp/llcp.c b/net/nfc/llcp/llcp.c
index 82f0f7588b46..6f368412ffd2 100644
--- a/net/nfc/llcp/llcp.c
+++ b/net/nfc/llcp/llcp.c
@@ -114,9 +114,9 @@ static void local_release(struct kref *ref)
114 nfc_llcp_socket_release(local, false); 114 nfc_llcp_socket_release(local, false);
115 del_timer_sync(&local->link_timer); 115 del_timer_sync(&local->link_timer);
116 skb_queue_purge(&local->tx_queue); 116 skb_queue_purge(&local->tx_queue);
117 destroy_workqueue(local->tx_wq); 117 cancel_work_sync(&local->tx_work);
118 destroy_workqueue(local->rx_wq); 118 cancel_work_sync(&local->rx_work);
119 destroy_workqueue(local->timeout_wq); 119 cancel_work_sync(&local->timeout_work);
120 kfree_skb(local->rx_pending); 120 kfree_skb(local->rx_pending);
121 kfree(local); 121 kfree(local);
122} 122}
@@ -181,7 +181,7 @@ static void nfc_llcp_symm_timer(unsigned long data)
181 181
182 pr_err("SYMM timeout\n"); 182 pr_err("SYMM timeout\n");
183 183
184 queue_work(local->timeout_wq, &local->timeout_work); 184 queue_work(system_nrt_wq, &local->timeout_work);
185} 185}
186 186
187struct nfc_llcp_local *nfc_llcp_find_local(struct nfc_dev *dev) 187struct nfc_llcp_local *nfc_llcp_find_local(struct nfc_dev *dev)
@@ -1052,7 +1052,7 @@ static void nfc_llcp_rx_work(struct work_struct *work)
1052 1052
1053 } 1053 }
1054 1054
1055 queue_work(local->tx_wq, &local->tx_work); 1055 queue_work(system_nrt_wq, &local->tx_work);
1056 kfree_skb(local->rx_pending); 1056 kfree_skb(local->rx_pending);
1057 local->rx_pending = NULL; 1057 local->rx_pending = NULL;
1058 1058
@@ -1071,7 +1071,7 @@ void nfc_llcp_recv(void *data, struct sk_buff *skb, int err)
1071 1071
1072 local->rx_pending = skb_get(skb); 1072 local->rx_pending = skb_get(skb);
1073 del_timer(&local->link_timer); 1073 del_timer(&local->link_timer);
1074 queue_work(local->rx_wq, &local->rx_work); 1074 queue_work(system_nrt_wq, &local->rx_work);
1075 1075
1076 return; 1076 return;
1077} 1077}
@@ -1086,7 +1086,7 @@ int nfc_llcp_data_received(struct nfc_dev *dev, struct sk_buff *skb)
1086 1086
1087 local->rx_pending = skb_get(skb); 1087 local->rx_pending = skb_get(skb);
1088 del_timer(&local->link_timer); 1088 del_timer(&local->link_timer);
1089 queue_work(local->rx_wq, &local->rx_work); 1089 queue_work(system_nrt_wq, &local->rx_work);
1090 1090
1091 return 0; 1091 return 0;
1092} 1092}
@@ -1121,7 +1121,7 @@ void nfc_llcp_mac_is_up(struct nfc_dev *dev, u32 target_idx,
1121 if (rf_mode == NFC_RF_INITIATOR) { 1121 if (rf_mode == NFC_RF_INITIATOR) {
1122 pr_debug("Queueing Tx work\n"); 1122 pr_debug("Queueing Tx work\n");
1123 1123
1124 queue_work(local->tx_wq, &local->tx_work); 1124 queue_work(system_nrt_wq, &local->tx_work);
1125 } else { 1125 } else {
1126 mod_timer(&local->link_timer, 1126 mod_timer(&local->link_timer,
1127 jiffies + msecs_to_jiffies(local->remote_lto)); 1127 jiffies + msecs_to_jiffies(local->remote_lto));
@@ -1130,10 +1130,7 @@ void nfc_llcp_mac_is_up(struct nfc_dev *dev, u32 target_idx,
1130 1130
1131int nfc_llcp_register_device(struct nfc_dev *ndev) 1131int nfc_llcp_register_device(struct nfc_dev *ndev)
1132{ 1132{
1133 struct device *dev = &ndev->dev;
1134 struct nfc_llcp_local *local; 1133 struct nfc_llcp_local *local;
1135 char name[32];
1136 int err;
1137 1134
1138 local = kzalloc(sizeof(struct nfc_llcp_local), GFP_KERNEL); 1135 local = kzalloc(sizeof(struct nfc_llcp_local), GFP_KERNEL);
1139 if (local == NULL) 1136 if (local == NULL)
@@ -1149,38 +1146,11 @@ int nfc_llcp_register_device(struct nfc_dev *ndev)
1149 1146
1150 skb_queue_head_init(&local->tx_queue); 1147 skb_queue_head_init(&local->tx_queue);
1151 INIT_WORK(&local->tx_work, nfc_llcp_tx_work); 1148 INIT_WORK(&local->tx_work, nfc_llcp_tx_work);
1152 snprintf(name, sizeof(name), "%s_llcp_tx_wq", dev_name(dev));
1153 local->tx_wq =
1154 alloc_workqueue(name,
1155 WQ_NON_REENTRANT | WQ_UNBOUND | WQ_MEM_RECLAIM,
1156 1);
1157 if (local->tx_wq == NULL) {
1158 err = -ENOMEM;
1159 goto err_local;
1160 }
1161 1149
1162 local->rx_pending = NULL; 1150 local->rx_pending = NULL;
1163 INIT_WORK(&local->rx_work, nfc_llcp_rx_work); 1151 INIT_WORK(&local->rx_work, nfc_llcp_rx_work);
1164 snprintf(name, sizeof(name), "%s_llcp_rx_wq", dev_name(dev));
1165 local->rx_wq =
1166 alloc_workqueue(name,
1167 WQ_NON_REENTRANT | WQ_UNBOUND | WQ_MEM_RECLAIM,
1168 1);
1169 if (local->rx_wq == NULL) {
1170 err = -ENOMEM;
1171 goto err_tx_wq;
1172 }
1173 1152
1174 INIT_WORK(&local->timeout_work, nfc_llcp_timeout_work); 1153 INIT_WORK(&local->timeout_work, nfc_llcp_timeout_work);
1175 snprintf(name, sizeof(name), "%s_llcp_timeout_wq", dev_name(dev));
1176 local->timeout_wq =
1177 alloc_workqueue(name,
1178 WQ_NON_REENTRANT | WQ_UNBOUND | WQ_MEM_RECLAIM,
1179 1);
1180 if (local->timeout_wq == NULL) {
1181 err = -ENOMEM;
1182 goto err_rx_wq;
1183 }
1184 1154
1185 local->sockets.lock = __RW_LOCK_UNLOCKED(local->sockets.lock); 1155 local->sockets.lock = __RW_LOCK_UNLOCKED(local->sockets.lock);
1186 local->connecting_sockets.lock = __RW_LOCK_UNLOCKED(local->connecting_sockets.lock); 1156 local->connecting_sockets.lock = __RW_LOCK_UNLOCKED(local->connecting_sockets.lock);
@@ -1193,17 +1163,6 @@ int nfc_llcp_register_device(struct nfc_dev *ndev)
1193 list_add(&llcp_devices, &local->list); 1163 list_add(&llcp_devices, &local->list);
1194 1164
1195 return 0; 1165 return 0;
1196
1197err_rx_wq:
1198 destroy_workqueue(local->rx_wq);
1199
1200err_tx_wq:
1201 destroy_workqueue(local->tx_wq);
1202
1203err_local:
1204 kfree(local);
1205
1206 return 0;
1207} 1166}
1208 1167
1209void nfc_llcp_unregister_device(struct nfc_dev *dev) 1168void nfc_llcp_unregister_device(struct nfc_dev *dev)
diff --git a/net/nfc/llcp/llcp.h b/net/nfc/llcp/llcp.h
index 83b8bba5a280..af395c9ceb03 100644
--- a/net/nfc/llcp/llcp.h
+++ b/net/nfc/llcp/llcp.h
@@ -56,12 +56,9 @@ struct nfc_llcp_local {
56 56
57 struct timer_list link_timer; 57 struct timer_list link_timer;
58 struct sk_buff_head tx_queue; 58 struct sk_buff_head tx_queue;
59 struct workqueue_struct *tx_wq;
60 struct work_struct tx_work; 59 struct work_struct tx_work;
61 struct workqueue_struct *rx_wq;
62 struct work_struct rx_work; 60 struct work_struct rx_work;
63 struct sk_buff *rx_pending; 61 struct sk_buff *rx_pending;
64 struct workqueue_struct *timeout_wq;
65 struct work_struct timeout_work; 62 struct work_struct timeout_work;
66 63
67 u32 target_idx; 64 u32 target_idx;