[PATCH 1/2] drm/atomic-helper: Add atomic_mode_set version to extend encoder mode_set

Daniel Vetter daniel at ffwll.ch
Fri Jul 22 16:56:50 UTC 2016


On Fri, Jul 22, 2016 at 06:53:41PM +0200, Daniel Vetter wrote:
> On Fri, Jul 22, 2016 at 02:09:12PM +0200, Philipp Zabel wrote:
> > Some encoders need more information from crtc and connector state
> > than just the mode. Add an atomic encoder mode setting variant
> > that passes the crtc state (which contains the modes) and the
> > connector state.
> > 
> > Signed-off-by: Philipp Zabel <p.zabel at pengutronix.de>
> > ---
> >  drivers/gpu/drm/drm_atomic_helper.c      |  6 +++++-
> >  include/drm/drm_modeset_helper_vtables.h | 20 ++++++++++++++++++++
> >  2 files changed, 25 insertions(+), 1 deletion(-)
> > 
> > diff --git a/drivers/gpu/drm/drm_atomic_helper.c b/drivers/gpu/drm/drm_atomic_helper.c
> > index de7fddc..a3c033f 100644
> > --- a/drivers/gpu/drm/drm_atomic_helper.c
> > +++ b/drivers/gpu/drm/drm_atomic_helper.c
> > @@ -880,8 +880,12 @@ crtc_set_mode(struct drm_device *dev, struct drm_atomic_state *old_state)
> >  		 * Each encoder has at most one connector (since we always steal
> >  		 * it away), so we won't call mode_set hooks twice.
> >  		 */
> > -		if (funcs && funcs->mode_set)
> > +		if (funcs && funcs->atomic_mode_set) {
> > +			funcs->atomic_mode_set(encoder, new_crtc_state,
> > +					       connector->state);
> > +		} else if (funcs && funcs->mode_set) {
> >  			funcs->mode_set(encoder, mode, adjusted_mode);
> > +		}
> >  
> >  		drm_bridge_mode_set(encoder->bridge, mode, adjusted_mode);
> >  	}
> > diff --git a/include/drm/drm_modeset_helper_vtables.h b/include/drm/drm_modeset_helper_vtables.h
> > index b55f218..1b15c1f 100644
> > --- a/include/drm/drm_modeset_helper_vtables.h
> > +++ b/include/drm/drm_modeset_helper_vtables.h
> > @@ -529,6 +529,26 @@ struct drm_encoder_helper_funcs {
> >  			 struct drm_display_mode *adjusted_mode);
> >  
> >  	/**
> > +	 * @atomic_mode_set:
> > +	 *
> > +	 * This callback is used to update the display mode of an encoder.
> > +	 *
> > +	 * Note that the display pipe is completely off when this function is
> > +	 * called. Drivers which need hardware to be running before they program
> > +	 * the new display mode (because they implement runtime PM) should not
> > +	 * use this hook, because the helper library calls it only once and not
> > +	 * every time the display pipeline is suspended using either DPMS or the
> > +	 * new "ACTIVE" property. Such drivers should instead move all their
> > +	 * encoder setup into the ->enable() callback.
> > +	 *
> > +	 * This callback is used by the atomic modeset helpers instead of the
> > +	 * mode_set callback. It is optional in the atomic helpers.
> 
> s/mode_set/@mode_set/ Also pls a bit of text when this should be used (any
> time you need to inspect connector state, since there's no direct way to
> go from the encoder to the current connector). And pls add a note to
> @mode_set that drivers should use @atomic_mode_set in such a case, for
> cross linking.
> 
> Great docs matter ;-)
> 
> While at it I noticed that the kernel-doc for @mode_set is wrong, it says
> it's only used by CRTC helpers. Can you pls fix that too?

Strike that part, I accidentally read the kerneldoc for crtc->mode_fixup.
-Daniel
-- 
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch


More information about the dri-devel mailing list