Pārlūkot izejas kodu

touchscreen: raydium: Both regulators turn off

Add the shutdown callback() in i2c_driver struct.
Keep both regulators should be turn off in release sequence.

Change-Id: Icbfa8d9c9226bce8bf2286f99a18d3385e3b4d45
Signed-off-by: ppadasal <[email protected]>
ppadasal 2 gadi atpakaļ
vecāks
revīzija
ddda48faec
1 mainītis faili ar 38 papildinājumiem un 0 dzēšanām
  1. 38 0
      raydium/raydium_driver.c

+ 38 - 0
raydium/raydium_driver.c

@@ -2391,6 +2391,43 @@ exit_check_functionality_failed:
 
 }
 
+
+void raydium_ts_shutdown(struct i2c_client *client)
+{
+
+#if defined(CONFIG_FB)
+	raydium_unregister_notifier();
+#elif defined(CONFIG_HAS_EARLYSUSPEND)
+	unregister_early_suspend(&g_raydium_ts->early_suspend);
+#elif defined(CONFIG_DRM)
+	if (active_panel)
+		drm_panel_notifier_unregister(active_panel, &g_raydium_ts->fb_notifier);
+#endif/*end of CONFIG_FB*/
+	input_unregister_device(g_raydium_ts->input_dev);
+	input_free_device(g_raydium_ts->input_dev);
+	gpio_free(g_raydium_ts->rst_gpio);
+
+#ifdef CONFIG_RM_SYSFS_DEBUG
+	raydium_release_sysfs(client);
+#endif /*end of CONFIG_RM_SYSFS_DEBUG*/
+
+	free_irq(client->irq, g_raydium_ts);
+
+	if (gpio_is_valid(g_raydium_ts->rst_gpio))
+		gpio_free(g_raydium_ts->rst_gpio);
+
+	if (gpio_is_valid(g_raydium_ts->irq_gpio))
+		gpio_free(g_raydium_ts->irq_gpio);
+
+	cancel_work_sync(&g_raydium_ts->work);
+	destroy_workqueue(g_raydium_ts->workqueue);
+
+	raydium_enable_regulator(g_raydium_ts, false);
+	raydium_get_regulator(g_raydium_ts, false);
+
+	i2c_set_clientdata(client, NULL);
+}
+
 static int raydium_ts_remove(struct i2c_client *client)
 {
 
@@ -2447,6 +2484,7 @@ static const struct of_device_id raydium_match_table[] = {
 static struct i2c_driver raydium_ts_driver = {
 	.probe = raydium_ts_probe,
 	.remove = raydium_ts_remove,
+	.shutdown = raydium_ts_shutdown,
 	.id_table = raydium_ts_id,
 	.driver = {
 		.name = RAYDIUM_NAME,