From: abhinavk@codeaurora.org
To: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Cc: Bjorn Andersson <bjorn.andersson@linaro.org>,
Rob Clark <robdclark@gmail.com>, Sean Paul <sean@poorly.run>,
Jonathan Marek <jonathan@marek.ca>,
Stephen Boyd <sboyd@kernel.org>,
linux-arm-msm@vger.kernel.org, dri-devel@lists.freedesktop.org,
David Airlie <airlied@linux.ie>, Daniel Vetter <daniel@ffwll.ch>,
freedreno@lists.freedesktop.org
Subject: Re: [Freedreno] [PATCH v1 3/7] drm/msm/dpu: support setting up two independent DSI connectors
Date: Fri, 09 Jul 2021 15:09:02 -0700 [thread overview]
Message-ID: <72d95728559ef617a3dc29621cc5a2b5@codeaurora.org> (raw)
In-Reply-To: <20210708122833.363451-4-dmitry.baryshkov@linaro.org>
On 2021-07-08 05:28, Dmitry Baryshkov wrote:
> Move setting up encoders from set_encoder_mode to
> _dpu_kms_initialize_dsi() / _dpu_kms_initialize_displayport(). This
> allows us to support not only "single DSI" and "bonded DSI" but also
> "two
> independent DSI" configurations. In future this would also help adding
> support for multiple DP connectors.
>
> Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
> ---
> drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c | 102 +++++++++++++-----------
> 1 file changed, 57 insertions(+), 45 deletions(-)
>
> diff --git a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c
> b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c
> index 1d3a4f395e74..8459da36174e 100644
> --- a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c
> +++ b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c
> @@ -471,30 +471,68 @@ static int _dpu_kms_initialize_dsi(struct
> drm_device *dev,
> struct dpu_kms *dpu_kms)
> {
> struct drm_encoder *encoder = NULL;
> + struct msm_display_info info;
> int i, rc = 0;
>
> if (!(priv->dsi[0] || priv->dsi[1]))
> return rc;
>
> - /*TODO: Support two independent DSI connectors */
> - encoder = dpu_encoder_init(dev, DRM_MODE_ENCODER_DSI);
> - if (IS_ERR(encoder)) {
> - DPU_ERROR("encoder init failed for dsi display\n");
> - return PTR_ERR(encoder);
> - }
> -
> - priv->encoders[priv->num_encoders++] = encoder;
> -
> + /*
> + * We support following confiurations:
> + * - Single DSI host (dsi0 or dsi1)
> + * - Two independent DSI hosts
> + * - Bonded DSI0 and DSI1 hosts
> + *
> + * TODO: Support swapping DSI0 and DSI1 in the bonded setup.
> + */
> for (i = 0; i < ARRAY_SIZE(priv->dsi); i++) {
> if (!priv->dsi[i])
> continue;
>
> + if (!encoder) {
> + encoder = dpu_encoder_init(dev, DRM_MODE_ENCODER_DSI);
> + if (IS_ERR(encoder)) {
> + DPU_ERROR("encoder init failed for dsi display\n");
> + return PTR_ERR(encoder);
> + }
> +
> + priv->encoders[priv->num_encoders++] = encoder;
> +
> + memset(&info, 0, sizeof(info));
> + info.intf_type = encoder->encoder_type;
> + info.capabilities = msm_dsi_is_cmd_mode(priv->dsi[i]) ?
> + MSM_DISPLAY_CAP_CMD_MODE :
> + MSM_DISPLAY_CAP_VID_MODE;
> + }
> +
> rc = msm_dsi_modeset_init(priv->dsi[i], dev, encoder);
> if (rc) {
> DPU_ERROR("modeset_init failed for dsi[%d], rc = %d\n",
> i, rc);
> break;
> }
> +
> + info.h_tile_instance[info.num_of_h_tiles++] = i;
> +
> + /* Register non-bonded encoder here. If the encoder is bonded,
> + * it will be registered later, when both DSI hosts are
> + * initialized.
> + */
> + if (!msm_dsi_is_bonded_dsi(priv->dsi[i])) {
> + rc = dpu_encoder_setup(dev, encoder, &info);
> + if (rc)
> + DPU_ERROR("failed to setup DPU encoder %d: rc:%d\n",
> + encoder->base.id, rc);
> + encoder = NULL;
Seems like you are using encoder = NULL as a check to distinguish
whether this is bonded mode or not.
> + }
> + }
> +
> + /* Register bonded encoder here, when both DSI hosts are initialized
> */
> + if (encoder) {
Why cant we replace this with if (msm_dsi_is_bonded_dsi(priv->dsi[i])
and get rid
of the encoder = NULL?
> + rc = dpu_encoder_setup(dev, encoder, &info);
> + if (rc)
> + DPU_ERROR("failed to setup DPU encoder %d: rc:%d\n",
> + encoder->base.id, rc);
> }
>
> return rc;
> @@ -505,6 +543,7 @@ static int _dpu_kms_initialize_displayport(struct
> drm_device *dev,
> struct dpu_kms *dpu_kms)
> {
> struct drm_encoder *encoder = NULL;
> + struct msm_display_info info;
> int rc = 0;
>
> if (!priv->dp)
> @@ -516,6 +555,7 @@ static int _dpu_kms_initialize_displayport(struct
> drm_device *dev,
> return PTR_ERR(encoder);
> }
>
> + memset(&info, 0, sizeof(info));
> rc = msm_dp_modeset_init(priv->dp, dev, encoder);
> if (rc) {
> DPU_ERROR("modeset_init failed for DP, rc = %d\n", rc);
> @@ -524,6 +564,14 @@ static int _dpu_kms_initialize_displayport(struct
> drm_device *dev,
> }
>
> priv->encoders[priv->num_encoders++] = encoder;
> +
> + info.num_of_h_tiles = 1;
> + info.capabilities = MSM_DISPLAY_CAP_VID_MODE;
> + info.intf_type = encoder->encoder_type;
> + rc = dpu_encoder_setup(dev, encoder, &info);
> + if (rc)
> + DPU_ERROR("failed to setup DPU encoder %d: rc:%d\n",
> + encoder->base.id, rc);
> return rc;
> }
>
> @@ -726,41 +774,6 @@ static void dpu_kms_destroy(struct msm_kms *kms)
> msm_kms_destroy(&dpu_kms->base);
> }
>
> -static void _dpu_kms_set_encoder_mode(struct msm_kms *kms,
> - struct drm_encoder *encoder,
> - bool cmd_mode)
> -{
> - struct msm_display_info info;
> - struct msm_drm_private *priv = encoder->dev->dev_private;
> - int i, rc = 0;
> -
> - memset(&info, 0, sizeof(info));
> -
> - info.intf_type = encoder->encoder_type;
> - info.capabilities = cmd_mode ? MSM_DISPLAY_CAP_CMD_MODE :
> - MSM_DISPLAY_CAP_VID_MODE;
> -
> - 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)
> - DPU_ERROR("failed to setup DPU encoder %d: rc:%d\n",
> - encoder->base.id, rc);
> -}
> -
> static irqreturn_t dpu_irq(struct msm_kms *kms)
> {
> struct dpu_kms *dpu_kms = to_dpu_kms(kms);
> @@ -863,7 +876,6 @@ static const struct msm_kms_funcs kms_funcs = {
> .get_format = dpu_get_msm_format,
> .round_pixclk = dpu_kms_round_pixclk,
> .destroy = dpu_kms_destroy,
> - .set_encoder_mode = _dpu_kms_set_encoder_mode,
> .snapshot = dpu_kms_mdp_snapshot,
> #ifdef CONFIG_DEBUG_FS
> .debugfs_init = dpu_kms_debugfs_init,
WARNING: multiple messages have this Message-ID (diff)
From: abhinavk@codeaurora.org
To: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Cc: freedreno@lists.freedesktop.org,
Jonathan Marek <jonathan@marek.ca>,
Stephen Boyd <sboyd@kernel.org>,
linux-arm-msm@vger.kernel.org, dri-devel@lists.freedesktop.org,
Bjorn Andersson <bjorn.andersson@linaro.org>,
David Airlie <airlied@linux.ie>, Sean Paul <sean@poorly.run>
Subject: Re: [Freedreno] [PATCH v1 3/7] drm/msm/dpu: support setting up two independent DSI connectors
Date: Fri, 09 Jul 2021 15:09:02 -0700 [thread overview]
Message-ID: <72d95728559ef617a3dc29621cc5a2b5@codeaurora.org> (raw)
In-Reply-To: <20210708122833.363451-4-dmitry.baryshkov@linaro.org>
On 2021-07-08 05:28, Dmitry Baryshkov wrote:
> Move setting up encoders from set_encoder_mode to
> _dpu_kms_initialize_dsi() / _dpu_kms_initialize_displayport(). This
> allows us to support not only "single DSI" and "bonded DSI" but also
> "two
> independent DSI" configurations. In future this would also help adding
> support for multiple DP connectors.
>
> Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
> ---
> drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c | 102 +++++++++++++-----------
> 1 file changed, 57 insertions(+), 45 deletions(-)
>
> diff --git a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c
> b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c
> index 1d3a4f395e74..8459da36174e 100644
> --- a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c
> +++ b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c
> @@ -471,30 +471,68 @@ static int _dpu_kms_initialize_dsi(struct
> drm_device *dev,
> struct dpu_kms *dpu_kms)
> {
> struct drm_encoder *encoder = NULL;
> + struct msm_display_info info;
> int i, rc = 0;
>
> if (!(priv->dsi[0] || priv->dsi[1]))
> return rc;
>
> - /*TODO: Support two independent DSI connectors */
> - encoder = dpu_encoder_init(dev, DRM_MODE_ENCODER_DSI);
> - if (IS_ERR(encoder)) {
> - DPU_ERROR("encoder init failed for dsi display\n");
> - return PTR_ERR(encoder);
> - }
> -
> - priv->encoders[priv->num_encoders++] = encoder;
> -
> + /*
> + * We support following confiurations:
> + * - Single DSI host (dsi0 or dsi1)
> + * - Two independent DSI hosts
> + * - Bonded DSI0 and DSI1 hosts
> + *
> + * TODO: Support swapping DSI0 and DSI1 in the bonded setup.
> + */
> for (i = 0; i < ARRAY_SIZE(priv->dsi); i++) {
> if (!priv->dsi[i])
> continue;
>
> + if (!encoder) {
> + encoder = dpu_encoder_init(dev, DRM_MODE_ENCODER_DSI);
> + if (IS_ERR(encoder)) {
> + DPU_ERROR("encoder init failed for dsi display\n");
> + return PTR_ERR(encoder);
> + }
> +
> + priv->encoders[priv->num_encoders++] = encoder;
> +
> + memset(&info, 0, sizeof(info));
> + info.intf_type = encoder->encoder_type;
> + info.capabilities = msm_dsi_is_cmd_mode(priv->dsi[i]) ?
> + MSM_DISPLAY_CAP_CMD_MODE :
> + MSM_DISPLAY_CAP_VID_MODE;
> + }
> +
> rc = msm_dsi_modeset_init(priv->dsi[i], dev, encoder);
> if (rc) {
> DPU_ERROR("modeset_init failed for dsi[%d], rc = %d\n",
> i, rc);
> break;
> }
> +
> + info.h_tile_instance[info.num_of_h_tiles++] = i;
> +
> + /* Register non-bonded encoder here. If the encoder is bonded,
> + * it will be registered later, when both DSI hosts are
> + * initialized.
> + */
> + if (!msm_dsi_is_bonded_dsi(priv->dsi[i])) {
> + rc = dpu_encoder_setup(dev, encoder, &info);
> + if (rc)
> + DPU_ERROR("failed to setup DPU encoder %d: rc:%d\n",
> + encoder->base.id, rc);
> + encoder = NULL;
Seems like you are using encoder = NULL as a check to distinguish
whether this is bonded mode or not.
> + }
> + }
> +
> + /* Register bonded encoder here, when both DSI hosts are initialized
> */
> + if (encoder) {
Why cant we replace this with if (msm_dsi_is_bonded_dsi(priv->dsi[i])
and get rid
of the encoder = NULL?
> + rc = dpu_encoder_setup(dev, encoder, &info);
> + if (rc)
> + DPU_ERROR("failed to setup DPU encoder %d: rc:%d\n",
> + encoder->base.id, rc);
> }
>
> return rc;
> @@ -505,6 +543,7 @@ static int _dpu_kms_initialize_displayport(struct
> drm_device *dev,
> struct dpu_kms *dpu_kms)
> {
> struct drm_encoder *encoder = NULL;
> + struct msm_display_info info;
> int rc = 0;
>
> if (!priv->dp)
> @@ -516,6 +555,7 @@ static int _dpu_kms_initialize_displayport(struct
> drm_device *dev,
> return PTR_ERR(encoder);
> }
>
> + memset(&info, 0, sizeof(info));
> rc = msm_dp_modeset_init(priv->dp, dev, encoder);
> if (rc) {
> DPU_ERROR("modeset_init failed for DP, rc = %d\n", rc);
> @@ -524,6 +564,14 @@ static int _dpu_kms_initialize_displayport(struct
> drm_device *dev,
> }
>
> priv->encoders[priv->num_encoders++] = encoder;
> +
> + info.num_of_h_tiles = 1;
> + info.capabilities = MSM_DISPLAY_CAP_VID_MODE;
> + info.intf_type = encoder->encoder_type;
> + rc = dpu_encoder_setup(dev, encoder, &info);
> + if (rc)
> + DPU_ERROR("failed to setup DPU encoder %d: rc:%d\n",
> + encoder->base.id, rc);
> return rc;
> }
>
> @@ -726,41 +774,6 @@ static void dpu_kms_destroy(struct msm_kms *kms)
> msm_kms_destroy(&dpu_kms->base);
> }
>
> -static void _dpu_kms_set_encoder_mode(struct msm_kms *kms,
> - struct drm_encoder *encoder,
> - bool cmd_mode)
> -{
> - struct msm_display_info info;
> - struct msm_drm_private *priv = encoder->dev->dev_private;
> - int i, rc = 0;
> -
> - memset(&info, 0, sizeof(info));
> -
> - info.intf_type = encoder->encoder_type;
> - info.capabilities = cmd_mode ? MSM_DISPLAY_CAP_CMD_MODE :
> - MSM_DISPLAY_CAP_VID_MODE;
> -
> - 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)
> - DPU_ERROR("failed to setup DPU encoder %d: rc:%d\n",
> - encoder->base.id, rc);
> -}
> -
> static irqreturn_t dpu_irq(struct msm_kms *kms)
> {
> struct dpu_kms *dpu_kms = to_dpu_kms(kms);
> @@ -863,7 +876,6 @@ static const struct msm_kms_funcs kms_funcs = {
> .get_format = dpu_get_msm_format,
> .round_pixclk = dpu_kms_round_pixclk,
> .destroy = dpu_kms_destroy,
> - .set_encoder_mode = _dpu_kms_set_encoder_mode,
> .snapshot = dpu_kms_mdp_snapshot,
> #ifdef CONFIG_DEBUG_FS
> .debugfs_init = dpu_kms_debugfs_init,
next prev parent reply other threads:[~2021-07-09 22:09 UTC|newest]
Thread overview: 36+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-07-08 12:28 [PATCH v1 0/7] drm/msm/dpu: add support for idependent DSI config Dmitry Baryshkov
2021-07-08 12:28 ` Dmitry Baryshkov
2021-07-08 12:28 ` [PATCH v1 1/7] drm/msm/dsi: rename dual DSI to bonded DSI Dmitry Baryshkov
2021-07-08 12:28 ` Dmitry Baryshkov
2021-07-09 22:13 ` [Freedreno] " abhinavk
2021-07-09 22:13 ` abhinavk
2021-07-08 12:28 ` [PATCH v1 2/7] drm/msm/dsi: add two helper functions Dmitry Baryshkov
2021-07-08 12:28 ` Dmitry Baryshkov
2021-07-09 22:14 ` [Freedreno] " abhinavk
2021-07-09 22:14 ` abhinavk
2021-07-08 12:28 ` [PATCH v1 3/7] drm/msm/dpu: support setting up two independent DSI connectors Dmitry Baryshkov
2021-07-08 12:28 ` Dmitry Baryshkov
2021-07-09 22:09 ` abhinavk [this message]
2021-07-09 22:09 ` [Freedreno] " abhinavk
2021-07-09 22:13 ` Dmitry Baryshkov
2021-07-09 22:13 ` Dmitry Baryshkov
2021-07-08 12:28 ` [PATCH v1 4/7] drm/msm/mdp5: move mdp5_encoder_set_intf_mode after msm_dsi_modeset_init Dmitry Baryshkov
2021-07-08 12:28 ` Dmitry Baryshkov
2021-07-09 22:15 ` [Freedreno] " abhinavk
2021-07-09 22:15 ` abhinavk
2021-07-08 12:28 ` [PATCH v1 5/7] drm/msm/dp: stop calling set_encoder_mode callback Dmitry Baryshkov
2021-07-08 12:28 ` Dmitry Baryshkov
2021-07-09 22:16 ` [Freedreno] " abhinavk
2021-07-09 22:16 ` abhinavk
2021-07-09 23:46 ` Dmitry Baryshkov
2021-07-09 23:46 ` Dmitry Baryshkov
2021-07-08 12:28 ` [PATCH v1 6/7] drm/msm/dsi: " Dmitry Baryshkov
2021-07-08 12:28 ` Dmitry Baryshkov
2021-07-09 22:17 ` [Freedreno] " abhinavk
2021-07-09 22:17 ` abhinavk
2021-07-08 12:28 ` [PATCH v1 7/7] drm/msm/kms: drop " Dmitry Baryshkov
2021-07-08 12:28 ` Dmitry Baryshkov
2021-07-09 22:17 ` [Freedreno] " abhinavk
2021-07-09 22:17 ` abhinavk
2021-07-09 13:06 ` [Freedreno] [PATCH v1 0/7] drm/msm/dpu: add support for idependent DSI config Alexey Minnekhanov
2021-07-09 13:06 ` Alexey Minnekhanov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=72d95728559ef617a3dc29621cc5a2b5@codeaurora.org \
--to=abhinavk@codeaurora.org \
--cc=airlied@linux.ie \
--cc=bjorn.andersson@linaro.org \
--cc=daniel@ffwll.ch \
--cc=dmitry.baryshkov@linaro.org \
--cc=dri-devel@lists.freedesktop.org \
--cc=freedreno@lists.freedesktop.org \
--cc=jonathan@marek.ca \
--cc=linux-arm-msm@vger.kernel.org \
--cc=robdclark@gmail.com \
--cc=sboyd@kernel.org \
--cc=sean@poorly.run \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.