[Nouveau] [PATCH v2 2/4] drm/vc4: Take underscan setup into account when updating planes

Boris Brezillon boris.brezillon at bootlin.com
Fri May 11 17:12:21 UTC 2018


On Fri, 11 May 2018 19:54:02 +0300
Ville Syrjälä <ville.syrjala at linux.intel.com> wrote:

> On Fri, May 11, 2018 at 05:52:56PM +0200, Boris Brezillon wrote:
> > On Fri, 11 May 2018 18:34:50 +0300
> > Ville Syrjälä <ville.syrjala at linux.intel.com> wrote:
> >   
> > > On Fri, May 11, 2018 at 04:59:17PM +0200, Boris Brezillon wrote:  
> > > > Applying an underscan setup is just a matter of scaling all planes
> > > > appropriately and adjusting the CRTC X/Y offset to account for the
> > > > horizontal and vertical border.
> > > > 
> > > > Create an vc4_plane_underscan_adj() function doing that and call it from
> > > > vc4_plane_setup_clipping_and_scaling() so that we are ready to attach
> > > > underscan properties to the HDMI connector.
> > > > 
> > > > Signed-off-by: Boris Brezillon <boris.brezillon at bootlin.com>
> > > > ---
> > > > Changes in v2:
> > > > - Take changes on hborder/vborder meaning into account
> > > > ---
> > > >  drivers/gpu/drm/vc4/vc4_plane.c | 49 ++++++++++++++++++++++++++++++++++++++++-
> > > >  1 file changed, 48 insertions(+), 1 deletion(-)
> > > > 
> > > > diff --git a/drivers/gpu/drm/vc4/vc4_plane.c b/drivers/gpu/drm/vc4/vc4_plane.c
> > > > index 71d44c357d35..61ed60841cd6 100644
> > > > --- a/drivers/gpu/drm/vc4/vc4_plane.c
> > > > +++ b/drivers/gpu/drm/vc4/vc4_plane.c
> > > > @@ -258,6 +258,49 @@ static u32 vc4_get_scl_field(struct drm_plane_state *state, int plane)
> > > >  	}
> > > >  }
> > > >  
> > > > +static int vc4_plane_underscan_adj(struct drm_plane_state *pstate)
> > > > +{
> > > > +	struct vc4_plane_state *vc4_pstate = to_vc4_plane_state(pstate);
> > > > +	struct drm_connector_state *conn_state = NULL;
> > > > +	struct drm_connector *conn;
> > > > +	struct drm_crtc_state *crtc_state;
> > > > +	int i;
> > > > +
> > > > +	for_each_new_connector_in_state(pstate->state, conn, conn_state, i) {
> > > > +		if (conn_state->crtc == pstate->crtc)
> > > > +			break;
> > > > +	}
> > > > +
> > > > +	if (i == pstate->state->num_connector)
> > > > +		return 0;
> > > > +
> > > > +	if (conn_state->underscan.mode != DRM_UNDERSCAN_ON)
> > > > +		return 0;
> > > > +
> > > > +	crtc_state = drm_atomic_get_new_crtc_state(pstate->state,
> > > > +						   pstate->crtc);
> > > > +
> > > > +	if (conn_state->underscan.hborder >= crtc_state->mode.hdisplay ||
> > > > +	    conn_state->underscan.vborder >= crtc_state->mode.vdisplay)
> > > > +		return -EINVAL;    
> > > 
> > > border * 2 ?  
> > 
> > Oops, indeed. I'll fix that.
> >   
> > >   
> > > > +
> > > > +	vc4_pstate->crtc_x += conn_state->underscan.hborder;
> > > > +	vc4_pstate->crtc_y += conn_state->underscan.vborder;
> > > > +	vc4_pstate->crtc_w = (vc4_pstate->crtc_w *
> > > > +			      (crtc_state->mode.hdisplay -
> > > > +			       (conn_state->underscan.hborder * 2))) /
> > > > +			     crtc_state->mode.hdisplay;
> > > > +	vc4_pstate->crtc_h = (vc4_pstate->crtc_h *
> > > > +			      (crtc_state->mode.vdisplay -
> > > > +			       (conn_state->underscan.vborder * 2))) /
> > > > +			     crtc_state->mode.vdisplay;    
> > > 
> > > So you're now scaling all planes? The code seems to reject scaling for
> > > the cursor plane, how are you dealing with that? Or just no cursor
> > > allowed when underscanning?  
> > 
> > No, I just didn't test with a cursor plane. We should probably avoid
> > scaling the cursor plane and just adjust its position. Eric any opinion
> > on that?  
> 
> I don't think you can just not scale it. The user asked for the cursor
> to be at a specific place with a specific size. Can't just ignore
> that and do something else. Also eg. i915 would definitely scale the
> cursor since we'd just scale the entire crtc instead of scaling
> individual planes. Different drivers doing different things wouldn't
> be good.

Except in our case the scaling takes place before the composition, so
we don't have a choice.

> 
> >   
> > > 
> > > I'm also wondering if there's any way we can reconcile these border
> > > props with the scaling mode prop, should we ever wish to expose
> > > these props on connectors that already have the scaling mode prop.  
> > 
> > Nouveau seems to expose both, and I don't see why we couldn't.  
> 
> First of all the interaction of these borders with panels that have
> a fixed mode would need to be properly specified. Do we apply the
> borders against the user mode or the panel's native mode?

Hm, I'm a bit lost. Isn't crtc_state->mode supposed to contain the mode
that is about to be applied, no matter if it's a usermode or one of the
mode returned by the display? 

> I guess
> the latter would be a bit easier (would also match how the TV margins
> behave I suppose). But that does leave open the question of how
> would generic userspace know which case it's dealing with? Eg. if it
> wants to underscan by some specific percentage it has to calculate
> the borders based on the correct mode, otherwise the results aren't
> going to match the expectations.

I don't get it, sorry. Borders are relative to the mode applied by
userspace. So if it needs to express borders as a ratio of the
resolution, then for sure userspace will have to do the math, but I
don't see the problem here.


More information about the Nouveau mailing list