return ret;
}
-int sde_hdmi_core_enable(struct sde_hdmi *sde_hdmi)
-{
- struct hdmi *hdmi = sde_hdmi->ctrl.ctrl;
- const struct hdmi_platform_config *config = hdmi->config;
- struct device *dev = &hdmi->pdev->dev;
- int i, ret;
- struct drm_connector *connector;
- struct msm_drm_private *priv;
- struct sde_kms *sde_kms;
-
- connector = hdmi->connector;
- priv = connector->dev->dev_private;
- sde_kms = to_sde_kms(priv->kms);
-
- for (i = 0; i < config->hpd_reg_cnt; i++) {
- ret = regulator_enable(hdmi->hpd_regs[i]);
- if (ret) {
- SDE_ERROR("failed to enable hpd regulator: %s (%d)\n",
- config->hpd_reg_names[i], ret);
- }
- }
-
- ret = pinctrl_pm_select_default_state(dev);
- if (ret)
- SDE_ERROR("pinctrl state chg failed: %d\n", ret);
-
- ret = _sde_hdmi_gpio_config(hdmi, true);
- if (ret)
- SDE_ERROR("failed to configure GPIOs: %d\n", ret);
-
- for (i = 0; i < config->hpd_clk_cnt; i++) {
- if (config->hpd_freq && config->hpd_freq[i]) {
- ret = clk_set_rate(hdmi->hpd_clks[i],
- config->hpd_freq[i]);
- if (ret)
- pr_warn("failed to set clk %s (%d)\n",
- config->hpd_clk_names[i], ret);
- }
-
- ret = clk_prepare_enable(hdmi->hpd_clks[i]);
- if (ret) {
- SDE_ERROR("failed to enable hpd clk: %s (%d)\n",
- config->hpd_clk_names[i], ret);
- }
- }
-
- return ret;
-}
-
-static void _sde_hdmi_hpd_disable(struct sde_hdmi *sde_hdmi)
+static void _sde_hdmi_hdp_disable(struct sde_hdmi *sde_hdmi)
{
struct hdmi *hdmi = sde_hdmi->ctrl.ctrl;
const struct hdmi_platform_config *config = hdmi->config;
}
}
-void sde_hdmi_core_disable(struct sde_hdmi *sde_hdmi)
-{
- /* HPD contains all the core clock and pwr */
- _sde_hdmi_hpd_disable(sde_hdmi);
-}
-
static void _sde_hdmi_cec_update_phys_addr(struct sde_hdmi *display)
{
struct edid *edid = display->edid_ctrl->edid;
return -EINVAL;
}
- if (!sde_hdmi->non_pluggable)
- _sde_hdmi_hpd_disable(sde_hdmi);
+ _sde_hdmi_hdp_disable(sde_hdmi);
return 0;
}
INIT_WORK(&sde_hdmi->hpd_work, _sde_hdmi_hotplug_work);
/* Enable HPD detection */
- if (!sde_hdmi->non_pluggable) {
- rc = _sde_hdmi_hpd_enable(sde_hdmi);
- if (rc)
- SDE_ERROR("failed to enable HPD: %d\n", rc);
- } else {
- /* Disable HPD interrupt */
- hdmi_write(hdmi, REG_HDMI_HPD_INT_CTRL, 0);
- }
+ rc = _sde_hdmi_hpd_enable(sde_hdmi);
+ if (rc)
+ SDE_ERROR("failed to enable HPD: %d\n", rc);
_sde_hdmi_get_tx_version(sde_hdmi);
#define HDMI_AVI_IFRAME_LINE_NUMBER 1
#define HDMI_VENDOR_IFRAME_LINE_NUMBER 3
-static int _sde_hdmi_bridge_setup_scrambler(struct hdmi *hdmi,
- struct drm_display_mode *mode);
void _sde_hdmi_bridge_destroy(struct drm_bridge *bridge)
{
}
struct sde_hdmi_bridge *sde_hdmi_bridge = to_hdmi_bridge(bridge);
struct hdmi *hdmi = sde_hdmi_bridge->hdmi;
const struct hdmi_platform_config *config = hdmi->config;
- struct sde_connector *c_conn = to_sde_connector(hdmi->connector);
- struct sde_hdmi *display = (struct sde_hdmi *)c_conn->display;
int i, ret;
for (i = 0; i < config->pwr_reg_cnt; i++) {
config->pwr_clk_names[i], ret);
}
}
-
- if (display->non_pluggable) {
- ret = sde_hdmi_core_enable(display);
- if (ret)
- SDE_ERROR("failed to enable hpd clks: %d\n", ret);
- }
- _sde_hdmi_bridge_setup_scrambler(hdmi, &display->mode);
}
static void _sde_hdmi_bridge_power_off(struct drm_bridge *bridge)
struct sde_hdmi_bridge *sde_hdmi_bridge = to_hdmi_bridge(bridge);
struct hdmi *hdmi = sde_hdmi_bridge->hdmi;
const struct hdmi_platform_config *config = hdmi->config;
- struct sde_connector *c_conn = to_sde_connector(hdmi->connector);
- struct sde_hdmi *display = (struct sde_hdmi *)c_conn->display;
int i, ret;
/* Wait for vsync */
config->pwr_reg_names[i], ret);
}
}
-
- if (display->non_pluggable)
- sde_hdmi_core_disable(display);
}
static int _sde_hdmi_bridge_ddc_clear_irq(struct hdmi *hdmi,
if (hdmi->hdcp_ctrl && hdmi->is_hdcp_supported)
hdmi_hdcp_ctrl_on(hdmi->hdcp_ctrl);
- /* turn on scrambler, scrambler was skipped if HDMI is off */
- _sde_hdmi_bridge_setup_scrambler(hdmi, &display->mode);
-
mutex_lock(&display->display_lock);
if (display->codec_ready)
sde_hdmi_notify_clients(display, display->connected);
}
_sde_hdmi_save_mode(hdmi, mode);
- if (hdmi->power_on)
- _sde_hdmi_bridge_setup_scrambler(hdmi, mode);
+ _sde_hdmi_bridge_setup_scrambler(hdmi, mode);
_sde_hdmi_bridge_setup_deep_color(hdmi);
}