diff options
Diffstat (limited to 'drivers/video/omap2')
-rw-r--r-- | drivers/video/omap2/dss/hdmi.c | 18 | ||||
-rw-r--r-- | drivers/video/omap2/dss/ti_hdmi.h | 15 | ||||
-rw-r--r-- | drivers/video/omap2/dss/ti_hdmi_4xxx_ip.c | 20 |
3 files changed, 30 insertions, 23 deletions
diff --git a/drivers/video/omap2/dss/hdmi.c b/drivers/video/omap2/dss/hdmi.c index 2a8a55d7c7d..5afc51bc618 100644 --- a/drivers/video/omap2/dss/hdmi.c +++ b/drivers/video/omap2/dss/hdmi.c | |||
@@ -366,7 +366,7 @@ static void hdmi_read_edid(struct omap_video_timings *dp) | |||
366 | memset(hdmi.edid, 0, HDMI_EDID_MAX_LENGTH); | 366 | memset(hdmi.edid, 0, HDMI_EDID_MAX_LENGTH); |
367 | 367 | ||
368 | if (!hdmi.edid_set) | 368 | if (!hdmi.edid_set) |
369 | ret = read_edid(&hdmi.ip_data, hdmi.edid, | 369 | ret = ti_hdmi_4xxx_read_edid(&hdmi.ip_data, hdmi.edid, |
370 | HDMI_EDID_MAX_LENGTH); | 370 | HDMI_EDID_MAX_LENGTH); |
371 | if (!ret) { | 371 | if (!ret) { |
372 | if (!memcmp(hdmi.edid, edid_header, sizeof(edid_header))) { | 372 | if (!memcmp(hdmi.edid, edid_header, sizeof(edid_header))) { |
@@ -480,16 +480,16 @@ static int hdmi_power_on(struct omap_dss_device *dssdev) | |||
480 | 480 | ||
481 | hdmi_compute_pll(dssdev, phy, &hdmi.ip_data.pll_data); | 481 | hdmi_compute_pll(dssdev, phy, &hdmi.ip_data.pll_data); |
482 | 482 | ||
483 | hdmi_wp_video_start(&hdmi.ip_data, 0); | 483 | ti_hdmi_4xxx_wp_video_start(&hdmi.ip_data, 0); |
484 | 484 | ||
485 | /* config the PLL and PHY hdmi_set_pll_pwrfirst */ | 485 | /* config the PLL and PHY hdmi_set_pll_pwrfirst */ |
486 | r = hdmi_pll_program(&hdmi.ip_data); | 486 | r = ti_hdmi_4xxx_pll_enable(&hdmi.ip_data); |
487 | if (r) { | 487 | if (r) { |
488 | DSSDBG("Failed to lock PLL\n"); | 488 | DSSDBG("Failed to lock PLL\n"); |
489 | goto err; | 489 | goto err; |
490 | } | 490 | } |
491 | 491 | ||
492 | r = hdmi_phy_init(&hdmi.ip_data); | 492 | r = ti_hdmi_4xxx_phy_enable(&hdmi.ip_data); |
493 | if (r) { | 493 | if (r) { |
494 | DSSDBG("Failed to start PHY\n"); | 494 | DSSDBG("Failed to start PHY\n"); |
495 | goto err; | 495 | goto err; |
@@ -497,7 +497,7 @@ static int hdmi_power_on(struct omap_dss_device *dssdev) | |||
497 | 497 | ||
498 | hdmi.ip_data.cfg.cm.mode = hdmi.mode; | 498 | hdmi.ip_data.cfg.cm.mode = hdmi.mode; |
499 | hdmi.ip_data.cfg.cm.code = hdmi.code; | 499 | hdmi.ip_data.cfg.cm.code = hdmi.code; |
500 | hdmi_basic_configure(&hdmi.ip_data); | 500 | ti_hdmi_4xxx_basic_configure(&hdmi.ip_data); |
501 | 501 | ||
502 | /* Make selection of HDMI in DSS */ | 502 | /* Make selection of HDMI in DSS */ |
503 | dss_select_hdmi_venc_clk_source(DSS_HDMI_M_PCLK); | 503 | dss_select_hdmi_venc_clk_source(DSS_HDMI_M_PCLK); |
@@ -519,7 +519,7 @@ static int hdmi_power_on(struct omap_dss_device *dssdev) | |||
519 | 519 | ||
520 | dispc_mgr_enable(OMAP_DSS_CHANNEL_DIGIT, 1); | 520 | dispc_mgr_enable(OMAP_DSS_CHANNEL_DIGIT, 1); |
521 | 521 | ||
522 | hdmi_wp_video_start(&hdmi.ip_data, 1); | 522 | ti_hdmi_4xxx_wp_video_start(&hdmi.ip_data, 1); |
523 | 523 | ||
524 | return 0; | 524 | return 0; |
525 | err: | 525 | err: |
@@ -531,9 +531,9 @@ static void hdmi_power_off(struct omap_dss_device *dssdev) | |||
531 | { | 531 | { |
532 | dispc_mgr_enable(OMAP_DSS_CHANNEL_DIGIT, 0); | 532 | dispc_mgr_enable(OMAP_DSS_CHANNEL_DIGIT, 0); |
533 | 533 | ||
534 | hdmi_wp_video_start(&hdmi.ip_data, 0); | 534 | ti_hdmi_4xxx_wp_video_start(&hdmi.ip_data, 0); |
535 | hdmi_phy_off(&hdmi.ip_data); | 535 | ti_hdmi_4xxx_phy_disable(&hdmi.ip_data); |
536 | hdmi_set_pll_pwr(&hdmi.ip_data, HDMI_PLLPWRCMD_ALLOFF); | 536 | ti_hdmi_4xxx_pll_disable(&hdmi.ip_data); |
537 | hdmi_runtime_put(); | 537 | hdmi_runtime_put(); |
538 | 538 | ||
539 | hdmi.edid_set = 0; | 539 | hdmi.edid_set = 0; |
diff --git a/drivers/video/omap2/dss/ti_hdmi.h b/drivers/video/omap2/dss/ti_hdmi.h index 7c630984767..823fbe655b8 100644 --- a/drivers/video/omap2/dss/ti_hdmi.h +++ b/drivers/video/omap2/dss/ti_hdmi.h | |||
@@ -91,11 +91,12 @@ struct hdmi_ip_data { | |||
91 | struct hdmi_config cfg; | 91 | struct hdmi_config cfg; |
92 | struct hdmi_pll_info pll_data; | 92 | struct hdmi_pll_info pll_data; |
93 | }; | 93 | }; |
94 | int hdmi_phy_init(struct hdmi_ip_data *ip_data); | 94 | int ti_hdmi_4xxx_phy_enable(struct hdmi_ip_data *ip_data); |
95 | void hdmi_phy_off(struct hdmi_ip_data *ip_data); | 95 | void ti_hdmi_4xxx_phy_disable(struct hdmi_ip_data *ip_data); |
96 | int read_edid(struct hdmi_ip_data *ip_data, u8 *pedid, u16 max_length); | 96 | int ti_hdmi_4xxx_read_edid(struct hdmi_ip_data *ip_data, |
97 | void hdmi_wp_video_start(struct hdmi_ip_data *ip_data, bool start); | 97 | u8 *pedid, u16 max_length); |
98 | int hdmi_pll_program(struct hdmi_ip_data *ip_data); | 98 | void ti_hdmi_4xxx_wp_video_start(struct hdmi_ip_data *ip_data, bool start); |
99 | int hdmi_set_pll_pwr(struct hdmi_ip_data *ip_data, enum hdmi_pll_pwr val); | 99 | int ti_hdmi_4xxx_pll_enable(struct hdmi_ip_data *ip_data); |
100 | void hdmi_basic_configure(struct hdmi_ip_data *ip_data); | 100 | void ti_hdmi_4xxx_pll_disable(struct hdmi_ip_data *ip_data); |
101 | void ti_hdmi_4xxx_basic_configure(struct hdmi_ip_data *ip_data); | ||
101 | #endif | 102 | #endif |
diff --git a/drivers/video/omap2/dss/ti_hdmi_4xxx_ip.c b/drivers/video/omap2/dss/ti_hdmi_4xxx_ip.c index c2a98f830b8..cb3a2d6753d 100644 --- a/drivers/video/omap2/dss/ti_hdmi_4xxx_ip.c +++ b/drivers/video/omap2/dss/ti_hdmi_4xxx_ip.c | |||
@@ -164,7 +164,7 @@ static int hdmi_set_phy_pwr(struct hdmi_ip_data *ip_data, enum hdmi_phy_pwr val) | |||
164 | } | 164 | } |
165 | 165 | ||
166 | /* PLL_PWR_CMD */ | 166 | /* PLL_PWR_CMD */ |
167 | int hdmi_set_pll_pwr(struct hdmi_ip_data *ip_data, enum hdmi_pll_pwr val) | 167 | static int hdmi_set_pll_pwr(struct hdmi_ip_data *ip_data, enum hdmi_pll_pwr val) |
168 | { | 168 | { |
169 | /* Command for power control of HDMI PLL */ | 169 | /* Command for power control of HDMI PLL */ |
170 | REG_FLD_MOD(hdmi_wp_base(ip_data), HDMI_WP_PWR_CTRL, val, 3, 2); | 170 | REG_FLD_MOD(hdmi_wp_base(ip_data), HDMI_WP_PWR_CTRL, val, 3, 2); |
@@ -194,7 +194,7 @@ static int hdmi_pll_reset(struct hdmi_ip_data *ip_data) | |||
194 | return 0; | 194 | return 0; |
195 | } | 195 | } |
196 | 196 | ||
197 | int hdmi_pll_program(struct hdmi_ip_data *ip_data) | 197 | int ti_hdmi_4xxx_pll_enable(struct hdmi_ip_data *ip_data) |
198 | { | 198 | { |
199 | u16 r = 0; | 199 | u16 r = 0; |
200 | 200 | ||
@@ -217,7 +217,12 @@ int hdmi_pll_program(struct hdmi_ip_data *ip_data) | |||
217 | return 0; | 217 | return 0; |
218 | } | 218 | } |
219 | 219 | ||
220 | int hdmi_phy_init(struct hdmi_ip_data *ip_data) | 220 | void ti_hdmi_4xxx_pll_disable(struct hdmi_ip_data *ip_data) |
221 | { | ||
222 | hdmi_set_pll_pwr(ip_data, HDMI_PLLPWRCMD_ALLOFF); | ||
223 | } | ||
224 | |||
225 | int ti_hdmi_4xxx_phy_enable(struct hdmi_ip_data *ip_data) | ||
221 | { | 226 | { |
222 | u16 r = 0; | 227 | u16 r = 0; |
223 | void __iomem *phy_base = hdmi_phy_base(ip_data); | 228 | void __iomem *phy_base = hdmi_phy_base(ip_data); |
@@ -254,7 +259,7 @@ int hdmi_phy_init(struct hdmi_ip_data *ip_data) | |||
254 | return 0; | 259 | return 0; |
255 | } | 260 | } |
256 | 261 | ||
257 | void hdmi_phy_off(struct hdmi_ip_data *ip_data) | 262 | void ti_hdmi_4xxx_phy_disable(struct hdmi_ip_data *ip_data) |
258 | { | 263 | { |
259 | hdmi_set_phy_pwr(ip_data, HDMI_PHYPWRCMD_OFF); | 264 | hdmi_set_phy_pwr(ip_data, HDMI_PHYPWRCMD_OFF); |
260 | } | 265 | } |
@@ -360,7 +365,8 @@ static int hdmi_core_ddc_edid(struct hdmi_ip_data *ip_data, | |||
360 | return 0; | 365 | return 0; |
361 | } | 366 | } |
362 | 367 | ||
363 | int read_edid(struct hdmi_ip_data *ip_data, u8 *pedid, u16 max_length) | 368 | int ti_hdmi_4xxx_read_edid(struct hdmi_ip_data *ip_data, |
369 | u8 *pedid, u16 max_length) | ||
364 | { | 370 | { |
365 | int r = 0, n = 0, i = 0; | 371 | int r = 0, n = 0, i = 0; |
366 | int max_ext_blocks = (max_length / 128) - 1; | 372 | int max_ext_blocks = (max_length / 128) - 1; |
@@ -613,7 +619,7 @@ static void hdmi_wp_init(struct omap_video_timings *timings, | |||
613 | 619 | ||
614 | } | 620 | } |
615 | 621 | ||
616 | void hdmi_wp_video_start(struct hdmi_ip_data *ip_data, bool start) | 622 | void ti_hdmi_4xxx_wp_video_start(struct hdmi_ip_data *ip_data, bool start) |
617 | { | 623 | { |
618 | REG_FLD_MOD(hdmi_wp_base(ip_data), HDMI_WP_VIDEO_CFG, start, 31, 31); | 624 | REG_FLD_MOD(hdmi_wp_base(ip_data), HDMI_WP_VIDEO_CFG, start, 31, 31); |
619 | } | 625 | } |
@@ -680,7 +686,7 @@ static void hdmi_wp_video_config_timing(struct hdmi_ip_data *ip_data, | |||
680 | hdmi_write_reg(hdmi_wp_base(ip_data), HDMI_WP_VIDEO_TIMING_V, timing_v); | 686 | hdmi_write_reg(hdmi_wp_base(ip_data), HDMI_WP_VIDEO_TIMING_V, timing_v); |
681 | } | 687 | } |
682 | 688 | ||
683 | void hdmi_basic_configure(struct hdmi_ip_data *ip_data) | 689 | void ti_hdmi_4xxx_basic_configure(struct hdmi_ip_data *ip_data) |
684 | { | 690 | { |
685 | /* HDMI */ | 691 | /* HDMI */ |
686 | struct omap_video_timings video_timing; | 692 | struct omap_video_timings video_timing; |