aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/video/omap2/dss/dss.c52
1 files changed, 26 insertions, 26 deletions
diff --git a/drivers/video/omap2/dss/dss.c b/drivers/video/omap2/dss/dss.c
index d0b3f81b372..bcd4a07adcc 100644
--- a/drivers/video/omap2/dss/dss.c
+++ b/drivers/video/omap2/dss/dss.c
@@ -669,7 +669,6 @@ static int dss_init(void)
669 int r; 669 int r;
670 u32 rev; 670 u32 rev;
671 struct resource *dss_mem; 671 struct resource *dss_mem;
672 struct clk *dpll4_m4_ck;
673 672
674 dss_mem = platform_get_resource(dss.pdev, IORESOURCE_MEM, 0); 673 dss_mem = platform_get_resource(dss.pdev, IORESOURCE_MEM, 0);
675 if (!dss_mem) { 674 if (!dss_mem) {
@@ -715,26 +714,6 @@ static int dss_init(void)
715 REG_FLD_MOD(DSS_CONTROL, 1, 3, 3); /* venc clock 4x enable */ 714 REG_FLD_MOD(DSS_CONTROL, 1, 3, 3); /* venc clock 4x enable */
716 REG_FLD_MOD(DSS_CONTROL, 0, 2, 2); /* venc clock mode = normal */ 715 REG_FLD_MOD(DSS_CONTROL, 0, 2, 2); /* venc clock mode = normal */
717#endif 716#endif
718 if (cpu_is_omap34xx()) {
719 dpll4_m4_ck = clk_get(NULL, "dpll4_m4_ck");
720 if (IS_ERR(dpll4_m4_ck)) {
721 DSSERR("Failed to get dpll4_m4_ck\n");
722 r = PTR_ERR(dpll4_m4_ck);
723 goto fail1;
724 }
725 } else if (cpu_is_omap44xx()) {
726 dpll4_m4_ck = clk_get(NULL, "dpll_per_m5x2_ck");
727 if (IS_ERR(dpll4_m4_ck)) {
728 DSSERR("Failed to get dpll4_m4_ck\n");
729 r = PTR_ERR(dpll4_m4_ck);
730 goto fail1;
731 }
732 } else { /* omap24xx */
733 dpll4_m4_ck = NULL;
734 }
735
736 dss.dpll4_m4_ck = dpll4_m4_ck;
737
738 dss.dsi_clk_source[0] = OMAP_DSS_CLK_SRC_FCK; 717 dss.dsi_clk_source[0] = OMAP_DSS_CLK_SRC_FCK;
739 dss.dsi_clk_source[1] = OMAP_DSS_CLK_SRC_FCK; 718 dss.dsi_clk_source[1] = OMAP_DSS_CLK_SRC_FCK;
740 dss.dispc_clk_source = OMAP_DSS_CLK_SRC_FCK; 719 dss.dispc_clk_source = OMAP_DSS_CLK_SRC_FCK;
@@ -749,17 +728,12 @@ static int dss_init(void)
749 728
750 return 0; 729 return 0;
751 730
752fail1:
753 iounmap(dss.base);
754fail0: 731fail0:
755 return r; 732 return r;
756} 733}
757 734
758static void dss_exit(void) 735static void dss_exit(void)
759{ 736{
760 if (dss.dpll4_m4_ck)
761 clk_put(dss.dpll4_m4_ck);
762
763 iounmap(dss.base); 737 iounmap(dss.base);
764} 738}
765 739
@@ -845,6 +819,7 @@ static int dss_get_clock(struct clk **clock, const char *clk_name)
845static int dss_get_clocks(void) 819static int dss_get_clocks(void)
846{ 820{
847 int r; 821 int r;
822 struct clk *dpll4_m4_ck;
848 struct omap_display_platform_data *pdata = dss.pdev->dev.platform_data; 823 struct omap_display_platform_data *pdata = dss.pdev->dev.platform_data;
849 824
850 dss.dss_ick = NULL; 825 dss.dss_ick = NULL;
@@ -884,6 +859,27 @@ static int dss_get_clocks(void)
884 goto err; 859 goto err;
885 } 860 }
886 861
862 if (cpu_is_omap34xx()) {
863 dpll4_m4_ck = clk_get(NULL, "dpll4_m4_ck");
864 if (IS_ERR(dpll4_m4_ck)) {
865 DSSERR("Failed to get dpll4_m4_ck\n");
866 r = PTR_ERR(dpll4_m4_ck);
867 goto err;
868 }
869 } else if (cpu_is_omap44xx()) {
870 dpll4_m4_ck = clk_get(NULL, "dpll_per_m5x2_ck");
871 if (IS_ERR(dpll4_m4_ck)) {
872 DSSERR("Failed to get dpll_per_m5x2_ck\n");
873 r = PTR_ERR(dpll4_m4_ck);
874 goto err;
875 }
876 } else { /* omap24xx */
877 dpll4_m4_ck = NULL;
878 }
879
880 dss.dpll4_m4_ck = dpll4_m4_ck;
881
882
887 return 0; 883 return 0;
888 884
889err: 885err:
@@ -897,12 +893,16 @@ err:
897 clk_put(dss.dss_tv_fck); 893 clk_put(dss.dss_tv_fck);
898 if (dss.dss_video_fck) 894 if (dss.dss_video_fck)
899 clk_put(dss.dss_video_fck); 895 clk_put(dss.dss_video_fck);
896 if (dss.dpll4_m4_ck)
897 clk_put(dss.dpll4_m4_ck);
900 898
901 return r; 899 return r;
902} 900}
903 901
904static void dss_put_clocks(void) 902static void dss_put_clocks(void)
905{ 903{
904 if (dss.dpll4_m4_ck)
905 clk_put(dss.dpll4_m4_ck);
906 if (dss.dss_video_fck) 906 if (dss.dss_video_fck)
907 clk_put(dss.dss_video_fck); 907 clk_put(dss.dss_video_fck);
908 if (dss.dss_tv_fck) 908 if (dss.dss_tv_fck)