From: Simon Ser Date: Mon, 14 Dec 2020 17:32:47 +0000 (+0100) Subject: dri: add createImageWithModifiers2 interface X-Git-Tag: upstream/21.2.3~3210 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=afd8b2f498a417de6ecdbd13045d97c9ecf4391b;p=platform%2Fupstream%2Fmesa.git dri: add createImageWithModifiers2 interface With the addition of createImageWithModifiers usage flags were dropped, as it was believed at the time that modifers will be a full replacement for the usage flags. This has turned out to be untrue, as modifiers are not able to describe buffer placement. Add a new version of the interface, that allows to specifiy use flags in addition to the modifier. Signed-off-by: Simon Ser Signed-off-by: Lucas Stach Reviewed-by: Daniel Stone Part-of: --- diff --git a/include/GL/internal/dri_interface.h b/include/GL/internal/dri_interface.h index 9b85e67..a7d9903 100644 --- a/include/GL/internal/dri_interface.h +++ b/include/GL/internal/dri_interface.h @@ -1328,7 +1328,7 @@ struct __DRIdri2ExtensionRec { * extensions. */ #define __DRI_IMAGE "DRI_IMAGE" -#define __DRI_IMAGE_VERSION 18 +#define __DRI_IMAGE_VERSION 19 /** * These formats correspond to the similarly named MESA_FORMAT_* @@ -1803,6 +1803,28 @@ struct __DRIimageExtensionRec { uint32_t flags, unsigned *error, void *loaderPrivate); + + /** + * Creates an image with implementation's favorite modifiers and the + * provided usage flags. + * + * This acts like createImageWithModifiers except usage is also specified. + * + * The created image should be destroyed with destroyImage(). + * + * Returns the new DRIimage. The chosen modifier can be obtained later on + * and passed back to things like the kernel's AddFB2 interface. + * + * \sa __DRIimageRec::createImage + * + * \since 19 + */ + __DRIimage *(*createImageWithModifiers2)(__DRIscreen *screen, + int width, int height, int format, + const uint64_t *modifiers, + const unsigned int modifier_count, + unsigned int use, + void *loaderPrivate); };