[Intel-gfx] [PATCH v2 3/9] drm/dp: Split drm_dp_mst_allocate_vcpi

Pandiyan, Dhinakaran dhinakaran.pandiyan at intel.com
Wed Jan 25 20:34:38 UTC 2017


On Wed, 2017-01-25 at 10:31 +1000, Dave Airlie wrote:
> On 25 January 2017 at 09:49, Dhinakaran Pandiyan
> <dhinakaran.pandiyan at intel.com> wrote:
> > drm_dp_mst_allocate_vcpi() apart from setting up the vcpi structure,
> > also finds if there are enough slots available. This check is a duplicate
> > of that implemented in drm_dp_mst_find_vcpi_slots(). Let's move this check
> > out and reuse the existing drm_dp_mst_find_vcpi_slots() function to check
> > if there are enough vcpi slots before allocating them.
> >
> > This brings the check to one place. Additionally drivers that will use MST
> > state tracking for atomic modesets can use the atomic version of
> > find_vcpi_slots() and reuse drm_dp_mst_allocate_vcpi()
> >
> 
> Also seem sane, at least for the core bits,
> 
> Reviewed-by: Dave Airlie <airlied at redhat.com>
> 

Thanks for the review.

-DK


> > Signed-off-by: Dhinakaran Pandiyan <dhinakaran.pandiyan at intel.com>
> > ---
> >  drivers/gpu/drm/drm_dp_mst_topology.c  | 20 +++++++++-----------
> >  drivers/gpu/drm/i915/intel_dp_mst.c    |  4 ++--
> >  drivers/gpu/drm/nouveau/nv50_display.c |  3 ++-
> >  drivers/gpu/drm/radeon/radeon_dp_mst.c |  4 +++-
> >  include/drm/drm_dp_mst_helper.h        |  2 +-
> >  5 files changed, 17 insertions(+), 16 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/drm_dp_mst_topology.c b/drivers/gpu/drm/drm_dp_mst_topology.c
> > index d9edd84..b871d4e 100644
> > --- a/drivers/gpu/drm/drm_dp_mst_topology.c
> > +++ b/drivers/gpu/drm/drm_dp_mst_topology.c
> > @@ -2479,20 +2479,17 @@ int drm_dp_find_vcpi_slots(struct drm_dp_mst_topology_mgr *mgr,
> >  EXPORT_SYMBOL(drm_dp_find_vcpi_slots);
> >
> >  static int drm_dp_init_vcpi(struct drm_dp_mst_topology_mgr *mgr,
> > -                           struct drm_dp_vcpi *vcpi, int pbn)
> > +                           struct drm_dp_vcpi *vcpi, int pbn, int slots)
> >  {
> > -       int num_slots;
> >         int ret;
> >
> > -       num_slots = DIV_ROUND_UP(pbn, mgr->pbn_div);
> > -
> >         /* max. time slots - one slot for MTP header */
> > -       if (num_slots > 63)
> > +       if (slots > 63)
> >                 return -ENOSPC;
> >
> >         vcpi->pbn = pbn;
> > -       vcpi->aligned_pbn = num_slots * mgr->pbn_div;
> > -       vcpi->num_slots = num_slots;
> > +       vcpi->aligned_pbn = slots * mgr->pbn_div;
> > +       vcpi->num_slots = slots;
> >
> >         ret = drm_dp_mst_assign_payload_id(mgr, vcpi);
> >         if (ret < 0)
> > @@ -2507,7 +2504,7 @@ static int drm_dp_init_vcpi(struct drm_dp_mst_topology_mgr *mgr,
> >   * @pbn: payload bandwidth number to request
> >   * @slots: returned number of slots for this PBN.
> >   */
> > -bool drm_dp_mst_allocate_vcpi(struct drm_dp_mst_topology_mgr *mgr, struct drm_dp_mst_port *port, int pbn, int *slots)
> > +bool drm_dp_mst_allocate_vcpi(struct drm_dp_mst_topology_mgr *mgr, struct drm_dp_mst_port *port, int pbn, int slots)
> >  {
> >         int ret;
> >
> > @@ -2515,16 +2512,18 @@ bool drm_dp_mst_allocate_vcpi(struct drm_dp_mst_topology_mgr *mgr, struct drm_dp
> >         if (!port)
> >                 return false;
> >
> > +       if (slots < 0)
> > +               return false;
> > +
> >         if (port->vcpi.vcpi > 0) {
> >                 DRM_DEBUG_KMS("payload: vcpi %d already allocated for pbn %d - requested pbn %d\n", port->vcpi.vcpi, port->vcpi.pbn, pbn);
> >                 if (pbn == port->vcpi.pbn) {
> > -                       *slots = port->vcpi.num_slots;
> >                         drm_dp_put_port(port);
> >                         return true;
> >                 }
> >         }
> >
> > -       ret = drm_dp_init_vcpi(mgr, &port->vcpi, pbn);
> > +       ret = drm_dp_init_vcpi(mgr, &port->vcpi, pbn, slots);
> >         if (ret) {
> >                 DRM_DEBUG_KMS("failed to init vcpi slots=%d max=63 ret=%d\n",
> >                                 DIV_ROUND_UP(pbn, mgr->pbn_div), ret);
> > @@ -2532,7 +2531,6 @@ bool drm_dp_mst_allocate_vcpi(struct drm_dp_mst_topology_mgr *mgr, struct drm_dp
> >         }
> >         DRM_DEBUG_KMS("initing vcpi for pbn=%d slots=%d\n",
> >                         pbn, port->vcpi.num_slots);
> > -       *slots = port->vcpi.num_slots;
> >
> >         drm_dp_put_port(port);
> >         return true;
> > diff --git a/drivers/gpu/drm/i915/intel_dp_mst.c b/drivers/gpu/drm/i915/intel_dp_mst.c
> > index 38e3ca2..f51574f 100644
> > --- a/drivers/gpu/drm/i915/intel_dp_mst.c
> > +++ b/drivers/gpu/drm/i915/intel_dp_mst.c
> > @@ -147,7 +147,6 @@ static void intel_mst_pre_enable_dp(struct intel_encoder *encoder,
> >                 to_intel_connector(conn_state->connector);
> >         int ret;
> >         uint32_t temp;
> > -       int slots;
> >
> >         /* MST encoders are bound to a crtc, not to a connector,
> >          * force the mapping here for get_hw_state.
> > @@ -177,7 +176,8 @@ static void intel_mst_pre_enable_dp(struct intel_encoder *encoder,
> >
> >         ret = drm_dp_mst_allocate_vcpi(&intel_dp->mst_mgr,
> >                                        connector->port,
> > -                                      pipe_config->pbn, &slots);
> > +                                      pipe_config->pbn,
> > +                                      pipe_config->dp_m_n.tu);
> >         if (ret == false) {
> >                 DRM_ERROR("failed to allocate vcpi\n");
> >                 return;
> > diff --git a/drivers/gpu/drm/nouveau/nv50_display.c b/drivers/gpu/drm/nouveau/nv50_display.c
> > index 452da48..91a4875 100644
> > --- a/drivers/gpu/drm/nouveau/nv50_display.c
> > +++ b/drivers/gpu/drm/nouveau/nv50_display.c
> > @@ -2959,7 +2959,8 @@ nv50_msto_enable(struct drm_encoder *encoder)
> >         if (WARN_ON(!mstc))
> >                 return;
> >
> > -       r = drm_dp_mst_allocate_vcpi(&mstm->mgr, mstc->port, mstc->pbn, &slots);
> > +       slots = drm_dp_find_vcpi_slots(&mstm->mgr, mstc->pbn);
> > +       r = drm_dp_mst_allocate_vcpi(&mstm->mgr, mstc->port, mstc->pbn, slots);
> >         WARN_ON(!r);
> >
> >         if (mstm->outp->dcb->sorconf.link & 1)
> > diff --git a/drivers/gpu/drm/radeon/radeon_dp_mst.c b/drivers/gpu/drm/radeon/radeon_dp_mst.c
> > index 7d5ada3..6598306 100644
> > --- a/drivers/gpu/drm/radeon/radeon_dp_mst.c
> > +++ b/drivers/gpu/drm/radeon/radeon_dp_mst.c
> > @@ -453,9 +453,11 @@ radeon_mst_encoder_dpms(struct drm_encoder *encoder, int mode)
> >                 DRM_DEBUG_KMS("dig encoder is %d %d %d\n", dig_enc->dig_encoder,
> >                               dig_enc->linkb, radeon_crtc->crtc_id);
> >
> > +               slots = drm_dp_find_vcpi_slots(&radeon_connector->mst_port->mst_mgr,
> > +                                              mst_enc->pbn);
> >                 ret = drm_dp_mst_allocate_vcpi(&radeon_connector->mst_port->mst_mgr,
> >                                                radeon_connector->port,
> > -                                              mst_enc->pbn, &slots);
> > +                                              mst_enc->pbn, slots);
> >                 ret = drm_dp_update_payload_part1(&radeon_connector->mst_port->mst_mgr);
> >
> >                 radeon_dp_mst_set_be_cntl(primary, mst_enc,
> > diff --git a/include/drm/drm_dp_mst_helper.h b/include/drm/drm_dp_mst_helper.h
> > index b0f4a09..98d3c73 100644
> > --- a/include/drm/drm_dp_mst_helper.h
> > +++ b/include/drm/drm_dp_mst_helper.h
> > @@ -568,7 +568,7 @@ struct edid *drm_dp_mst_get_edid(struct drm_connector *connector, struct drm_dp_
> >  int drm_dp_calc_pbn_mode(int clock, int bpp);
> >
> >
> > -bool drm_dp_mst_allocate_vcpi(struct drm_dp_mst_topology_mgr *mgr, struct drm_dp_mst_port *port, int pbn, int *slots);
> > +bool drm_dp_mst_allocate_vcpi(struct drm_dp_mst_topology_mgr *mgr, struct drm_dp_mst_port *port, int pbn, int slots);
> >
> >  int drm_dp_mst_get_vcpi_slots(struct drm_dp_mst_topology_mgr *mgr, struct drm_dp_mst_port *port);
> >
> > --
> > 2.7.4
> >
> > _______________________________________________
> > Intel-gfx mailing list
> > Intel-gfx at lists.freedesktop.org
> > https://lists.freedesktop.org/mailman/listinfo/intel-gfx
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/intel-gfx



More information about the Intel-gfx mailing list