struct mutex lock;
struct platform_device *pdev;
- struct hdmi_ip_data ip_data;
+ struct hdmi_wp_data wp;
+ struct hdmi_pll_data pll;
+ struct hdmi_phy_data phy;
+ struct hdmi_core_data core;
+
+ struct hdmi_config cfg;
struct clk *sys_clk;
struct regulator *vdda_hdmi_dac_reg;
int i;
for (i = 0; i < len; i++) {
- if (timings_arr[i].cm.code == hdmi.ip_data.cfg.cm.code)
+ if (timings_arr[i].cm.code == hdmi.cfg.cm.code)
return &timings_arr[i];
}
return NULL;
const struct hdmi_config *arr;
int len;
- if (hdmi.ip_data.cfg.cm.mode == HDMI_DVI) {
- arr = vesa_timings;
- len = ARRAY_SIZE(vesa_timings);
- } else {
- arr = cea_timings;
- len = ARRAY_SIZE(cea_timings);
- }
+ if (hdmi.cfg.cm.mode == HDMI_DVI) {
+ arr = vesa_timings;
+ len = ARRAY_SIZE(vesa_timings);
+ } else {
+ arr = cea_timings;
+ len = ARRAY_SIZE(cea_timings);
+ }
- return hdmi_find_timing(arr, len);
+ return hdmi_find_timing(arr, len);
}
static bool hdmi_timings_compare(struct omap_video_timings *timing1,
dss_mgr_disable(mgr);
- p = &hdmi.ip_data.cfg.timings;
+ p = &hdmi.cfg.timings;
DSSDBG("hdmi_power_on x_res= %d y_res = %d\n", p->x_res, p->y_res);
phy = p->pixel_clock;
- hdmi_pll_compute(&hdmi.ip_data.pll, clk_get_rate(hdmi.sys_clk), phy);
+ hdmi_pll_compute(&hdmi.pll, clk_get_rate(hdmi.sys_clk), phy);
- hdmi_wp_video_stop(&hdmi.ip_data.wp);
+ hdmi_wp_video_stop(&hdmi.wp);
/* config the PLL and PHY hdmi_set_pll_pwrfirst */
- r = hdmi_pll_enable(&hdmi.ip_data.pll, &hdmi.ip_data.wp);
+ r = hdmi_pll_enable(&hdmi.pll, &hdmi.wp);
if (r) {
DSSDBG("Failed to lock PLL\n");
goto err_pll_enable;
}
- r = hdmi_phy_enable(&hdmi.ip_data.phy, &hdmi.ip_data.wp,
- &hdmi.ip_data.cfg);
+ r = hdmi_phy_enable(&hdmi.phy, &hdmi.wp, &hdmi.cfg);
if (r) {
DSSDBG("Failed to start PHY\n");
goto err_phy_enable;
}
- hdmi4_configure(&hdmi.ip_data.core, &hdmi.ip_data.wp,
- &hdmi.ip_data.cfg);
+ hdmi4_configure(&hdmi.core, &hdmi.wp, &hdmi.cfg);
/* bypass TV gamma table */
dispc_enable_gamma_table(0);
/* tv size */
dss_mgr_set_timings(mgr, p);
- r = hdmi_wp_video_start(&hdmi.ip_data.wp);
+ r = hdmi_wp_video_start(&hdmi.wp);
if (r)
goto err_vid_enable;
return 0;
err_mgr_enable:
- hdmi_wp_video_stop(&hdmi.ip_data.wp);
+ hdmi_wp_video_stop(&hdmi.wp);
err_vid_enable:
- hdmi_phy_disable(&hdmi.ip_data.phy, &hdmi.ip_data.wp);
+ hdmi_phy_disable(&hdmi.phy, &hdmi.wp);
err_phy_enable:
- hdmi_pll_disable(&hdmi.ip_data.pll, &hdmi.ip_data.wp);
+ hdmi_pll_disable(&hdmi.pll, &hdmi.wp);
err_pll_enable:
hdmi_power_off_core(dssdev);
return -EIO;
dss_mgr_disable(mgr);
- hdmi_wp_video_stop(&hdmi.ip_data.wp);
- hdmi_phy_disable(&hdmi.ip_data.phy, &hdmi.ip_data.wp);
- hdmi_pll_disable(&hdmi.ip_data.pll, &hdmi.ip_data.wp);
+ hdmi_wp_video_stop(&hdmi.wp);
+ hdmi_phy_disable(&hdmi.phy, &hdmi.wp);
+ hdmi_pll_disable(&hdmi.pll, &hdmi.wp);
hdmi_power_off_core(dssdev);
}
mutex_lock(&hdmi.lock);
cm = hdmi_get_code(timings);
- hdmi.ip_data.cfg.cm = cm;
+ hdmi.cfg.cm = cm;
t = hdmi_get_timings();
if (t != NULL) {
- hdmi.ip_data.cfg = *t;
+ hdmi.cfg = *t;
dispc_set_tv_pclk(t->timings.pixel_clock * 1000);
}
return;
}
- hdmi_wp_dump(&hdmi.ip_data.wp, s);
- hdmi_pll_dump(&hdmi.ip_data.pll, s);
- hdmi_phy_dump(&hdmi.ip_data.phy, s);
- hdmi4_core_dump(&hdmi.ip_data.core, s);
+ hdmi_wp_dump(&hdmi.wp, s);
+ hdmi_pll_dump(&hdmi.pll, s);
+ hdmi_phy_dump(&hdmi.phy, s);
+ hdmi4_core_dump(&hdmi.core, s);
hdmi_runtime_put();
mutex_unlock(&hdmi.lock);
r = hdmi_runtime_get();
BUG_ON(r);
- r = hdmi4_read_edid(&hdmi.ip_data.core, buf, len);
+ r = hdmi4_read_edid(&hdmi.core, buf, len);
hdmi_runtime_put();
mutex_unlock(&hdmi.lock);
{
u32 deep_color;
bool deep_color_correct = false;
- u32 pclk = hdmi.ip_data.cfg.timings.pixel_clock;
+ u32 pclk = hdmi.cfg.timings.pixel_clock;
if (n == NULL || cts == NULL)
return -EINVAL;
static bool hdmi_mode_has_audio(void)
{
- if (hdmi.ip_data.cfg.cm.mode == HDMI_HDMI)
+ if (hdmi.cfg.cm.mode == HDMI_HDMI)
return true;
else
return false;
}
+
#endif
static int hdmi_connect(struct omap_dss_device *dssdev,
goto err;
}
- r = hdmi_wp_audio_enable(&hdmi.ip_data.wp, true);
+ r = hdmi_wp_audio_enable(&hdmi.wp, true);
if (r)
goto err;
static void hdmi_audio_disable(struct omap_dss_device *dssdev)
{
- hdmi_wp_audio_enable(&hdmi.ip_data.wp, false);
+ hdmi_wp_audio_enable(&hdmi.wp, false);
}
static int hdmi_audio_start(struct omap_dss_device *dssdev)
{
- return hdmi4_audio_start(&hdmi.ip_data.core, &hdmi.ip_data.wp);
+ return hdmi4_audio_start(&hdmi.core, &hdmi.wp);
}
static void hdmi_audio_stop(struct omap_dss_device *dssdev)
{
- hdmi4_audio_stop(&hdmi.ip_data.core, &hdmi.ip_data.wp);
+ hdmi4_audio_stop(&hdmi.core, &hdmi.wp);
}
static bool hdmi_audio_supported(struct omap_dss_device *dssdev)
goto err;
}
- r = hdmi4_audio_config(&hdmi.ip_data.core, &hdmi.ip_data.wp, audio);
+ r = hdmi4_audio_config(&hdmi.core, &hdmi.wp, audio);
if (r)
goto err;
hdmi.pdev = pdev;
mutex_init(&hdmi.lock);
- mutex_init(&hdmi.ip_data.lock);
- r = hdmi_wp_init(pdev, &hdmi.ip_data.wp);
+ r = hdmi_wp_init(pdev, &hdmi.wp);
if (r)
return r;
- r = hdmi_pll_init(pdev, &hdmi.ip_data.pll);
+ r = hdmi_pll_init(pdev, &hdmi.pll);
if (r)
return r;
- r = hdmi_phy_init(pdev, &hdmi.ip_data.phy);
+ r = hdmi_phy_init(pdev, &hdmi.phy);
if (r)
return r;
- r = hdmi4_core_init(pdev, &hdmi.ip_data.core);
+ r = hdmi4_core_init(pdev, &hdmi.core);
if (r)
return r;