drm/msm/dpu: add display port support in DPU
Add display port support in DPU by creating hooks for DP encoder enumeration and encoder mode initialization. changes in v2: - rebase on [2] (Sean Paul) - remove unwanted error checks and switch cases (Jordan Crouse) [1] https://lwn.net/Articles/768265/ [2] https://lkml.org/lkml/2018/11/17/87 changes in V3: -- Moved this change as part of the DP driver changes. -- Addressed compilation issues on the latest code base. Changes in v6: -- Fix checkpatch.pl warning Changes in v7: Remove depends-on tag from commit message. Changes in v8: None Changes in v9: None Signed-off-by: Jeykumar Sankaran <jsanka@codeaurora.org> Signed-off-by: Chandan Uddaraju <chandanu@codeaurora.org> Signed-off-by: Vara Reddy <varar@codeaurora.org> Signed-off-by: Tanmay Shah <tanmay@codeaurora.org> Signed-off-by: Rob Clark <robdclark@chromium.org>
This commit is contained in:
parent
14975cff5b
commit
a10476e450
@ -2027,7 +2027,7 @@ static int dpu_encoder_setup_display(struct dpu_encoder_virt *dpu_enc,
|
||||
{
|
||||
int ret = 0;
|
||||
int i = 0;
|
||||
enum dpu_intf_type intf_type;
|
||||
enum dpu_intf_type intf_type = INTF_NONE;
|
||||
struct dpu_enc_phys_init_params phys_params;
|
||||
|
||||
if (!dpu_enc) {
|
||||
@ -2049,9 +2049,9 @@ static int dpu_encoder_setup_display(struct dpu_encoder_virt *dpu_enc,
|
||||
case DRM_MODE_ENCODER_DSI:
|
||||
intf_type = INTF_DSI;
|
||||
break;
|
||||
default:
|
||||
DPU_ERROR_ENC(dpu_enc, "unsupported display interface type\n");
|
||||
return -EINVAL;
|
||||
case DRM_MODE_ENCODER_TMDS:
|
||||
intf_type = INTF_DP;
|
||||
break;
|
||||
}
|
||||
|
||||
WARN_ON(disp_info->num_of_h_tiles < 1);
|
||||
|
@ -501,6 +501,33 @@ static int _dpu_kms_initialize_dsi(struct drm_device *dev,
|
||||
return rc;
|
||||
}
|
||||
|
||||
static int _dpu_kms_initialize_displayport(struct drm_device *dev,
|
||||
struct msm_drm_private *priv,
|
||||
struct dpu_kms *dpu_kms)
|
||||
{
|
||||
struct drm_encoder *encoder = NULL;
|
||||
int rc = 0;
|
||||
|
||||
if (!priv->dp)
|
||||
return rc;
|
||||
|
||||
encoder = dpu_encoder_init(dev, DRM_MODE_ENCODER_TMDS);
|
||||
if (IS_ERR(encoder)) {
|
||||
DPU_ERROR("encoder init failed for dsi display\n");
|
||||
return PTR_ERR(encoder);
|
||||
}
|
||||
|
||||
rc = msm_dp_modeset_init(priv->dp, dev, encoder);
|
||||
if (rc) {
|
||||
DPU_ERROR("modeset_init failed for DP, rc = %d\n", rc);
|
||||
drm_encoder_cleanup(encoder);
|
||||
return rc;
|
||||
}
|
||||
|
||||
priv->encoders[priv->num_encoders++] = encoder;
|
||||
return rc;
|
||||
}
|
||||
|
||||
/**
|
||||
* _dpu_kms_setup_displays - create encoders, bridges and connectors
|
||||
* for underlying displays
|
||||
@ -513,12 +540,21 @@ static int _dpu_kms_setup_displays(struct drm_device *dev,
|
||||
struct msm_drm_private *priv,
|
||||
struct dpu_kms *dpu_kms)
|
||||
{
|
||||
/**
|
||||
* Extend this function to initialize other
|
||||
* types of displays
|
||||
*/
|
||||
int rc = 0;
|
||||
|
||||
return _dpu_kms_initialize_dsi(dev, priv, dpu_kms);
|
||||
rc = _dpu_kms_initialize_dsi(dev, priv, dpu_kms);
|
||||
if (rc) {
|
||||
DPU_ERROR("initialize_dsi failed, rc = %d\n", rc);
|
||||
return rc;
|
||||
}
|
||||
|
||||
rc = _dpu_kms_initialize_displayport(dev, priv, dpu_kms);
|
||||
if (rc) {
|
||||
DPU_ERROR("initialize_DP failed, rc = %d\n", rc);
|
||||
return rc;
|
||||
}
|
||||
|
||||
return rc;
|
||||
}
|
||||
|
||||
static void _dpu_kms_drm_obj_destroy(struct dpu_kms *dpu_kms)
|
||||
@ -703,13 +739,20 @@ static void _dpu_kms_set_encoder_mode(struct msm_kms *kms,
|
||||
info.capabilities = cmd_mode ? MSM_DISPLAY_CAP_CMD_MODE :
|
||||
MSM_DISPLAY_CAP_VID_MODE;
|
||||
|
||||
/* TODO: No support for DSI swap */
|
||||
for (i = 0; i < ARRAY_SIZE(priv->dsi); i++) {
|
||||
if (priv->dsi[i]) {
|
||||
info.h_tile_instance[info.num_of_h_tiles] = i;
|
||||
info.num_of_h_tiles++;
|
||||
switch (info.intf_type) {
|
||||
case DRM_MODE_ENCODER_DSI:
|
||||
/* TODO: No support for DSI swap */
|
||||
for (i = 0; i < ARRAY_SIZE(priv->dsi); i++) {
|
||||
if (priv->dsi[i]) {
|
||||
info.h_tile_instance[info.num_of_h_tiles] = i;
|
||||
info.num_of_h_tiles++;
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
case DRM_MODE_ENCODER_TMDS:
|
||||
info.num_of_h_tiles = 1;
|
||||
break;
|
||||
};
|
||||
|
||||
rc = dpu_encoder_setup(encoder->dev, encoder, &info);
|
||||
if (rc)
|
||||
|
Loading…
Reference in New Issue
Block a user