[PATCH igt v7 4/4] kms_atomic: Add basic atomic modesetting tests

Daniel Vetter daniel at ffwll.ch
Fri Oct 30 03:44:15 PDT 2015


On Thu, Oct 29, 2015 at 11:33:48AM +0000, Emil Velikov wrote:
> Hi Dan,
> 
> Suspecting that these were meant for the intel-gfx list, although I
> doubt people will object seeing them here :-)
> 
> On 29 October 2015 at 10:35, Daniel Stone <daniels at collabora.com> wrote:
> > Add tests for KMS atomic modesetting, to exercise the basic interface
> > and test failure/corner cases. Should ensure coherency between the
> > legacy and atomic interfaces.
> >
> > v2: New patch.
> > v3: Disable connector checking for now, as it was causing GPU hangs on
> >     newer kernels.
> > v4: Rebase.
> > v5: Use do_ioctl or do_ioctl_err consistently. Use igt_assert_*()
> >     helper macros rather than igt_assert() directly.
> >     Move assertions into helper/check functions. Define atomic commit
> >     helper.
> > v6: Use do_ioctl_err, and define macros to move errors to
> >     actual callsite, rather than helper functions.
> > v7: Fix RELAX_MODE thinko and refresh CRTC state in find_crtc.
> >
> > Co-authored-by: Micah Fedke <micah.fedke at collabora.com>
> > Signed-off-by: Daniel Stone <daniels at collabora.com>
> > ---
> >  configure.ac           |    2 +-
> >  tests/.gitignore       |    1 +
> >  tests/Makefile.sources |    1 +
> >  tests/kms_atomic.c     | 1345 ++++++++++++++++++++++++++++++++++++++++++++++++
> >  4 files changed, 1348 insertions(+), 1 deletion(-)
> >  create mode 100644 tests/kms_atomic.c
> >
> > diff --git a/configure.ac b/configure.ac
> > index 5f97466..97de58a 100644
> > --- a/configure.ac
> > +++ b/configure.ac
> > @@ -85,7 +85,7 @@ if test "x$GCC" = "xyes"; then
> >  fi
> >  AC_SUBST(ASSEMBLER_WARN_CFLAGS)
> >
> > -PKG_CHECK_MODULES(DRM, [libdrm_intel >= 2.4.55 libdrm])
> > +PKG_CHECK_MODULES(DRM, [libdrm_intel >= 2.4.64 libdrm])
> Afaics you're not using anything intel specific here. I'd suspect one
> wants to bump (add) the libdrm version, this way igt can remove a lot
> of the local duplication.
> 
> [snip]
> > --- /dev/null
> > +++ b/tests/kms_atomic.c
> [snip]
> > +#ifndef DRM_CLIENT_CAP_ATOMIC
> > +#define DRM_CLIENT_CAP_ATOMIC 3
> > +#endif
> > +
> > +#ifndef DRM_CAP_CURSOR_WIDTH
> > +#define DRM_CAP_CURSOR_WIDTH 0x8
> > +#endif
> > +
> > +#ifndef DRM_CAP_CURSOR_HEIGHT
> > +#define DRM_CAP_CURSOR_HEIGHT 0x9
> > +#endif
> > +
> > +#ifndef DRM_MODE_ATOMIC_TEST_ONLY
> > +#define DRM_MODE_ATOMIC_TEST_ONLY 0x0100
> > +#define DRM_MODE_ATOMIC_NONBLOCK 0x0200
> > +#define DRM_MODE_ATOMIC_ALLOW_MODESET 0x0400
> > +
> > +struct drm_mode_atomic {
> > +       __u32 flags;
> > +       __u32 count_objs;
> > +       __u64 objs_ptr;
> > +       __u64 count_props_ptr;
> > +       __u64 props_ptr;
> > +       __u64 prop_values_ptr;
> > +       __u64 reserved;
> > +       __u64 user_data;
> > +};
> > +#endif
> > +
> ... like the above but we still need the cursor bits :-(
> 
> [snip]
> > +#define MAX_PLANES 15
> > +#define MAX_CRTCS 3
> > +#define MAX_CONNECTORS 8
> > +
> Worth adding a note where these MAX values come from - intel specific,
> educated guess, etc ?

They're definitely too low for radeon (has up to 6 crtcs) and iirc other
limits are similarly funky. I guess we could go with kmalloc or just make
the limits something huge like 256 or so.
-Daniel

> 
> [snip]
> > +#if 0
> > +/* XXX: Checking this repeatedly actually hangs the GPU. I have literally no
> > + *      idea why. */
> > +static void
> > +connector_check_current_state(struct kms_atomic_connector_state *connector)
> Perhaps add a reference to the bugzilla ticket/discussion thread ?
> 
> As it goes - just my 2c, fwiw.
> 
> Cheers,
> Emil
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel

-- 
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch


More information about the dri-devel mailing list