diff options
Diffstat (limited to 'drivers/video/omap2/displays')
-rw-r--r-- | drivers/video/omap2/displays/panel-taal.c | 44 |
1 files changed, 40 insertions, 4 deletions
diff --git a/drivers/video/omap2/displays/panel-taal.c b/drivers/video/omap2/displays/panel-taal.c index d2e2ac7444e0..8fbb94e2bf5d 100644 --- a/drivers/video/omap2/displays/panel-taal.c +++ b/drivers/video/omap2/displays/panel-taal.c | |||
@@ -490,6 +490,22 @@ static struct attribute_group taal_attr_group = { | |||
490 | .attrs = taal_attrs, | 490 | .attrs = taal_attrs, |
491 | }; | 491 | }; |
492 | 492 | ||
493 | static void taal_hw_reset(struct omap_dss_device *dssdev) | ||
494 | { | ||
495 | if (dssdev->reset_gpio == -1) | ||
496 | return; | ||
497 | |||
498 | gpio_set_value(dssdev->reset_gpio, 1); | ||
499 | udelay(10); | ||
500 | /* reset the panel */ | ||
501 | gpio_set_value(dssdev->reset_gpio, 0); | ||
502 | /* assert reset for at least 10us */ | ||
503 | udelay(10); | ||
504 | gpio_set_value(dssdev->reset_gpio, 1); | ||
505 | /* wait 5ms after releasing reset */ | ||
506 | msleep(5); | ||
507 | } | ||
508 | |||
493 | static int taal_probe(struct omap_dss_device *dssdev) | 509 | static int taal_probe(struct omap_dss_device *dssdev) |
494 | { | 510 | { |
495 | struct backlight_properties props; | 511 | struct backlight_properties props; |
@@ -527,6 +543,8 @@ static int taal_probe(struct omap_dss_device *dssdev) | |||
527 | 543 | ||
528 | dev_set_drvdata(&dssdev->dev, td); | 544 | dev_set_drvdata(&dssdev->dev, td); |
529 | 545 | ||
546 | taal_hw_reset(dssdev); | ||
547 | |||
530 | /* if no platform set_backlight() defined, presume DSI backlight | 548 | /* if no platform set_backlight() defined, presume DSI backlight |
531 | * control */ | 549 | * control */ |
532 | memset(&props, 0, sizeof(struct backlight_properties)); | 550 | memset(&props, 0, sizeof(struct backlight_properties)); |
@@ -628,6 +646,9 @@ static void taal_remove(struct omap_dss_device *dssdev) | |||
628 | cancel_delayed_work_sync(&td->esd_work); | 646 | cancel_delayed_work_sync(&td->esd_work); |
629 | destroy_workqueue(td->esd_wq); | 647 | destroy_workqueue(td->esd_wq); |
630 | 648 | ||
649 | /* reset, to be sure that the panel is in a valid state */ | ||
650 | taal_hw_reset(dssdev); | ||
651 | |||
631 | kfree(td); | 652 | kfree(td); |
632 | } | 653 | } |
633 | 654 | ||
@@ -654,6 +675,8 @@ static int taal_power_on(struct omap_dss_device *dssdev) | |||
654 | goto err0; | 675 | goto err0; |
655 | } | 676 | } |
656 | 677 | ||
678 | taal_hw_reset(dssdev); | ||
679 | |||
657 | omapdss_dsi_vc_enable_hs(TCH, false); | 680 | omapdss_dsi_vc_enable_hs(TCH, false); |
658 | 681 | ||
659 | r = taal_sleep_out(td); | 682 | r = taal_sleep_out(td); |
@@ -704,6 +727,10 @@ static int taal_power_on(struct omap_dss_device *dssdev) | |||
704 | 727 | ||
705 | return 0; | 728 | return 0; |
706 | err: | 729 | err: |
730 | dev_err(&dssdev->dev, "error while enabling panel, issuing HW reset\n"); | ||
731 | |||
732 | taal_hw_reset(dssdev); | ||
733 | |||
707 | omapdss_dsi_display_disable(dssdev); | 734 | omapdss_dsi_display_disable(dssdev); |
708 | err0: | 735 | err0: |
709 | dsi_bus_unlock(); | 736 | dsi_bus_unlock(); |
@@ -716,16 +743,24 @@ err0: | |||
716 | static void taal_power_off(struct omap_dss_device *dssdev) | 743 | static void taal_power_off(struct omap_dss_device *dssdev) |
717 | { | 744 | { |
718 | struct taal_data *td = dev_get_drvdata(&dssdev->dev); | 745 | struct taal_data *td = dev_get_drvdata(&dssdev->dev); |
746 | int r; | ||
719 | 747 | ||
720 | dsi_bus_lock(); | 748 | dsi_bus_lock(); |
721 | 749 | ||
722 | cancel_delayed_work(&td->esd_work); | 750 | cancel_delayed_work(&td->esd_work); |
723 | 751 | ||
724 | taal_dcs_write_0(DCS_DISPLAY_OFF); | 752 | r = taal_dcs_write_0(DCS_DISPLAY_OFF); |
725 | taal_sleep_in(td); | 753 | if (!r) { |
754 | r = taal_sleep_in(td); | ||
755 | /* wait a bit so that the message goes through */ | ||
756 | msleep(10); | ||
757 | } | ||
726 | 758 | ||
727 | /* wait a bit so that the message goes through */ | 759 | if (r) { |
728 | msleep(10); | 760 | dev_err(&dssdev->dev, |
761 | "error disabling panel, issuing HW reset\n"); | ||
762 | taal_hw_reset(dssdev); | ||
763 | } | ||
729 | 764 | ||
730 | omapdss_dsi_display_disable(dssdev); | 765 | omapdss_dsi_display_disable(dssdev); |
731 | 766 | ||
@@ -1186,6 +1221,7 @@ err: | |||
1186 | dev_err(&dssdev->dev, "performing LCD reset\n"); | 1221 | dev_err(&dssdev->dev, "performing LCD reset\n"); |
1187 | 1222 | ||
1188 | taal_power_off(dssdev); | 1223 | taal_power_off(dssdev); |
1224 | taal_hw_reset(dssdev); | ||
1189 | taal_power_on(dssdev); | 1225 | taal_power_on(dssdev); |
1190 | 1226 | ||
1191 | dsi_bus_unlock(); | 1227 | dsi_bus_unlock(); |