PKGBUILDs/extra/mesa/0002-iris-Retry-DRM_IOCTL_I915_GEM_EXECBUFFER2-on-ENOMEM.patch

52 lines
2 KiB
Diff
Raw Normal View History

2023-01-13 11:55:59 +00:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Kai-Heng Feng <kai.heng.feng@canonical.com>
Date: Thu, 29 Dec 2022 13:43:27 +0800
Subject: [PATCH] iris: Retry DRM_IOCTL_I915_GEM_EXECBUFFER2 on ENOMEM
2023-03-21 23:28:08 +00:00
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
2023-01-13 11:55:59 +00:00
We are seeing endless DRM_IOCTL_SYNCOBJ_WAIT ioctl when system memory is
under pressured.
Commit f9d8d9acbb6a ("iris: Avoid abort() if kernel can't allocate
memory") avoids the abort() on ENOMEM by resetting the batch. However,
when there's an ongoing OpenGL query, resetting the batch will make the
snapshots_landed never be flipped, so iris_get_query_result() gets stuck
in the while loop forever.
Since there's no guarantee that the next batch after resetting won't hit
ENOMEM, so instead of resetting the batch, be patient and wait until kernel has
enough memory. Once the batch is submiited and snapshots_landed gets
flipped, iris_get_query_result() can proceed normally.
2023-03-21 23:28:08 +00:00
Reviewed-by: José Roberto de Souza <jose.souza@intel.com>
2023-01-13 11:55:59 +00:00
Closes: https://gitlab.freedesktop.org/drm/intel/-/issues/6851
2023-03-21 23:28:08 +00:00
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/20449>
2023-01-13 11:55:59 +00:00
---
src/gallium/drivers/iris/iris_batch.c | 11 ++++++++---
1 file changed, 8 insertions(+), 3 deletions(-)
diff --git a/src/gallium/drivers/iris/iris_batch.c b/src/gallium/drivers/iris/iris_batch.c
2023-03-21 23:28:08 +00:00
index c7a08a0e1f5f..deab85ce4aaf 100644
2023-01-13 11:55:59 +00:00
--- a/src/gallium/drivers/iris/iris_batch.c
+++ b/src/gallium/drivers/iris/iris_batch.c
2023-03-21 23:28:08 +00:00
@@ -981,9 +981,14 @@ submit_batch(struct iris_batch *batch)
2023-01-13 11:55:59 +00:00
}
int ret = 0;
2023-03-21 23:28:08 +00:00
- if (!batch->screen->devinfo->no_hw &&
2023-01-13 11:55:59 +00:00
- intel_ioctl(batch->screen->fd, DRM_IOCTL_I915_GEM_EXECBUFFER2, &execbuf))
- ret = -errno;
2023-03-21 23:28:08 +00:00
+ if (!batch->screen->devinfo->no_hw) {
2023-01-13 11:55:59 +00:00
+ do {
+ ret = intel_ioctl(batch->screen->fd, DRM_IOCTL_I915_GEM_EXECBUFFER2, &execbuf);
+ } while (ret && errno == ENOMEM);
+
+ if (ret)
2023-03-21 23:28:08 +00:00
+ ret = -errno;
2023-01-13 11:55:59 +00:00
+ }
simple_mtx_unlock(bo_deps_lock);