aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/misc
diff options
context:
space:
mode:
authorPavan Savoy <pavan_savoy@ti.com>2011-02-04 03:23:15 -0500
committerGreg Kroah-Hartman <gregkh@suse.de>2011-02-04 15:41:21 -0500
commit781a7395d239dbdb59738ca7fe08e71641bf583c (patch)
treefb57da5401614e1b727457b78c7582327be61265 /drivers/misc
parent6d71ba2105a1d8c1712cdfcf46fc6040e4707cb9 (diff)
drivers:misc: ti-st: remove multiple gpio handling
TI shared transport driver previously intended to expose rfkill entries for each of the protocol gpio that the chip would have. However now in case such gpios exist, which requires to be enabled for a specific protocol, the responsibility lay on protocol driver. This patch removes the request/free of multiple gpios, rfkill struct references and also removes the chip_toggle function. Signed-off-by: Pavan Savoy <pavan_savoy@ti.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/misc')
-rw-r--r--drivers/misc/ti-st/st_core.c11
-rw-r--r--drivers/misc/ti-st/st_kim.c117
2 files changed, 24 insertions, 104 deletions
diff --git a/drivers/misc/ti-st/st_core.c b/drivers/misc/ti-st/st_core.c
index f0d24d852078..1847c477c0c0 100644
--- a/drivers/misc/ti-st/st_core.c
+++ b/drivers/misc/ti-st/st_core.c
@@ -515,7 +515,6 @@ long st_register(struct st_proto_s *new_proto)
515 if (test_bit(ST_REG_IN_PROGRESS, &st_gdata->st_state)) { 515 if (test_bit(ST_REG_IN_PROGRESS, &st_gdata->st_state)) {
516 pr_info(" ST_REG_IN_PROGRESS:%d ", new_proto->chnl_id); 516 pr_info(" ST_REG_IN_PROGRESS:%d ", new_proto->chnl_id);
517 /* fw download in progress */ 517 /* fw download in progress */
518 st_kim_chip_toggle(new_proto->chnl_id, KIM_GPIO_ACTIVE);
519 518
520 add_channel_to_table(st_gdata, new_proto); 519 add_channel_to_table(st_gdata, new_proto);
521 st_gdata->protos_registered++; 520 st_gdata->protos_registered++;
@@ -548,10 +547,6 @@ long st_register(struct st_proto_s *new_proto)
548 return -EINVAL; 547 return -EINVAL;
549 } 548 }
550 549
551 /* the chnl_id might require other gpios to be toggled
552 */
553 st_kim_chip_toggle(new_proto->chnl_id, KIM_GPIO_ACTIVE);
554
555 clear_bit(ST_REG_IN_PROGRESS, &st_gdata->st_state); 550 clear_bit(ST_REG_IN_PROGRESS, &st_gdata->st_state);
556 st_recv = st_int_recv; 551 st_recv = st_int_recv;
557 552
@@ -622,12 +617,6 @@ long st_unregister(struct st_proto_s *proto)
622 617
623 st_gdata->protos_registered--; 618 st_gdata->protos_registered--;
624 remove_channel_from_table(st_gdata, proto); 619 remove_channel_from_table(st_gdata, proto);
625
626 /* kim ignores BT in the below function
627 * and handles the rest, BT is toggled
628 * only in kim_start and kim_stop
629 */
630 st_kim_chip_toggle(proto->chnl_id, KIM_GPIO_INACTIVE);
631 spin_unlock_irqrestore(&st_gdata->lock, flags); 620 spin_unlock_irqrestore(&st_gdata->lock, flags);
632 621
633 if ((st_gdata->protos_registered == ST_EMPTY) && 622 if ((st_gdata->protos_registered == ST_EMPTY) &&
diff --git a/drivers/misc/ti-st/st_kim.c b/drivers/misc/ti-st/st_kim.c
index 2c096ccd53b0..9ee4c788aa69 100644
--- a/drivers/misc/ti-st/st_kim.c
+++ b/drivers/misc/ti-st/st_kim.c
@@ -390,49 +390,6 @@ static long download_firmware(struct kim_data_s *kim_gdata)
390 390
391/**********************************************************************/ 391/**********************************************************************/
392/* functions called from ST core */ 392/* functions called from ST core */
393/* function to toggle the GPIO
394 * needs to know whether the GPIO is active high or active low
395 */
396void st_kim_chip_toggle(enum proto_type type, enum kim_gpio_state state)
397{
398 struct platform_device *kim_pdev;
399 struct kim_data_s *kim_gdata;
400 pr_info(" %s ", __func__);
401
402 kim_pdev = st_get_plat_device(0);
403 kim_gdata = dev_get_drvdata(&kim_pdev->dev);
404
405 if (kim_gdata->gpios[type] == -1) {
406 pr_info("gpio not requested for protocol %d", type);
407 return;
408 }
409 switch (type) {
410 case ST_BT:
411 /*Do Nothing */
412 break;
413
414 case ST_FM:
415 if (state == KIM_GPIO_ACTIVE)
416 gpio_set_value(kim_gdata->gpios[ST_FM], GPIO_LOW);
417 else
418 gpio_set_value(kim_gdata->gpios[ST_FM], GPIO_HIGH);
419 break;
420
421 case ST_GPS:
422 if (state == KIM_GPIO_ACTIVE)
423 gpio_set_value(kim_gdata->gpios[ST_GPS], GPIO_HIGH);
424 else
425 gpio_set_value(kim_gdata->gpios[ST_GPS], GPIO_LOW);
426 break;
427
428 case ST_MAX_CHANNELS:
429 default:
430 break;
431 }
432
433 return;
434}
435
436/* called from ST Core, when REG_IN_PROGRESS (registration in progress) 393/* called from ST Core, when REG_IN_PROGRESS (registration in progress)
437 * can be because of 394 * can be because of
438 * 1. response to read local version 395 * 1. response to read local version
@@ -482,9 +439,9 @@ long st_kim_start(void *kim_data)
482 439
483 do { 440 do {
484 /* Configure BT nShutdown to HIGH state */ 441 /* Configure BT nShutdown to HIGH state */
485 gpio_set_value(kim_gdata->gpios[ST_BT], GPIO_LOW); 442 gpio_set_value(kim_gdata->nshutdown, GPIO_LOW);
486 mdelay(5); /* FIXME: a proper toggle */ 443 mdelay(5); /* FIXME: a proper toggle */
487 gpio_set_value(kim_gdata->gpios[ST_BT], GPIO_HIGH); 444 gpio_set_value(kim_gdata->nshutdown, GPIO_HIGH);
488 mdelay(100); 445 mdelay(100);
489 /* re-initialize the completion */ 446 /* re-initialize the completion */
490 INIT_COMPLETION(kim_gdata->ldisc_installed); 447 INIT_COMPLETION(kim_gdata->ldisc_installed);
@@ -552,11 +509,11 @@ long st_kim_stop(void *kim_data)
552 } 509 }
553 510
554 /* By default configure BT nShutdown to LOW state */ 511 /* By default configure BT nShutdown to LOW state */
555 gpio_set_value(kim_gdata->gpios[ST_BT], GPIO_LOW); 512 gpio_set_value(kim_gdata->nshutdown, GPIO_LOW);
556 mdelay(1); 513 mdelay(1);
557 gpio_set_value(kim_gdata->gpios[ST_BT], GPIO_HIGH); 514 gpio_set_value(kim_gdata->nshutdown, GPIO_HIGH);
558 mdelay(1); 515 mdelay(1);
559 gpio_set_value(kim_gdata->gpios[ST_BT], GPIO_LOW); 516 gpio_set_value(kim_gdata->nshutdown, GPIO_LOW);
560 return err; 517 return err;
561} 518}
562 519
@@ -685,10 +642,8 @@ struct dentry *kim_debugfs_dir;
685static int kim_probe(struct platform_device *pdev) 642static int kim_probe(struct platform_device *pdev)
686{ 643{
687 long status; 644 long status;
688 long proto;
689 struct kim_data_s *kim_gdata; 645 struct kim_data_s *kim_gdata;
690 struct ti_st_plat_data *pdata = pdev->dev.platform_data; 646 struct ti_st_plat_data *pdata = pdev->dev.platform_data;
691 long *gpios = pdata->gpios;
692 647
693 if ((pdev->id != -1) && (pdev->id < MAX_ST_DEVICES)) { 648 if ((pdev->id != -1) && (pdev->id < MAX_ST_DEVICES)) {
694 /* multiple devices could exist */ 649 /* multiple devices could exist */
@@ -713,40 +668,19 @@ static int kim_probe(struct platform_device *pdev)
713 /* refer to itself */ 668 /* refer to itself */
714 kim_gdata->core_data->kim_data = kim_gdata; 669 kim_gdata->core_data->kim_data = kim_gdata;
715 670
716 for (proto = 0; proto < ST_MAX_CHANNELS; proto++) { 671 /* Claim the chip enable nShutdown gpio from the system */
717 kim_gdata->gpios[proto] = gpios[proto]; 672 kim_gdata->nshutdown = pdata->nshutdown_gpio;
718 pr_info(" %ld gpio to be requested", gpios[proto]); 673 status = gpio_request(kim_gdata->nshutdown, "kim");
674 if (unlikely(status)) {
675 pr_err(" gpio %ld request failed ", kim_gdata->nshutdown);
676 return status;
719 } 677 }
720 678
721 for (proto = 0; (proto < ST_MAX_CHANNELS) 679 /* Configure nShutdown GPIO as output=0 */
722 && (gpios[proto] != -1); proto++) { 680 status = gpio_direction_output(kim_gdata->nshutdown, 0);
723 /* Claim the Bluetooth/FM/GPIO 681 if (unlikely(status)) {
724 * nShutdown gpio from the system 682 pr_err(" unable to configure gpio %ld", kim_gdata->nshutdown);
725 */ 683 return status;
726 status = gpio_request(gpios[proto], "kim");
727 if (unlikely(status)) {
728 pr_err(" gpio %ld request failed ", gpios[proto]);
729 proto -= 1;
730 while (proto >= 0) {
731 if (gpios[proto] != -1)
732 gpio_free(gpios[proto]);
733 }
734 return status;
735 }
736
737 /* Configure nShutdown GPIO as output=0 */
738 status =
739 gpio_direction_output(gpios[proto], 0);
740 if (unlikely(status)) {
741 pr_err(" unable to configure gpio %ld",
742 gpios[proto]);
743 proto -= 1;
744 while (proto >= 0) {
745 if (gpios[proto] != -1)
746 gpio_free(gpios[proto]);
747 }
748 return status;
749 }
750 } 684 }
751 /* get reference of pdev for request_firmware 685 /* get reference of pdev for request_firmware
752 */ 686 */
@@ -785,23 +719,20 @@ static int kim_remove(struct platform_device *pdev)
785{ 719{
786 /* free the GPIOs requested */ 720 /* free the GPIOs requested */
787 struct ti_st_plat_data *pdata = pdev->dev.platform_data; 721 struct ti_st_plat_data *pdata = pdev->dev.platform_data;
788 long *gpios = pdata->gpios;
789 long proto;
790 struct kim_data_s *kim_gdata; 722 struct kim_data_s *kim_gdata;
791 723
792 kim_gdata = dev_get_drvdata(&pdev->dev); 724 kim_gdata = dev_get_drvdata(&pdev->dev);
793 725
794 for (proto = 0; (proto < ST_MAX_CHANNELS) 726 /* Free the Bluetooth/FM/GPIO
795 && (gpios[proto] != -1); proto++) { 727 * nShutdown gpio from the system
796 /* Claim the Bluetooth/FM/GPIO 728 */
797 * nShutdown gpio from the system 729 gpio_free(pdata->nshutdown_gpio);
798 */ 730 pr_info("nshutdown GPIO Freed");
799 gpio_free(gpios[proto]);
800 }
801 pr_info("kim: GPIO Freed");
802 debugfs_remove_recursive(kim_debugfs_dir);
803 731
732 debugfs_remove_recursive(kim_debugfs_dir);
804 sysfs_remove_group(&pdev->dev.kobj, &uim_attr_grp); 733 sysfs_remove_group(&pdev->dev.kobj, &uim_attr_grp);
734 pr_info("sysfs entries removed");
735
805 kim_gdata->kim_pdev = NULL; 736 kim_gdata->kim_pdev = NULL;
806 st_core_exit(kim_gdata->core_data); 737 st_core_exit(kim_gdata->core_data);
807 738