OSDN Git Service

drm/modifiers: Enforce consistency between the cap an IN_FORMATS
authorDaniel Vetter <daniel.vetter@ffwll.ch>
Thu, 6 May 2021 13:23:43 +0000 (15:23 +0200)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Wed, 12 May 2021 09:31:29 +0000 (11:31 +0200)
commitbfebd42d5609848de3c5b5723e56f2e6f08ca8ec
tree1db9d3d255c500a6b77d9a171881b616e60188d4
parentdda6024b57c03f2f7708f019ba6511743d5f5630
drm/modifiers: Enforce consistency between the cap an IN_FORMATS

It's very confusing for userspace to have to deal with inconsistencies
here, and some drivers screwed this up a bit. Most just ommitted the
format list when they meant to say that only linear modifier is
allowed, but some also meant that only implied modifiers are
acceptable (because actually none of the planes registered supported
modifiers).

Now that this is all done consistently across all drivers, document
the rules and enforce it in the drm core.

v2:
- Make the capability a link (Simon)
- Note that all is lost before 5.1.

v3:
- Use drm_WARN_ON (Lyude)

Acked-by: Pekka Paalanen <pekka.paalanen@collabora.com>
Reviewed-by: Emil Velikov <emil.velikov@collabora.com>
Reviewed-by: Lyude Paul <lyude@redhat.com>
Acked-by: Maxime Ripard <maxime@cerno.tech>
Cc: Simon Ser <contact@emersion.fr>
Reviewed-by: Lucas Stach <l.stach@pengutronix.de>
Cc: Pekka Paalanen <pekka.paalanen@collabora.com>
Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
Cc: Maxime Ripard <mripard@kernel.org>
Cc: Thomas Zimmermann <tzimmermann@suse.de>
Cc: David Airlie <airlied@linux.ie>
Cc: Daniel Vetter <daniel@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20210506132343.2873699-1-daniel.vetter@ffwll.ch
drivers/gpu/drm/drm_plane.c
include/drm/drm_mode_config.h