[PATCH 13/13] RFC: drm: Atomic modeset ioctl
Daniel Vetter
daniel at ffwll.ch
Wed Dec 17 03:18:41 PST 2014
On Wed, Dec 17, 2014 at 06:31:13PM +0900, Michel Dänzer wrote:
> On 17.12.2014 16:20, Pekka Paalanen wrote:
> > On Wed, 17 Dec 2014 11:48:51 +0900
> > Michel Dänzer <michel at daenzer.net> wrote:
> >
> >> On 17.12.2014 08:05, Rob Clark wrote:
> >>> The atomic modeset ioctl can be used to push any number of new values
> >>> for object properties. The driver can then check the full device
> >>> configuration as single unit, and try to apply the changes atomically.
> >>>
> >>> The ioctl simply takes a list of object IDs and property IDs and their
> >>> values.
> >>
> >> [...]
> >>
> >>> diff --git a/include/uapi/drm/drm_mode.h b/include/uapi/drm/drm_mode.h
> >>> index 86574b0..3459778 100644
> >>> --- a/include/uapi/drm/drm_mode.h
> >>> +++ b/include/uapi/drm/drm_mode.h
> >>> @@ -519,4 +519,25 @@ struct drm_mode_destroy_dumb {
> >>> uint32_t handle;
> >>> };
> >>>
> >>> +/* page-flip flags are valid, plus: */
> >>> +#define DRM_MODE_ATOMIC_TEST_ONLY 0x0100
> >>> +#define DRM_MODE_ATOMIC_NONBLOCK 0x0200
> >>> +
> >>> +#define DRM_MODE_ATOMIC_FLAGS (\
> >>> + DRM_MODE_PAGE_FLIP_EVENT |\
> >>> + DRM_MODE_PAGE_FLIP_ASYNC |\
> >>> + DRM_MODE_ATOMIC_TEST_ONLY |\
> >>> + DRM_MODE_ATOMIC_NONBLOCK)
> >>> +
> >>> +struct drm_mode_atomic {
> >>> + __u32 flags;
> >>> + __u32 count_objs;
> >>> + __u64 objs_ptr;
> >>> + __u64 count_props_ptr;
> >>> + __u64 props_ptr;
> >>> + __u64 prop_values_ptr;
> >>> + __u64 blob_values_ptr; /* remove? */
> >>> + __u64 user_data;
> >>> +};
> >>> +
> >>> #endif
> >>>
> >>
> >> The new ioctl(s) should take an explicit parameter specifying when the
> >> changes should take effect. And since variable refresh rate displays are
> >> becoming mainstream, that parameter should probably be a timestamp
> >> rather than a frame counter.
> >
> > That sounds cool to me, but also a rabbit hole. While having worked on
> > the Wayland Presentation queueing extension, I'd like to ask the
> > following questions:
> >
> > - If you set the atomic kick to happen in the future, is there any way
> > to cancel it? I'd be ok with not being able to cancel initially, but
> > if one wants to add that later, we should already know how to
> > reference this atomic submission in the cancel request. What if user
> > space has a bug and schedules an update at one hour or three days from
> > now, how would we abort that?
> >
> > - Can you VT-switch or drop DRM master if you have a pending atomic
> > update?
> >
> > - Should one be able to set multiple pending atomic updates?
> >
> > - If I schedule an atomic update for one CTRC, can I schedule another
> > update for another CRTC before the first one completes? Or am I
> > forced to gather all updates over all outputs in the same atomic
> > submission even if I don't care about or want inter-output sync and
> > the outputs might even be running at different refresh rates?
> > (Actually, this seems to be a valid question even without any target
> > time parameter.)
> >
> > - If there can be multiple pending atomic updates on the same DRM
> > device, is there any way to guarantee that the
> > DRM_MODE_ATOMIC_TEST_ONLY results will be accurate also when the
> > atomic update actually kicks in? Another update may have changed the
> > configuration before this update kicks in, which means the overall
> > state isn't the same that was tested.
> >
> > - Does a pending atomic update prevent immediate (old style) KMS
> > changes?
> >
> > - Assuming hardware cannot do arbitrary time updates, how do you round
> > the given timestamp? Strictly "not before" given time? Round to
> > nearest possible time? The effect of required vs. unwanted sync to
> > vblank?
> >
> > - How would user space match the page flip event to the atomic
> > submission it did?
> >
> > I wonder if there is a way to postpone these hard(?) questions, so that
> > we could have atomic sooner and add scheduling later? I would imagine
> > solving everything above is quite some work.
>
> I agree. The main reason I brought it up is because I'd like to avoid
> getting into the same situation as with the current
> DRM_IOCTL_MODE_PAGE_FLIP ioctl, which doesn't explicitly communicate
> between userspace and kernel when the flip is supposed/expected to
> occur. We recently had to jump through some hoops in the radeon kernel
> driver to prevent flips from occurring sooner than expected by userspace.
The current approach is to ask for a vblank event 1 frame earlier in the
ddx and schedule the flip when you receive that. And hope for the best.
There shouldn't be anything really required in the kernel.
> But I also think it would be a shame at this point to add new ioctls
> which aren't designed with variable refresh rate displays in mind.
Let's please not aim for the kitchen sink, we won't get this in anytime
soon otherwise. And there is _lots_ more little features all over that we
want but don't yet have:
- update rectangle for manual/selective update panels
- async flips/flip merging and precise semantics
- integration with android syncpts
- flip queues and cancelling flips
- ...
It doesn't make sense to add everything in v1. And the atomic ioctl
extends fairly well (maybe we need write-only properties for some of this
stuff). Worst case we get atomic_2/3/4 ioctls. After all we're fairly good
at rev'ing interface in drm.
-Daniel
--
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch
More information about the dri-devel
mailing list