summaryrefslogtreecommitdiff
path: root/src/mesa/drivers
diff options
context:
space:
mode:
authorKenneth Graunke <kenneth@whitecape.org>2021-05-20 13:04:15 -0700
committerMarge Bot <eric+marge@anholt.net>2021-05-21 01:10:47 +0000
commite9e953ff943475806079d949b37974ce7e63c556 (patch)
treefe7b149bbcbe96b50ad902e9c061be1c32733683 /src/mesa/drivers
parent50a5cb000c9ec9be9248cc957a18a5878a687652 (diff)
i965: Don't advertise Y-tiled modifiers for scanout buffers on Gfx8-
According to isl_gfx7.c:264, the display engine does not support Y tiled buffers prior to Skylake. But we exposed I915_FORMAT_MOD_Y_TILED even when querying for a list of modifiers with __DRI_IMAGE_USE_SCANOUT set, which we can't support. That led to crashes later when we tried to create such an image, and isl rightly denied it. This duplicates a bit of code from ISL, but the isl_gfx6_filter_tiling function that we ought to use to filter things relies on surf_info, which we don't have at this stage. This is probably good enough. Fixes crashes in wflinfo since c03e79d7831f, but the bug exists before that and it's probably worth a stable backport even without that patch. Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/4815 Fixes: c03e79d7831 ("loader/dri: hook up createImageWithModifiers2") Reviewed-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com> Cc: mesa-stable Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/10907>
Diffstat (limited to 'src/mesa/drivers')
-rw-r--r--src/mesa/drivers/dri/i965/brw_screen.c18
1 files changed, 12 insertions, 6 deletions
diff --git a/src/mesa/drivers/dri/i965/brw_screen.c b/src/mesa/drivers/dri/i965/brw_screen.c
index 835b711729f..32f220c0611 100644
--- a/src/mesa/drivers/dri/i965/brw_screen.c
+++ b/src/mesa/drivers/dri/i965/brw_screen.c
@@ -357,7 +357,7 @@ static const struct {
static bool
modifier_is_supported(const struct intel_device_info *devinfo,
const struct brw_image_format *fmt, int dri_format,
- uint64_t modifier)
+ unsigned use, uint64_t modifier)
{
const struct isl_drm_modifier_info *modinfo =
isl_drm_modifier_get_info(modifier);
@@ -367,6 +367,11 @@ modifier_is_supported(const struct intel_device_info *devinfo,
if (!modinfo)
return false;
+ if (devinfo->ver < 9 && (use & __DRI_IMAGE_USE_SCANOUT) &&
+ !(modinfo->tiling == ISL_TILING_LINEAR ||
+ modinfo->tiling == ISL_TILING_X))
+ return false;
+
if (modinfo->aux_usage == ISL_AUX_USAGE_CCS_E) {
/* If INTEL_DEBUG=norbc is set, don't support any CCS_E modifiers */
if (INTEL_DEBUG & DEBUG_NO_RBC)
@@ -687,13 +692,14 @@ const uint64_t priority_to_modifier[] = {
static uint64_t
select_best_modifier(struct intel_device_info *devinfo,
int dri_format,
+ unsigned use,
const uint64_t *modifiers,
const unsigned count)
{
enum modifier_priority prio = MODIFIER_PRIORITY_INVALID;
for (int i = 0; i < count; i++) {
- if (!modifier_is_supported(devinfo, NULL, dri_format, modifiers[i]))
+ if (!modifier_is_supported(devinfo, NULL, dri_format, use, modifiers[i]))
continue;
switch (modifiers[i]) {
@@ -743,7 +749,7 @@ brw_create_image_common(__DRIscreen *dri_screen,
if (modifier == DRM_FORMAT_MOD_INVALID) {
if (modifiers) {
/* User requested specific modifiers */
- modifier = select_best_modifier(&screen->devinfo, format,
+ modifier = select_best_modifier(&screen->devinfo, format, use,
modifiers, count);
if (modifier == DRM_FORMAT_MOD_INVALID)
return NULL;
@@ -992,7 +998,7 @@ brw_query_format_modifier_attribs(__DRIscreen *dri_screen,
struct brw_screen *screen = dri_screen->driverPrivate;
const struct brw_image_format *f = brw_image_format_lookup(fourcc);
- if (!modifier_is_supported(&screen->devinfo, f, 0, modifier))
+ if (!modifier_is_supported(&screen->devinfo, f, 0, 0, modifier))
return false;
switch (attrib) {
@@ -1108,7 +1114,7 @@ brw_create_image_from_fds_common(__DRIscreen *dri_screen,
return NULL;
if (modifier != DRM_FORMAT_MOD_INVALID &&
- !modifier_is_supported(&screen->devinfo, f, 0, modifier))
+ !modifier_is_supported(&screen->devinfo, f, 0, 0, modifier))
return NULL;
if (f->nplanes == 1)
@@ -1420,7 +1426,7 @@ brw_query_dma_buf_modifiers(__DRIscreen *_screen, int fourcc, int max,
for (i = 0; i < ARRAY_SIZE(supported_modifiers); i++) {
uint64_t modifier = supported_modifiers[i].modifier;
- if (!modifier_is_supported(&screen->devinfo, f, 0, modifier))
+ if (!modifier_is_supported(&screen->devinfo, f, 0, 0, modifier))
continue;
num_mods++;