diff options
Diffstat (limited to 'drivers/bluetooth/btmrvl_sdio.c')
-rw-r--r-- | drivers/bluetooth/btmrvl_sdio.c | 135 |
1 files changed, 12 insertions, 123 deletions
diff --git a/drivers/bluetooth/btmrvl_sdio.c b/drivers/bluetooth/btmrvl_sdio.c index 7638f62e8a06..224af53e0fae 100644 --- a/drivers/bluetooth/btmrvl_sdio.c +++ b/drivers/bluetooth/btmrvl_sdio.c | |||
@@ -67,23 +67,17 @@ static int btmrvl_sdio_get_rx_unit(struct btmrvl_sdio_card *card) | |||
67 | u8 reg; | 67 | u8 reg; |
68 | int ret; | 68 | int ret; |
69 | 69 | ||
70 | BT_DBG("Enter"); | ||
71 | |||
72 | reg = sdio_readb(card->func, CARD_RX_UNIT_REG, &ret); | 70 | reg = sdio_readb(card->func, CARD_RX_UNIT_REG, &ret); |
73 | if (!ret) | 71 | if (!ret) |
74 | card->rx_unit = reg; | 72 | card->rx_unit = reg; |
75 | 73 | ||
76 | BT_DBG("Leave"); | ||
77 | |||
78 | return ret; | 74 | return ret; |
79 | } | 75 | } |
80 | 76 | ||
81 | static int btmrvl_sdio_read_fw_status(struct btmrvl_sdio_card *card, u16 *dat) | 77 | static int btmrvl_sdio_read_fw_status(struct btmrvl_sdio_card *card, u16 *dat) |
82 | { | 78 | { |
83 | int ret; | ||
84 | u8 fws0, fws1; | 79 | u8 fws0, fws1; |
85 | 80 | int ret; | |
86 | BT_DBG("Enter"); | ||
87 | 81 | ||
88 | *dat = 0; | 82 | *dat = 0; |
89 | 83 | ||
@@ -92,31 +86,23 @@ static int btmrvl_sdio_read_fw_status(struct btmrvl_sdio_card *card, u16 *dat) | |||
92 | if (!ret) | 86 | if (!ret) |
93 | fws1 = sdio_readb(card->func, CARD_FW_STATUS1_REG, &ret); | 87 | fws1 = sdio_readb(card->func, CARD_FW_STATUS1_REG, &ret); |
94 | 88 | ||
95 | if (ret) { | 89 | if (ret) |
96 | BT_DBG("Leave"); | ||
97 | return -EIO; | 90 | return -EIO; |
98 | } | ||
99 | 91 | ||
100 | *dat = (((u16) fws1) << 8) | fws0; | 92 | *dat = (((u16) fws1) << 8) | fws0; |
101 | 93 | ||
102 | BT_DBG("Leave"); | ||
103 | |||
104 | return 0; | 94 | return 0; |
105 | } | 95 | } |
106 | 96 | ||
107 | static int btmrvl_sdio_read_rx_len(struct btmrvl_sdio_card *card, u16 *dat) | 97 | static int btmrvl_sdio_read_rx_len(struct btmrvl_sdio_card *card, u16 *dat) |
108 | { | 98 | { |
109 | int ret; | ||
110 | u8 reg; | 99 | u8 reg; |
111 | 100 | int ret; | |
112 | BT_DBG("Enter"); | ||
113 | 101 | ||
114 | reg = sdio_readb(card->func, CARD_RX_LEN_REG, &ret); | 102 | reg = sdio_readb(card->func, CARD_RX_LEN_REG, &ret); |
115 | if (!ret) | 103 | if (!ret) |
116 | *dat = (u16) reg << card->rx_unit; | 104 | *dat = (u16) reg << card->rx_unit; |
117 | 105 | ||
118 | BT_DBG("Leave"); | ||
119 | |||
120 | return ret; | 106 | return ret; |
121 | } | 107 | } |
122 | 108 | ||
@@ -125,64 +111,48 @@ static int btmrvl_sdio_enable_host_int_mask(struct btmrvl_sdio_card *card, | |||
125 | { | 111 | { |
126 | int ret; | 112 | int ret; |
127 | 113 | ||
128 | BT_DBG("Enter"); | ||
129 | |||
130 | sdio_writeb(card->func, mask, HOST_INT_MASK_REG, &ret); | 114 | sdio_writeb(card->func, mask, HOST_INT_MASK_REG, &ret); |
131 | if (ret) { | 115 | if (ret) { |
132 | BT_ERR("Unable to enable the host interrupt!"); | 116 | BT_ERR("Unable to enable the host interrupt!"); |
133 | ret = -EIO; | 117 | ret = -EIO; |
134 | } | 118 | } |
135 | 119 | ||
136 | BT_DBG("Leave"); | ||
137 | |||
138 | return ret; | 120 | return ret; |
139 | } | 121 | } |
140 | 122 | ||
141 | static int btmrvl_sdio_disable_host_int_mask(struct btmrvl_sdio_card *card, | 123 | static int btmrvl_sdio_disable_host_int_mask(struct btmrvl_sdio_card *card, |
142 | u8 mask) | 124 | u8 mask) |
143 | { | 125 | { |
144 | int ret; | ||
145 | u8 host_int_mask; | 126 | u8 host_int_mask; |
146 | 127 | int ret; | |
147 | BT_DBG("Enter"); | ||
148 | 128 | ||
149 | host_int_mask = sdio_readb(card->func, HOST_INT_MASK_REG, &ret); | 129 | host_int_mask = sdio_readb(card->func, HOST_INT_MASK_REG, &ret); |
150 | if (ret) { | 130 | if (ret) |
151 | ret = -EIO; | 131 | return -EIO; |
152 | goto done; | ||
153 | } | ||
154 | 132 | ||
155 | host_int_mask &= ~mask; | 133 | host_int_mask &= ~mask; |
156 | 134 | ||
157 | sdio_writeb(card->func, host_int_mask, HOST_INT_MASK_REG, &ret); | 135 | sdio_writeb(card->func, host_int_mask, HOST_INT_MASK_REG, &ret); |
158 | if (ret < 0) { | 136 | if (ret < 0) { |
159 | BT_ERR("Unable to disable the host interrupt!"); | 137 | BT_ERR("Unable to disable the host interrupt!"); |
160 | ret = -EIO; | 138 | return -EIO; |
161 | goto done; | ||
162 | } | 139 | } |
163 | 140 | ||
164 | ret = 0; | 141 | return 0; |
165 | |||
166 | done: | ||
167 | BT_DBG("Leave"); | ||
168 | |||
169 | return ret; | ||
170 | } | 142 | } |
171 | 143 | ||
172 | static int btmrvl_sdio_poll_card_status(struct btmrvl_sdio_card *card, u8 bits) | 144 | static int btmrvl_sdio_poll_card_status(struct btmrvl_sdio_card *card, u8 bits) |
173 | { | 145 | { |
174 | unsigned int tries; | 146 | unsigned int tries; |
175 | int ret; | ||
176 | u8 status; | 147 | u8 status; |
177 | 148 | int ret; | |
178 | BT_DBG("Enter"); | ||
179 | 149 | ||
180 | for (tries = 0; tries < MAX_POLL_TRIES * 1000; tries++) { | 150 | for (tries = 0; tries < MAX_POLL_TRIES * 1000; tries++) { |
181 | status = sdio_readb(card->func, CARD_STATUS_REG, &ret); | 151 | status = sdio_readb(card->func, CARD_STATUS_REG, &ret); |
182 | if (ret) | 152 | if (ret) |
183 | goto failed; | 153 | goto failed; |
184 | if ((status & bits) == bits) | 154 | if ((status & bits) == bits) |
185 | goto done; | 155 | return ret; |
186 | 156 | ||
187 | udelay(1); | 157 | udelay(1); |
188 | } | 158 | } |
@@ -192,9 +162,6 @@ static int btmrvl_sdio_poll_card_status(struct btmrvl_sdio_card *card, u8 bits) | |||
192 | failed: | 162 | failed: |
193 | BT_ERR("FAILED! ret=%d", ret); | 163 | BT_ERR("FAILED! ret=%d", ret); |
194 | 164 | ||
195 | done: | ||
196 | BT_DBG("Leave"); | ||
197 | |||
198 | return ret; | 165 | return ret; |
199 | } | 166 | } |
200 | 167 | ||
@@ -205,8 +172,6 @@ static int btmrvl_sdio_verify_fw_download(struct btmrvl_sdio_card *card, | |||
205 | u16 firmwarestat; | 172 | u16 firmwarestat; |
206 | unsigned int tries; | 173 | unsigned int tries; |
207 | 174 | ||
208 | BT_DBG("Enter"); | ||
209 | |||
210 | /* Wait for firmware to become ready */ | 175 | /* Wait for firmware to become ready */ |
211 | for (tries = 0; tries < pollnum; tries++) { | 176 | for (tries = 0; tries < pollnum; tries++) { |
212 | if (btmrvl_sdio_read_fw_status(card, &firmwarestat) < 0) | 177 | if (btmrvl_sdio_read_fw_status(card, &firmwarestat) < 0) |
@@ -220,8 +185,6 @@ static int btmrvl_sdio_verify_fw_download(struct btmrvl_sdio_card *card, | |||
220 | } | 185 | } |
221 | } | 186 | } |
222 | 187 | ||
223 | BT_DBG("Leave"); | ||
224 | |||
225 | return ret; | 188 | return ret; |
226 | } | 189 | } |
227 | 190 | ||
@@ -235,8 +198,6 @@ static int btmrvl_sdio_download_helper(struct btmrvl_sdio_card *card) | |||
235 | u8 *helperbuf; | 198 | u8 *helperbuf; |
236 | u32 tx_len; | 199 | u32 tx_len; |
237 | 200 | ||
238 | BT_DBG("Enter"); | ||
239 | |||
240 | ret = request_firmware(&fw_helper, card->helper, | 201 | ret = request_firmware(&fw_helper, card->helper, |
241 | &card->func->dev); | 202 | &card->func->dev); |
242 | if ((ret < 0) || !fw_helper) { | 203 | if ((ret < 0) || !fw_helper) { |
@@ -326,8 +287,6 @@ done: | |||
326 | if (fw_helper) | 287 | if (fw_helper) |
327 | release_firmware(fw_helper); | 288 | release_firmware(fw_helper); |
328 | 289 | ||
329 | BT_DBG("Leave"); | ||
330 | |||
331 | return ret; | 290 | return ret; |
332 | } | 291 | } |
333 | 292 | ||
@@ -343,8 +302,6 @@ static int btmrvl_sdio_download_fw_w_helper(struct btmrvl_sdio_card *card) | |||
343 | u16 len; | 302 | u16 len; |
344 | int txlen = 0, tx_blocks = 0, count = 0; | 303 | int txlen = 0, tx_blocks = 0, count = 0; |
345 | 304 | ||
346 | BT_DBG("Enter"); | ||
347 | |||
348 | ret = request_firmware(&fw_firmware, card->firmware, | 305 | ret = request_firmware(&fw_firmware, card->firmware, |
349 | &card->func->dev); | 306 | &card->func->dev); |
350 | if ((ret < 0) || !fw_firmware) { | 307 | if ((ret < 0) || !fw_firmware) { |
@@ -479,8 +436,6 @@ done: | |||
479 | if (fw_firmware) | 436 | if (fw_firmware) |
480 | release_firmware(fw_firmware); | 437 | release_firmware(fw_firmware); |
481 | 438 | ||
482 | BT_DBG("Leave"); | ||
483 | |||
484 | return ret; | 439 | return ret; |
485 | } | 440 | } |
486 | 441 | ||
@@ -494,8 +449,6 @@ static int btmrvl_sdio_card_to_host(struct btmrvl_private *priv) | |||
494 | struct hci_dev *hdev = priv->btmrvl_dev.hcidev; | 449 | struct hci_dev *hdev = priv->btmrvl_dev.hcidev; |
495 | struct btmrvl_sdio_card *card = priv->btmrvl_dev.card; | 450 | struct btmrvl_sdio_card *card = priv->btmrvl_dev.card; |
496 | 451 | ||
497 | BT_DBG("Enter"); | ||
498 | |||
499 | if (!card || !card->func) { | 452 | if (!card || !card->func) { |
500 | BT_ERR("card or function is NULL!"); | 453 | BT_ERR("card or function is NULL!"); |
501 | ret = -EINVAL; | 454 | ret = -EINVAL; |
@@ -596,8 +549,6 @@ exit: | |||
596 | kfree_skb(skb); | 549 | kfree_skb(skb); |
597 | } | 550 | } |
598 | 551 | ||
599 | BT_DBG("Leave"); | ||
600 | |||
601 | return ret; | 552 | return ret; |
602 | } | 553 | } |
603 | 554 | ||
@@ -607,8 +558,6 @@ static int btmrvl_sdio_get_int_status(struct btmrvl_private *priv, u8 * ireg) | |||
607 | u8 sdio_ireg = 0; | 558 | u8 sdio_ireg = 0; |
608 | struct btmrvl_sdio_card *card = priv->btmrvl_dev.card; | 559 | struct btmrvl_sdio_card *card = priv->btmrvl_dev.card; |
609 | 560 | ||
610 | BT_DBG("Enter"); | ||
611 | |||
612 | *ireg = 0; | 561 | *ireg = 0; |
613 | 562 | ||
614 | sdio_ireg = sdio_readb(card->func, HOST_INTSTATUS_REG, &ret); | 563 | sdio_ireg = sdio_readb(card->func, HOST_INTSTATUS_REG, &ret); |
@@ -653,8 +602,6 @@ static int btmrvl_sdio_get_int_status(struct btmrvl_private *priv, u8 * ireg) | |||
653 | ret = 0; | 602 | ret = 0; |
654 | 603 | ||
655 | done: | 604 | done: |
656 | BT_DBG("Leave"); | ||
657 | |||
658 | return ret; | 605 | return ret; |
659 | } | 606 | } |
660 | 607 | ||
@@ -665,8 +612,6 @@ static void btmrvl_sdio_interrupt(struct sdio_func *func) | |||
665 | struct btmrvl_sdio_card *card; | 612 | struct btmrvl_sdio_card *card; |
666 | u8 ireg = 0; | 613 | u8 ireg = 0; |
667 | 614 | ||
668 | BT_DBG("Enter"); | ||
669 | |||
670 | card = sdio_get_drvdata(func); | 615 | card = sdio_get_drvdata(func); |
671 | if (card && card->priv) { | 616 | if (card && card->priv) { |
672 | priv = card->priv; | 617 | priv = card->priv; |
@@ -679,8 +624,6 @@ static void btmrvl_sdio_interrupt(struct sdio_func *func) | |||
679 | 624 | ||
680 | btmrvl_interrupt(priv); | 625 | btmrvl_interrupt(priv); |
681 | } | 626 | } |
682 | |||
683 | BT_DBG("Leave"); | ||
684 | } | 627 | } |
685 | 628 | ||
686 | static int btmrvl_sdio_register_dev(struct btmrvl_sdio_card *card) | 629 | static int btmrvl_sdio_register_dev(struct btmrvl_sdio_card *card) |
@@ -689,8 +632,6 @@ static int btmrvl_sdio_register_dev(struct btmrvl_sdio_card *card) | |||
689 | u8 reg; | 632 | u8 reg; |
690 | int ret = 0; | 633 | int ret = 0; |
691 | 634 | ||
692 | BT_DBG("Enter"); | ||
693 | |||
694 | if (!card || !card->func) { | 635 | if (!card || !card->func) { |
695 | BT_ERR("Error: card or function is NULL!"); | 636 | BT_ERR("Error: card or function is NULL!"); |
696 | ret = -EINVAL; | 637 | ret = -EINVAL; |
@@ -752,7 +693,6 @@ static int btmrvl_sdio_register_dev(struct btmrvl_sdio_card *card) | |||
752 | 693 | ||
753 | sdio_release_host(func); | 694 | sdio_release_host(func); |
754 | 695 | ||
755 | BT_DBG("Leave"); | ||
756 | return 0; | 696 | return 0; |
757 | 697 | ||
758 | release_irq: | 698 | release_irq: |
@@ -765,14 +705,11 @@ release_host: | |||
765 | sdio_release_host(func); | 705 | sdio_release_host(func); |
766 | 706 | ||
767 | failed: | 707 | failed: |
768 | BT_DBG("Leave"); | ||
769 | return ret; | 708 | return ret; |
770 | } | 709 | } |
771 | 710 | ||
772 | static int btmrvl_sdio_unregister_dev(struct btmrvl_sdio_card *card) | 711 | static int btmrvl_sdio_unregister_dev(struct btmrvl_sdio_card *card) |
773 | { | 712 | { |
774 | BT_DBG("Enter"); | ||
775 | |||
776 | if (card && card->func) { | 713 | if (card && card->func) { |
777 | sdio_claim_host(card->func); | 714 | sdio_claim_host(card->func); |
778 | sdio_release_irq(card->func); | 715 | sdio_release_irq(card->func); |
@@ -781,8 +718,6 @@ static int btmrvl_sdio_unregister_dev(struct btmrvl_sdio_card *card) | |||
781 | sdio_set_drvdata(card->func, NULL); | 718 | sdio_set_drvdata(card->func, NULL); |
782 | } | 719 | } |
783 | 720 | ||
784 | BT_DBG("Leave"); | ||
785 | |||
786 | return 0; | 721 | return 0; |
787 | } | 722 | } |
788 | 723 | ||
@@ -790,12 +725,8 @@ static int btmrvl_sdio_enable_host_int(struct btmrvl_sdio_card *card) | |||
790 | { | 725 | { |
791 | int ret; | 726 | int ret; |
792 | 727 | ||
793 | BT_DBG("Enter"); | 728 | if (!card || !card->func) |
794 | |||
795 | if (!card || !card->func) { | ||
796 | BT_DBG("Leave"); | ||
797 | return -EINVAL; | 729 | return -EINVAL; |
798 | } | ||
799 | 730 | ||
800 | sdio_claim_host(card->func); | 731 | sdio_claim_host(card->func); |
801 | 732 | ||
@@ -805,8 +736,6 @@ static int btmrvl_sdio_enable_host_int(struct btmrvl_sdio_card *card) | |||
805 | 736 | ||
806 | sdio_release_host(card->func); | 737 | sdio_release_host(card->func); |
807 | 738 | ||
808 | BT_DBG("Leave"); | ||
809 | |||
810 | return ret; | 739 | return ret; |
811 | } | 740 | } |
812 | 741 | ||
@@ -814,12 +743,8 @@ static int btmrvl_sdio_disable_host_int(struct btmrvl_sdio_card *card) | |||
814 | { | 743 | { |
815 | int ret; | 744 | int ret; |
816 | 745 | ||
817 | BT_DBG("Enter"); | 746 | if (!card || !card->func) |
818 | |||
819 | if (!card || !card->func) { | ||
820 | BT_DBG("Leave"); | ||
821 | return -EINVAL; | 747 | return -EINVAL; |
822 | } | ||
823 | 748 | ||
824 | sdio_claim_host(card->func); | 749 | sdio_claim_host(card->func); |
825 | 750 | ||
@@ -827,8 +752,6 @@ static int btmrvl_sdio_disable_host_int(struct btmrvl_sdio_card *card) | |||
827 | 752 | ||
828 | sdio_release_host(card->func); | 753 | sdio_release_host(card->func); |
829 | 754 | ||
830 | BT_DBG("Leave"); | ||
831 | |||
832 | return ret; | 755 | return ret; |
833 | } | 756 | } |
834 | 757 | ||
@@ -844,11 +767,8 @@ static int btmrvl_sdio_host_to_card(struct btmrvl_private *priv, | |||
844 | void *tmpbuf = NULL; | 767 | void *tmpbuf = NULL; |
845 | int tmpbufsz; | 768 | int tmpbufsz; |
846 | 769 | ||
847 | BT_DBG("Enter"); | ||
848 | |||
849 | if (!card || !card->func) { | 770 | if (!card || !card->func) { |
850 | BT_ERR("card or function is NULL!"); | 771 | BT_ERR("card or function is NULL!"); |
851 | BT_DBG("Leave"); | ||
852 | return -EINVAL; | 772 | return -EINVAL; |
853 | } | 773 | } |
854 | 774 | ||
@@ -886,8 +806,6 @@ static int btmrvl_sdio_host_to_card(struct btmrvl_private *priv, | |||
886 | exit: | 806 | exit: |
887 | sdio_release_host(card->func); | 807 | sdio_release_host(card->func); |
888 | 808 | ||
889 | BT_DBG("Leave"); | ||
890 | |||
891 | return ret; | 809 | return ret; |
892 | } | 810 | } |
893 | 811 | ||
@@ -895,11 +813,8 @@ static int btmrvl_sdio_download_fw(struct btmrvl_sdio_card *card) | |||
895 | { | 813 | { |
896 | int ret = 0; | 814 | int ret = 0; |
897 | 815 | ||
898 | BT_DBG("Enter"); | ||
899 | |||
900 | if (!card || !card->func) { | 816 | if (!card || !card->func) { |
901 | BT_ERR("card or function is NULL!"); | 817 | BT_ERR("card or function is NULL!"); |
902 | BT_DBG("Leave"); | ||
903 | return -EINVAL; | 818 | return -EINVAL; |
904 | } | 819 | } |
905 | sdio_claim_host(card->func); | 820 | sdio_claim_host(card->func); |
@@ -931,8 +846,6 @@ static int btmrvl_sdio_download_fw(struct btmrvl_sdio_card *card) | |||
931 | done: | 846 | done: |
932 | sdio_release_host(card->func); | 847 | sdio_release_host(card->func); |
933 | 848 | ||
934 | BT_DBG("Leave"); | ||
935 | |||
936 | return ret; | 849 | return ret; |
937 | } | 850 | } |
938 | 851 | ||
@@ -941,11 +854,8 @@ static int btmrvl_sdio_wakeup_fw(struct btmrvl_private *priv) | |||
941 | struct btmrvl_sdio_card *card = priv->btmrvl_dev.card; | 854 | struct btmrvl_sdio_card *card = priv->btmrvl_dev.card; |
942 | int ret = 0; | 855 | int ret = 0; |
943 | 856 | ||
944 | BT_DBG("Enter"); | ||
945 | |||
946 | if (!card || !card->func) { | 857 | if (!card || !card->func) { |
947 | BT_ERR("card or function is NULL!"); | 858 | BT_ERR("card or function is NULL!"); |
948 | BT_DBG("Leave"); | ||
949 | return -EINVAL; | 859 | return -EINVAL; |
950 | } | 860 | } |
951 | 861 | ||
@@ -957,8 +867,6 @@ static int btmrvl_sdio_wakeup_fw(struct btmrvl_private *priv) | |||
957 | 867 | ||
958 | BT_DBG("wake up firmware"); | 868 | BT_DBG("wake up firmware"); |
959 | 869 | ||
960 | BT_DBG("Leave"); | ||
961 | |||
962 | return ret; | 870 | return ret; |
963 | } | 871 | } |
964 | 872 | ||
@@ -969,8 +877,6 @@ static int btmrvl_sdio_probe(struct sdio_func *func, | |||
969 | struct btmrvl_private *priv = NULL; | 877 | struct btmrvl_private *priv = NULL; |
970 | struct btmrvl_sdio_card *card = NULL; | 878 | struct btmrvl_sdio_card *card = NULL; |
971 | 879 | ||
972 | BT_DBG("Enter"); | ||
973 | |||
974 | BT_INFO("vendor=0x%x, device=0x%x, class=%d, fn=%d", | 880 | BT_INFO("vendor=0x%x, device=0x%x, class=%d, fn=%d", |
975 | id->vendor, id->device, id->class, func->num); | 881 | id->vendor, id->device, id->class, func->num); |
976 | 882 | ||
@@ -1022,8 +928,6 @@ static int btmrvl_sdio_probe(struct sdio_func *func, | |||
1022 | 928 | ||
1023 | btmrvl_send_module_cfg_cmd(priv, MODULE_BRINGUP_REQ); | 929 | btmrvl_send_module_cfg_cmd(priv, MODULE_BRINGUP_REQ); |
1024 | 930 | ||
1025 | BT_DBG("Leave"); | ||
1026 | |||
1027 | return 0; | 931 | return 0; |
1028 | 932 | ||
1029 | disable_host_int: | 933 | disable_host_int: |
@@ -1033,8 +937,6 @@ unreg_dev: | |||
1033 | free_card: | 937 | free_card: |
1034 | kfree(card); | 938 | kfree(card); |
1035 | done: | 939 | done: |
1036 | BT_DBG("Leave"); | ||
1037 | |||
1038 | return ret; | 940 | return ret; |
1039 | } | 941 | } |
1040 | 942 | ||
@@ -1042,8 +944,6 @@ static void btmrvl_sdio_remove(struct sdio_func *func) | |||
1042 | { | 944 | { |
1043 | struct btmrvl_sdio_card *card; | 945 | struct btmrvl_sdio_card *card; |
1044 | 946 | ||
1045 | BT_DBG("Enter"); | ||
1046 | |||
1047 | if (func) { | 947 | if (func) { |
1048 | card = sdio_get_drvdata(func); | 948 | card = sdio_get_drvdata(func); |
1049 | if (card) { | 949 | if (card) { |
@@ -1061,8 +961,6 @@ static void btmrvl_sdio_remove(struct sdio_func *func) | |||
1061 | kfree(card); | 961 | kfree(card); |
1062 | } | 962 | } |
1063 | } | 963 | } |
1064 | |||
1065 | BT_DBG("Leave"); | ||
1066 | } | 964 | } |
1067 | 965 | ||
1068 | static struct sdio_driver bt_mrvl_sdio = { | 966 | static struct sdio_driver bt_mrvl_sdio = { |
@@ -1074,32 +972,23 @@ static struct sdio_driver bt_mrvl_sdio = { | |||
1074 | 972 | ||
1075 | static int btmrvl_sdio_init_module(void) | 973 | static int btmrvl_sdio_init_module(void) |
1076 | { | 974 | { |
1077 | BT_DBG("Enter"); | ||
1078 | |||
1079 | if (sdio_register_driver(&bt_mrvl_sdio) != 0) { | 975 | if (sdio_register_driver(&bt_mrvl_sdio) != 0) { |
1080 | BT_ERR("SDIO Driver Registration Failed"); | 976 | BT_ERR("SDIO Driver Registration Failed"); |
1081 | BT_DBG("Leave"); | ||
1082 | return -ENODEV; | 977 | return -ENODEV; |
1083 | } | 978 | } |
1084 | 979 | ||
1085 | /* Clear the flag in case user removes the card. */ | 980 | /* Clear the flag in case user removes the card. */ |
1086 | user_rmmod = 0; | 981 | user_rmmod = 0; |
1087 | 982 | ||
1088 | BT_DBG("Leave"); | ||
1089 | |||
1090 | return 0; | 983 | return 0; |
1091 | } | 984 | } |
1092 | 985 | ||
1093 | static void btmrvl_sdio_exit_module(void) | 986 | static void btmrvl_sdio_exit_module(void) |
1094 | { | 987 | { |
1095 | BT_DBG("Enter"); | ||
1096 | |||
1097 | /* Set the flag as user is removing this module. */ | 988 | /* Set the flag as user is removing this module. */ |
1098 | user_rmmod = 1; | 989 | user_rmmod = 1; |
1099 | 990 | ||
1100 | sdio_unregister_driver(&bt_mrvl_sdio); | 991 | sdio_unregister_driver(&bt_mrvl_sdio); |
1101 | |||
1102 | BT_DBG("Leave"); | ||
1103 | } | 992 | } |
1104 | 993 | ||
1105 | module_init(btmrvl_sdio_init_module); | 994 | module_init(btmrvl_sdio_init_module); |