diff options
Diffstat (limited to 'drivers/misc/ti-st/st_kim.c')
-rw-r--r-- | drivers/misc/ti-st/st_kim.c | 54 |
1 files changed, 16 insertions, 38 deletions
diff --git a/drivers/misc/ti-st/st_kim.c b/drivers/misc/ti-st/st_kim.c index 5996b934abf0..addb6c5a3a3b 100644 --- a/drivers/misc/ti-st/st_kim.c +++ b/drivers/misc/ti-st/st_kim.c @@ -451,9 +451,7 @@ long st_kim_start(void *kim_data) do { /* platform specific enabling code here */ - if (pdata->chip_enable) - pdata->chip_enable(); - + wake_lock(&kim_gdata->core_data->st_wk_lock); /* Configure BT nShutdown to HIGH state */ gpio_set_value(kim_gdata->nshutdown, GPIO_LOW); mdelay(5); /* FIXME: a proper toggle */ @@ -517,8 +515,6 @@ long st_kim_stop(void *kim_data) { long err = 0; struct kim_data_s *kim_gdata = (struct kim_data_s *)kim_data; - struct ti_st_plat_data *pdata = - kim_gdata->kim_pdev->dev.platform_data; INIT_COMPLETION(kim_gdata->ldisc_installed); @@ -547,8 +543,7 @@ long st_kim_stop(void *kim_data) gpio_set_value(kim_gdata->nshutdown, GPIO_LOW); /* platform specific disable */ - if (pdata->chip_disable) - pdata->chip_disable(); + wake_unlock(&kim_gdata->core_data->st_wk_lock); return err; } @@ -707,6 +702,8 @@ static int kim_probe(struct platform_device *pdev) /* refer to itself */ kim_gdata->core_data->kim_data = kim_gdata; + wake_lock_init(&kim_gdata->core_data->st_wk_lock, WAKE_LOCK_SUSPEND, + "st_wake_lock"); /* Claim the chip enable nShutdown gpio from the system */ kim_gdata->nshutdown = pdata->nshutdown_gpio; status = gpio_request(kim_gdata->nshutdown, "kim"); @@ -715,8 +712,6 @@ static int kim_probe(struct platform_device *pdev) return status; } - tegra_gpio_enable(kim_gdata->nshutdown); - /* Configure nShutdown GPIO as output=0 */ status = gpio_direction_output(kim_gdata->nshutdown, 0); if (unlikely(status)) { @@ -774,6 +769,7 @@ static int kim_remove(struct platform_device *pdev) sysfs_remove_group(&pdev->dev.kobj, &uim_attr_grp); pr_info("sysfs entries removed"); + wake_lock_destroy(&kim_gdata->core_data->st_wk_lock); kim_gdata->kim_pdev = NULL; st_core_exit(kim_gdata->core_data); @@ -783,49 +779,31 @@ static int kim_remove(struct platform_device *pdev) return 0; } -static unsigned long retry_suspend; - int kim_suspend(struct platform_device *pdev, pm_message_t state) { - struct ti_st_plat_data *pdata = pdev->dev.platform_data; - int ret; struct kim_data_s *kim_gdata; - struct st_data_s *core_data; - kim_gdata = dev_get_drvdata(&pdev->dev); - core_data = kim_gdata->core_data; - struct uart_state *uart_state; - struct uart_port *uport; - + struct st_data_s *core_data; + struct uart_state *uart_state; + struct uart_port *uport; + kim_gdata = dev_get_drvdata(&pdev->dev); + core_data = kim_gdata->core_data; if (st_ll_getstate(core_data) != ST_LL_INVALID) { - uart_state = core_data->tty->driver_data; - uport = uart_state->uart_port; + uart_state = core_data->tty->driver_data; + uport = uart_state->uart_port; #ifdef CONFIG_BT_TIBLUESLEEP - pr_info(" Bluesleep Start"); - bluesleep_start(uport); + pr_info(" Bluesleep Start"); + bluesleep_start(uport); #endif - - - } - - if (pdata->suspend) { - ret = pdata->suspend(pdev, state); - return ret; } - return -EOPNOTSUPP; + return 0; } int kim_resume(struct platform_device *pdev) { - struct ti_st_plat_data *pdata = pdev->dev.platform_data; - - if (pdata->resume) { - return pdata->resume(pdev); - } - - return -EOPNOTSUPP; + return 0; } /**********************************************************************/ |