diff options
Diffstat (limited to 'drivers/bluetooth')
-rw-r--r-- | drivers/bluetooth/btmrvl_drv.h | 1 | ||||
-rw-r--r-- | drivers/bluetooth/btmrvl_main.c | 75 | ||||
-rw-r--r-- | drivers/bluetooth/btmrvl_sdio.c | 7 |
3 files changed, 50 insertions, 33 deletions
diff --git a/drivers/bluetooth/btmrvl_drv.h b/drivers/bluetooth/btmrvl_drv.h index da68c62a22cc..bf6d54fcbeaf 100644 --- a/drivers/bluetooth/btmrvl_drv.h +++ b/drivers/bluetooth/btmrvl_drv.h | |||
@@ -126,6 +126,7 @@ struct btmrvl_event { | |||
126 | 126 | ||
127 | /* Prototype of global function */ | 127 | /* Prototype of global function */ |
128 | 128 | ||
129 | int btmrvl_register_hdev(struct btmrvl_private *priv); | ||
129 | struct btmrvl_private *btmrvl_add_card(void *card); | 130 | struct btmrvl_private *btmrvl_add_card(void *card); |
130 | int btmrvl_remove_card(struct btmrvl_private *priv); | 131 | int btmrvl_remove_card(struct btmrvl_private *priv); |
131 | 132 | ||
diff --git a/drivers/bluetooth/btmrvl_main.c b/drivers/bluetooth/btmrvl_main.c index 87d0d3d5ae54..ec48bfe9e279 100644 --- a/drivers/bluetooth/btmrvl_main.c +++ b/drivers/bluetooth/btmrvl_main.c | |||
@@ -524,47 +524,20 @@ static int btmrvl_service_main_thread(void *data) | |||
524 | return 0; | 524 | return 0; |
525 | } | 525 | } |
526 | 526 | ||
527 | struct btmrvl_private *btmrvl_add_card(void *card) | 527 | int btmrvl_register_hdev(struct btmrvl_private *priv) |
528 | { | 528 | { |
529 | struct hci_dev *hdev = NULL; | 529 | struct hci_dev *hdev = NULL; |
530 | struct btmrvl_private *priv; | ||
531 | int ret; | 530 | int ret; |
532 | 531 | ||
533 | priv = kzalloc(sizeof(*priv), GFP_KERNEL); | ||
534 | if (!priv) { | ||
535 | BT_ERR("Can not allocate priv"); | ||
536 | goto err_priv; | ||
537 | } | ||
538 | |||
539 | priv->adapter = kzalloc(sizeof(*priv->adapter), GFP_KERNEL); | ||
540 | if (!priv->adapter) { | ||
541 | BT_ERR("Allocate buffer for btmrvl_adapter failed!"); | ||
542 | goto err_adapter; | ||
543 | } | ||
544 | |||
545 | btmrvl_init_adapter(priv); | ||
546 | |||
547 | hdev = hci_alloc_dev(); | 532 | hdev = hci_alloc_dev(); |
548 | if (!hdev) { | 533 | if (!hdev) { |
549 | BT_ERR("Can not allocate HCI device"); | 534 | BT_ERR("Can not allocate HCI device"); |
550 | goto err_hdev; | 535 | goto err_hdev; |
551 | } | 536 | } |
552 | 537 | ||
553 | BT_DBG("Starting kthread..."); | ||
554 | priv->main_thread.priv = priv; | ||
555 | spin_lock_init(&priv->driver_lock); | ||
556 | |||
557 | init_waitqueue_head(&priv->main_thread.wait_q); | ||
558 | priv->main_thread.task = kthread_run(btmrvl_service_main_thread, | ||
559 | &priv->main_thread, "btmrvl_main_service"); | ||
560 | |||
561 | priv->btmrvl_dev.hcidev = hdev; | 538 | priv->btmrvl_dev.hcidev = hdev; |
562 | priv->btmrvl_dev.card = card; | ||
563 | |||
564 | hdev->driver_data = priv; | 539 | hdev->driver_data = priv; |
565 | 540 | ||
566 | priv->btmrvl_dev.tx_dnld_rdy = true; | ||
567 | |||
568 | hdev->bus = HCI_SDIO; | 541 | hdev->bus = HCI_SDIO; |
569 | hdev->open = btmrvl_open; | 542 | hdev->open = btmrvl_open; |
570 | hdev->close = btmrvl_close; | 543 | hdev->close = btmrvl_close; |
@@ -574,6 +547,8 @@ struct btmrvl_private *btmrvl_add_card(void *card) | |||
574 | hdev->ioctl = btmrvl_ioctl; | 547 | hdev->ioctl = btmrvl_ioctl; |
575 | hdev->owner = THIS_MODULE; | 548 | hdev->owner = THIS_MODULE; |
576 | 549 | ||
550 | btmrvl_send_module_cfg_cmd(priv, MODULE_BRINGUP_REQ); | ||
551 | |||
577 | ret = hci_register_dev(hdev); | 552 | ret = hci_register_dev(hdev); |
578 | if (ret < 0) { | 553 | if (ret < 0) { |
579 | BT_ERR("Can not register HCI device"); | 554 | BT_ERR("Can not register HCI device"); |
@@ -584,16 +559,52 @@ struct btmrvl_private *btmrvl_add_card(void *card) | |||
584 | btmrvl_debugfs_init(hdev); | 559 | btmrvl_debugfs_init(hdev); |
585 | #endif | 560 | #endif |
586 | 561 | ||
587 | return priv; | 562 | return 0; |
588 | 563 | ||
589 | err_hci_register_dev: | 564 | err_hci_register_dev: |
590 | /* Stop the thread servicing the interrupts */ | ||
591 | kthread_stop(priv->main_thread.task); | ||
592 | |||
593 | hci_free_dev(hdev); | 565 | hci_free_dev(hdev); |
594 | 566 | ||
595 | err_hdev: | 567 | err_hdev: |
568 | /* Stop the thread servicing the interrupts */ | ||
569 | kthread_stop(priv->main_thread.task); | ||
570 | |||
596 | btmrvl_free_adapter(priv); | 571 | btmrvl_free_adapter(priv); |
572 | kfree(priv); | ||
573 | |||
574 | return -ENOMEM; | ||
575 | } | ||
576 | EXPORT_SYMBOL_GPL(btmrvl_register_hdev); | ||
577 | |||
578 | struct btmrvl_private *btmrvl_add_card(void *card) | ||
579 | { | ||
580 | struct btmrvl_private *priv; | ||
581 | |||
582 | priv = kzalloc(sizeof(*priv), GFP_KERNEL); | ||
583 | if (!priv) { | ||
584 | BT_ERR("Can not allocate priv"); | ||
585 | goto err_priv; | ||
586 | } | ||
587 | |||
588 | priv->adapter = kzalloc(sizeof(*priv->adapter), GFP_KERNEL); | ||
589 | if (!priv->adapter) { | ||
590 | BT_ERR("Allocate buffer for btmrvl_adapter failed!"); | ||
591 | goto err_adapter; | ||
592 | } | ||
593 | |||
594 | btmrvl_init_adapter(priv); | ||
595 | |||
596 | BT_DBG("Starting kthread..."); | ||
597 | priv->main_thread.priv = priv; | ||
598 | spin_lock_init(&priv->driver_lock); | ||
599 | |||
600 | init_waitqueue_head(&priv->main_thread.wait_q); | ||
601 | priv->main_thread.task = kthread_run(btmrvl_service_main_thread, | ||
602 | &priv->main_thread, "btmrvl_main_service"); | ||
603 | |||
604 | priv->btmrvl_dev.card = card; | ||
605 | priv->btmrvl_dev.tx_dnld_rdy = true; | ||
606 | |||
607 | return priv; | ||
597 | 608 | ||
598 | err_adapter: | 609 | err_adapter: |
599 | kfree(priv); | 610 | kfree(priv); |
diff --git a/drivers/bluetooth/btmrvl_sdio.c b/drivers/bluetooth/btmrvl_sdio.c index 0dba76aa2232..df0773ebd9e4 100644 --- a/drivers/bluetooth/btmrvl_sdio.c +++ b/drivers/bluetooth/btmrvl_sdio.c | |||
@@ -931,7 +931,12 @@ static int btmrvl_sdio_probe(struct sdio_func *func, | |||
931 | priv->hw_host_to_card = btmrvl_sdio_host_to_card; | 931 | priv->hw_host_to_card = btmrvl_sdio_host_to_card; |
932 | priv->hw_wakeup_firmware = btmrvl_sdio_wakeup_fw; | 932 | priv->hw_wakeup_firmware = btmrvl_sdio_wakeup_fw; |
933 | 933 | ||
934 | btmrvl_send_module_cfg_cmd(priv, MODULE_BRINGUP_REQ); | 934 | if (btmrvl_register_hdev(priv)) { |
935 | BT_ERR("Register hdev failed!"); | ||
936 | ret = -ENODEV; | ||
937 | goto disable_host_int; | ||
938 | } | ||
939 | |||
935 | priv->btmrvl_dev.psmode = 1; | 940 | priv->btmrvl_dev.psmode = 1; |
936 | btmrvl_enable_ps(priv); | 941 | btmrvl_enable_ps(priv); |
937 | 942 | ||