diff options
Diffstat (limited to 'drivers/bluetooth')
-rw-r--r-- | drivers/bluetooth/btmrvl_main.c | 107 | ||||
-rw-r--r-- | drivers/bluetooth/btmrvl_sdio.c | 135 |
2 files changed, 23 insertions, 219 deletions
diff --git a/drivers/bluetooth/btmrvl_main.c b/drivers/bluetooth/btmrvl_main.c index bbc4446c4b4b..e605563b4eaa 100644 --- a/drivers/bluetooth/btmrvl_main.c +++ b/drivers/bluetooth/btmrvl_main.c | |||
@@ -32,8 +32,6 @@ | |||
32 | */ | 32 | */ |
33 | void btmrvl_interrupt(struct btmrvl_private *priv) | 33 | void btmrvl_interrupt(struct btmrvl_private *priv) |
34 | { | 34 | { |
35 | BT_DBG("Enter"); | ||
36 | |||
37 | priv->adapter->ps_state = PS_AWAKE; | 35 | priv->adapter->ps_state = PS_AWAKE; |
38 | 36 | ||
39 | priv->adapter->wakeup_tries = 0; | 37 | priv->adapter->wakeup_tries = 0; |
@@ -41,8 +39,6 @@ void btmrvl_interrupt(struct btmrvl_private *priv) | |||
41 | priv->adapter->int_count++; | 39 | priv->adapter->int_count++; |
42 | 40 | ||
43 | wake_up_interruptible(&priv->main_thread.wait_q); | 41 | wake_up_interruptible(&priv->main_thread.wait_q); |
44 | |||
45 | BT_DBG("Leave"); | ||
46 | } | 42 | } |
47 | EXPORT_SYMBOL_GPL(btmrvl_interrupt); | 43 | EXPORT_SYMBOL_GPL(btmrvl_interrupt); |
48 | 44 | ||
@@ -52,8 +48,6 @@ void btmrvl_check_evtpkt(struct btmrvl_private *priv, struct sk_buff *skb) | |||
52 | struct hci_ev_cmd_complete *ec; | 48 | struct hci_ev_cmd_complete *ec; |
53 | u16 opcode, ocf; | 49 | u16 opcode, ocf; |
54 | 50 | ||
55 | BT_DBG("Enter"); | ||
56 | |||
57 | if (hdr->evt == HCI_EV_CMD_COMPLETE) { | 51 | if (hdr->evt == HCI_EV_CMD_COMPLETE) { |
58 | ec = (void *) (skb->data + HCI_EVENT_HDR_SIZE); | 52 | ec = (void *) (skb->data + HCI_EVENT_HDR_SIZE); |
59 | opcode = __le16_to_cpu(ec->opcode); | 53 | opcode = __le16_to_cpu(ec->opcode); |
@@ -65,8 +59,6 @@ void btmrvl_check_evtpkt(struct btmrvl_private *priv, struct sk_buff *skb) | |||
65 | wake_up_interruptible(&priv->adapter->cmd_wait_q); | 59 | wake_up_interruptible(&priv->adapter->cmd_wait_q); |
66 | } | 60 | } |
67 | } | 61 | } |
68 | |||
69 | BT_DBG("Leave"); | ||
70 | } | 62 | } |
71 | EXPORT_SYMBOL_GPL(btmrvl_check_evtpkt); | 63 | EXPORT_SYMBOL_GPL(btmrvl_check_evtpkt); |
72 | 64 | ||
@@ -76,8 +68,6 @@ int btmrvl_process_event(struct btmrvl_private *priv, struct sk_buff *skb) | |||
76 | struct btmrvl_event *event; | 68 | struct btmrvl_event *event; |
77 | u8 ret = 0; | 69 | u8 ret = 0; |
78 | 70 | ||
79 | BT_DBG("Enter"); | ||
80 | |||
81 | event = (struct btmrvl_event *) skb->data; | 71 | event = (struct btmrvl_event *) skb->data; |
82 | if (event->ec != 0xff) { | 72 | if (event->ec != 0xff) { |
83 | BT_DBG("Not Marvell Event=%x", event->ec); | 73 | BT_DBG("Not Marvell Event=%x", event->ec); |
@@ -151,8 +141,6 @@ exit: | |||
151 | if (!ret) | 141 | if (!ret) |
152 | kfree_skb(skb); | 142 | kfree_skb(skb); |
153 | 143 | ||
154 | BT_DBG("Leave"); | ||
155 | |||
156 | return ret; | 144 | return ret; |
157 | } | 145 | } |
158 | EXPORT_SYMBOL_GPL(btmrvl_process_event); | 146 | EXPORT_SYMBOL_GPL(btmrvl_process_event); |
@@ -161,15 +149,12 @@ int btmrvl_send_module_cfg_cmd(struct btmrvl_private *priv, int subcmd) | |||
161 | { | 149 | { |
162 | struct sk_buff *skb; | 150 | struct sk_buff *skb; |
163 | struct btmrvl_cmd *cmd; | 151 | struct btmrvl_cmd *cmd; |
164 | u8 ret = 0; | 152 | int ret = 0; |
165 | |||
166 | BT_DBG("Enter"); | ||
167 | 153 | ||
168 | skb = bt_skb_alloc(sizeof(*cmd), GFP_ATOMIC); | 154 | skb = bt_skb_alloc(sizeof(*cmd), GFP_ATOMIC); |
169 | if (skb == NULL) { | 155 | if (skb == NULL) { |
170 | BT_ERR("No free skb"); | 156 | BT_ERR("No free skb"); |
171 | ret = -ENOMEM; | 157 | return -ENOMEM; |
172 | goto exit; | ||
173 | } | 158 | } |
174 | 159 | ||
175 | cmd = (struct btmrvl_cmd *) skb_put(skb, sizeof(*cmd)); | 160 | cmd = (struct btmrvl_cmd *) skb_put(skb, sizeof(*cmd)); |
@@ -200,9 +185,6 @@ int btmrvl_send_module_cfg_cmd(struct btmrvl_private *priv, int subcmd) | |||
200 | 185 | ||
201 | BT_DBG("module cfg Command done"); | 186 | BT_DBG("module cfg Command done"); |
202 | 187 | ||
203 | exit: | ||
204 | BT_DBG("Leave"); | ||
205 | |||
206 | return ret; | 188 | return ret; |
207 | } | 189 | } |
208 | EXPORT_SYMBOL_GPL(btmrvl_send_module_cfg_cmd); | 190 | EXPORT_SYMBOL_GPL(btmrvl_send_module_cfg_cmd); |
@@ -211,15 +193,12 @@ static int btmrvl_enable_hs(struct btmrvl_private *priv) | |||
211 | { | 193 | { |
212 | struct sk_buff *skb; | 194 | struct sk_buff *skb; |
213 | struct btmrvl_cmd *cmd; | 195 | struct btmrvl_cmd *cmd; |
214 | u8 ret = 0; | 196 | int ret = 0; |
215 | |||
216 | BT_DBG("Enter"); | ||
217 | 197 | ||
218 | skb = bt_skb_alloc(sizeof(*cmd), GFP_ATOMIC); | 198 | skb = bt_skb_alloc(sizeof(*cmd), GFP_ATOMIC); |
219 | if (skb == NULL) { | 199 | if (skb == NULL) { |
220 | BT_ERR("No free skb"); | 200 | BT_ERR("No free skb"); |
221 | ret = -ENOMEM; | 201 | return -ENOMEM; |
222 | goto exit; | ||
223 | } | 202 | } |
224 | 203 | ||
225 | cmd = (struct btmrvl_cmd *) skb_put(skb, sizeof(*cmd)); | 204 | cmd = (struct btmrvl_cmd *) skb_put(skb, sizeof(*cmd)); |
@@ -244,9 +223,6 @@ static int btmrvl_enable_hs(struct btmrvl_private *priv) | |||
244 | priv->adapter->wakeup_tries); | 223 | priv->adapter->wakeup_tries); |
245 | } | 224 | } |
246 | 225 | ||
247 | exit: | ||
248 | BT_DBG("Leave"); | ||
249 | |||
250 | return ret; | 226 | return ret; |
251 | } | 227 | } |
252 | 228 | ||
@@ -254,9 +230,7 @@ int btmrvl_prepare_command(struct btmrvl_private *priv) | |||
254 | { | 230 | { |
255 | struct sk_buff *skb = NULL; | 231 | struct sk_buff *skb = NULL; |
256 | struct btmrvl_cmd *cmd; | 232 | struct btmrvl_cmd *cmd; |
257 | u8 ret = 0; | 233 | int ret = 0; |
258 | |||
259 | BT_DBG("Enter"); | ||
260 | 234 | ||
261 | if (priv->btmrvl_dev.hscfgcmd) { | 235 | if (priv->btmrvl_dev.hscfgcmd) { |
262 | priv->btmrvl_dev.hscfgcmd = 0; | 236 | priv->btmrvl_dev.hscfgcmd = 0; |
@@ -264,8 +238,7 @@ int btmrvl_prepare_command(struct btmrvl_private *priv) | |||
264 | skb = bt_skb_alloc(sizeof(*cmd), GFP_ATOMIC); | 238 | skb = bt_skb_alloc(sizeof(*cmd), GFP_ATOMIC); |
265 | if (skb == NULL) { | 239 | if (skb == NULL) { |
266 | BT_ERR("No free skb"); | 240 | BT_ERR("No free skb"); |
267 | ret = -ENOMEM; | 241 | return -ENOMEM; |
268 | goto exit; | ||
269 | } | 242 | } |
270 | 243 | ||
271 | cmd = (struct btmrvl_cmd *) skb_put(skb, sizeof(*cmd)); | 244 | cmd = (struct btmrvl_cmd *) skb_put(skb, sizeof(*cmd)); |
@@ -289,8 +262,7 @@ int btmrvl_prepare_command(struct btmrvl_private *priv) | |||
289 | skb = bt_skb_alloc(sizeof(*cmd), GFP_ATOMIC); | 262 | skb = bt_skb_alloc(sizeof(*cmd), GFP_ATOMIC); |
290 | if (skb == NULL) { | 263 | if (skb == NULL) { |
291 | BT_ERR("No free skb"); | 264 | BT_ERR("No free skb"); |
292 | ret = -ENOMEM; | 265 | return -ENOMEM; |
293 | goto exit; | ||
294 | } | 266 | } |
295 | 267 | ||
296 | cmd = (struct btmrvl_cmd *) skb_put(skb, sizeof(*cmd)); | 268 | cmd = (struct btmrvl_cmd *) skb_put(skb, sizeof(*cmd)); |
@@ -321,27 +293,19 @@ int btmrvl_prepare_command(struct btmrvl_private *priv) | |||
321 | } | 293 | } |
322 | } | 294 | } |
323 | 295 | ||
324 | exit: | ||
325 | BT_DBG("Leave"); | ||
326 | |||
327 | return ret; | 296 | return ret; |
328 | } | 297 | } |
329 | 298 | ||
330 | static int btmrvl_tx_pkt(struct btmrvl_private *priv, struct sk_buff *skb) | 299 | static int btmrvl_tx_pkt(struct btmrvl_private *priv, struct sk_buff *skb) |
331 | { | 300 | { |
332 | u8 ret = 0; | 301 | int ret = 0; |
333 | 302 | ||
334 | BT_DBG("Enter"); | 303 | if (!skb || !skb->data) |
335 | |||
336 | if (!skb || !skb->data) { | ||
337 | BT_DBG("Leave"); | ||
338 | return -EINVAL; | 304 | return -EINVAL; |
339 | } | ||
340 | 305 | ||
341 | if (!skb->len || ((skb->len + BTM_HEADER_LEN) > BTM_UPLD_SIZE)) { | 306 | if (!skb->len || ((skb->len + BTM_HEADER_LEN) > BTM_UPLD_SIZE)) { |
342 | BT_ERR("Tx Error: Bad skb length %d : %d", | 307 | BT_ERR("Tx Error: Bad skb length %d : %d", |
343 | skb->len, BTM_UPLD_SIZE); | 308 | skb->len, BTM_UPLD_SIZE); |
344 | BT_DBG("Leave"); | ||
345 | return -EINVAL; | 309 | return -EINVAL; |
346 | } | 310 | } |
347 | 311 | ||
@@ -353,7 +317,6 @@ static int btmrvl_tx_pkt(struct btmrvl_private *priv, struct sk_buff *skb) | |||
353 | BT_ERR("Tx Error: realloc_headroom failed %d", | 317 | BT_ERR("Tx Error: realloc_headroom failed %d", |
354 | BTM_HEADER_LEN); | 318 | BTM_HEADER_LEN); |
355 | skb = tmp; | 319 | skb = tmp; |
356 | BT_DBG("Leave"); | ||
357 | return -EINVAL; | 320 | return -EINVAL; |
358 | } | 321 | } |
359 | 322 | ||
@@ -375,52 +338,35 @@ static int btmrvl_tx_pkt(struct btmrvl_private *priv, struct sk_buff *skb) | |||
375 | if (priv->hw_host_to_card) | 338 | if (priv->hw_host_to_card) |
376 | ret = priv->hw_host_to_card(priv, skb->data, skb->len); | 339 | ret = priv->hw_host_to_card(priv, skb->data, skb->len); |
377 | 340 | ||
378 | BT_DBG("Leave"); | ||
379 | |||
380 | return ret; | 341 | return ret; |
381 | } | 342 | } |
382 | 343 | ||
383 | static void btmrvl_init_adapter(struct btmrvl_private *priv) | 344 | static void btmrvl_init_adapter(struct btmrvl_private *priv) |
384 | { | 345 | { |
385 | BT_DBG("Enter"); | ||
386 | |||
387 | skb_queue_head_init(&priv->adapter->tx_queue); | 346 | skb_queue_head_init(&priv->adapter->tx_queue); |
388 | 347 | ||
389 | priv->adapter->ps_state = PS_AWAKE; | 348 | priv->adapter->ps_state = PS_AWAKE; |
390 | 349 | ||
391 | init_waitqueue_head(&priv->adapter->cmd_wait_q); | 350 | init_waitqueue_head(&priv->adapter->cmd_wait_q); |
392 | |||
393 | BT_DBG("Leave"); | ||
394 | } | 351 | } |
395 | 352 | ||
396 | static void btmrvl_free_adapter(struct btmrvl_private *priv) | 353 | static void btmrvl_free_adapter(struct btmrvl_private *priv) |
397 | { | 354 | { |
398 | BT_DBG("Enter"); | ||
399 | |||
400 | skb_queue_purge(&priv->adapter->tx_queue); | 355 | skb_queue_purge(&priv->adapter->tx_queue); |
401 | 356 | ||
402 | kfree(priv->adapter); | 357 | kfree(priv->adapter); |
403 | 358 | ||
404 | priv->adapter = NULL; | 359 | priv->adapter = NULL; |
405 | |||
406 | BT_DBG("Leave"); | ||
407 | } | 360 | } |
408 | 361 | ||
409 | static int btmrvl_ioctl(struct hci_dev *hdev, | 362 | static int btmrvl_ioctl(struct hci_dev *hdev, |
410 | unsigned int cmd, unsigned long arg) | 363 | unsigned int cmd, unsigned long arg) |
411 | { | 364 | { |
412 | BT_DBG("Enter"); | ||
413 | |||
414 | BT_DBG("Leave"); | ||
415 | |||
416 | return -ENOIOCTLCMD; | 365 | return -ENOIOCTLCMD; |
417 | } | 366 | } |
418 | 367 | ||
419 | static void btmrvl_destruct(struct hci_dev *hdev) | 368 | static void btmrvl_destruct(struct hci_dev *hdev) |
420 | { | 369 | { |
421 | BT_DBG("Enter"); | ||
422 | |||
423 | BT_DBG("Leave"); | ||
424 | } | 370 | } |
425 | 371 | ||
426 | static int btmrvl_send_frame(struct sk_buff *skb) | 372 | static int btmrvl_send_frame(struct sk_buff *skb) |
@@ -428,11 +374,10 @@ static int btmrvl_send_frame(struct sk_buff *skb) | |||
428 | struct hci_dev *hdev = (struct hci_dev *) skb->dev; | 374 | struct hci_dev *hdev = (struct hci_dev *) skb->dev; |
429 | struct btmrvl_private *priv = NULL; | 375 | struct btmrvl_private *priv = NULL; |
430 | 376 | ||
431 | BT_DBG("Enter: type=%d, len=%d", skb->pkt_type, skb->len); | 377 | BT_DBG("type=%d, len=%d", skb->pkt_type, skb->len); |
432 | 378 | ||
433 | if (!hdev || !hdev->driver_data) { | 379 | if (!hdev || !hdev->driver_data) { |
434 | BT_ERR("Frame for unknown HCI device"); | 380 | BT_ERR("Frame for unknown HCI device"); |
435 | BT_DBG("Leave"); | ||
436 | return -ENODEV; | 381 | return -ENODEV; |
437 | } | 382 | } |
438 | 383 | ||
@@ -441,7 +386,6 @@ static int btmrvl_send_frame(struct sk_buff *skb) | |||
441 | BT_ERR("Failed testing HCI_RUNING, flags=%lx", hdev->flags); | 386 | BT_ERR("Failed testing HCI_RUNING, flags=%lx", hdev->flags); |
442 | print_hex_dump_bytes("data: ", DUMP_PREFIX_OFFSET, | 387 | print_hex_dump_bytes("data: ", DUMP_PREFIX_OFFSET, |
443 | skb->data, skb->len); | 388 | skb->data, skb->len); |
444 | BT_DBG("Leave"); | ||
445 | return -EBUSY; | 389 | return -EBUSY; |
446 | } | 390 | } |
447 | 391 | ||
@@ -463,8 +407,6 @@ static int btmrvl_send_frame(struct sk_buff *skb) | |||
463 | 407 | ||
464 | wake_up_interruptible(&priv->main_thread.wait_q); | 408 | wake_up_interruptible(&priv->main_thread.wait_q); |
465 | 409 | ||
466 | BT_DBG("Leave"); | ||
467 | |||
468 | return 0; | 410 | return 0; |
469 | } | 411 | } |
470 | 412 | ||
@@ -472,12 +414,8 @@ static int btmrvl_flush(struct hci_dev *hdev) | |||
472 | { | 414 | { |
473 | struct btmrvl_private *priv = hdev->driver_data; | 415 | struct btmrvl_private *priv = hdev->driver_data; |
474 | 416 | ||
475 | BT_DBG("Enter"); | ||
476 | |||
477 | skb_queue_purge(&priv->adapter->tx_queue); | 417 | skb_queue_purge(&priv->adapter->tx_queue); |
478 | 418 | ||
479 | BT_DBG("Leave"); | ||
480 | |||
481 | return 0; | 419 | return 0; |
482 | } | 420 | } |
483 | 421 | ||
@@ -485,28 +423,18 @@ static int btmrvl_close(struct hci_dev *hdev) | |||
485 | { | 423 | { |
486 | struct btmrvl_private *priv = hdev->driver_data; | 424 | struct btmrvl_private *priv = hdev->driver_data; |
487 | 425 | ||
488 | BT_DBG("Enter"); | 426 | if (!test_and_clear_bit(HCI_RUNNING, &hdev->flags)) |
489 | |||
490 | if (!test_and_clear_bit(HCI_RUNNING, &hdev->flags)) { | ||
491 | BT_DBG("Leave"); | ||
492 | return 0; | 427 | return 0; |
493 | } | ||
494 | 428 | ||
495 | skb_queue_purge(&priv->adapter->tx_queue); | 429 | skb_queue_purge(&priv->adapter->tx_queue); |
496 | 430 | ||
497 | BT_DBG("Leave"); | ||
498 | |||
499 | return 0; | 431 | return 0; |
500 | } | 432 | } |
501 | 433 | ||
502 | static int btmrvl_open(struct hci_dev *hdev) | 434 | static int btmrvl_open(struct hci_dev *hdev) |
503 | { | 435 | { |
504 | BT_DBG("Enter"); | ||
505 | |||
506 | set_bit(HCI_RUNNING, &hdev->flags); | 436 | set_bit(HCI_RUNNING, &hdev->flags); |
507 | 437 | ||
508 | BT_DBG("Leave"); | ||
509 | |||
510 | return 0; | 438 | return 0; |
511 | } | 439 | } |
512 | 440 | ||
@@ -523,8 +451,6 @@ static int btmrvl_service_main_thread(void *data) | |||
523 | struct sk_buff *skb; | 451 | struct sk_buff *skb; |
524 | ulong flags; | 452 | ulong flags; |
525 | 453 | ||
526 | BT_DBG("Enter"); | ||
527 | |||
528 | init_waitqueue_entry(&wait, current); | 454 | init_waitqueue_entry(&wait, current); |
529 | 455 | ||
530 | current->flags |= PF_NOFREEZE; | 456 | current->flags |= PF_NOFREEZE; |
@@ -582,8 +508,6 @@ static int btmrvl_service_main_thread(void *data) | |||
582 | } | 508 | } |
583 | } | 509 | } |
584 | 510 | ||
585 | BT_DBG("Leave"); | ||
586 | |||
587 | return 0; | 511 | return 0; |
588 | } | 512 | } |
589 | 513 | ||
@@ -593,8 +517,6 @@ struct btmrvl_private *btmrvl_add_card(void *card) | |||
593 | struct btmrvl_private *priv; | 517 | struct btmrvl_private *priv; |
594 | int ret; | 518 | int ret; |
595 | 519 | ||
596 | BT_DBG("Enter"); | ||
597 | |||
598 | priv = kzalloc(sizeof(*priv), GFP_KERNEL); | 520 | priv = kzalloc(sizeof(*priv), GFP_KERNEL); |
599 | if (!priv) { | 521 | if (!priv) { |
600 | BT_ERR("Can not allocate priv"); | 522 | BT_ERR("Can not allocate priv"); |
@@ -649,7 +571,6 @@ struct btmrvl_private *btmrvl_add_card(void *card) | |||
649 | btmrvl_debugfs_init(hdev); | 571 | btmrvl_debugfs_init(hdev); |
650 | #endif | 572 | #endif |
651 | 573 | ||
652 | BT_DBG("Leave"); | ||
653 | return priv; | 574 | return priv; |
654 | 575 | ||
655 | err_hci_register_dev: | 576 | err_hci_register_dev: |
@@ -665,8 +586,6 @@ err_adapter: | |||
665 | kfree(priv); | 586 | kfree(priv); |
666 | 587 | ||
667 | err_priv: | 588 | err_priv: |
668 | BT_DBG("Leave"); | ||
669 | |||
670 | return NULL; | 589 | return NULL; |
671 | } | 590 | } |
672 | EXPORT_SYMBOL_GPL(btmrvl_add_card); | 591 | EXPORT_SYMBOL_GPL(btmrvl_add_card); |
@@ -675,8 +594,6 @@ int btmrvl_remove_card(struct btmrvl_private *priv) | |||
675 | { | 594 | { |
676 | struct hci_dev *hdev; | 595 | struct hci_dev *hdev; |
677 | 596 | ||
678 | BT_DBG("Enter"); | ||
679 | |||
680 | hdev = priv->btmrvl_dev.hcidev; | 597 | hdev = priv->btmrvl_dev.hcidev; |
681 | 598 | ||
682 | wake_up_interruptible(&priv->adapter->cmd_wait_q); | 599 | wake_up_interruptible(&priv->adapter->cmd_wait_q); |
@@ -697,8 +614,6 @@ int btmrvl_remove_card(struct btmrvl_private *priv) | |||
697 | 614 | ||
698 | kfree(priv); | 615 | kfree(priv); |
699 | 616 | ||
700 | BT_DBG("Leave"); | ||
701 | |||
702 | return 0; | 617 | return 0; |
703 | } | 618 | } |
704 | EXPORT_SYMBOL_GPL(btmrvl_remove_card); | 619 | EXPORT_SYMBOL_GPL(btmrvl_remove_card); |
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); |