Mesa (master): lima: use 0 to poll if BO is busy in lima_bo_wait()
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Mon Sep 23 02:45:32 UTC 2019
Module: Mesa
Branch: master
Commit: 9f897a2b4cf2c0e222487470053a69de843f2084
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=9f897a2b4cf2c0e222487470053a69de843f2084
Author: Vasily Khoruzhick <anarsoul at gmail.com>
Date: Sat Sep 7 19:30:39 2019 -0700
lima: use 0 to poll if BO is busy in lima_bo_wait()
os_time_get_absolute_timeout(0) returns current time, while kernel
driver expects 0 as value to poll BO status and return immediately.
Fix it by setting abs_timeout to 0 if timeout_ns is 0
Reviewed-by: Qiang Yu <yuq825 at gmail.com>
Signed-off-by: Vasily Khoruzhick <anarsoul at gmail.com>
---
src/gallium/drivers/lima/lima_bo.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/src/gallium/drivers/lima/lima_bo.c b/src/gallium/drivers/lima/lima_bo.c
index bd1f6cf8c8c..b082d32afd8 100644
--- a/src/gallium/drivers/lima/lima_bo.c
+++ b/src/gallium/drivers/lima/lima_bo.c
@@ -326,7 +326,13 @@ struct lima_bo *lima_bo_import(struct lima_screen *screen,
bool lima_bo_wait(struct lima_bo *bo, uint32_t op, uint64_t timeout_ns)
{
- int64_t abs_timeout = os_time_get_absolute_timeout(timeout_ns);
+ int64_t abs_timeout;
+
+ if (timeout_ns == 0)
+ abs_timeout = 0;
+ else
+ abs_timeout = os_time_get_absolute_timeout(timeout_ns);
+
if (abs_timeout == OS_TIMEOUT_INFINITE)
abs_timeout = INT64_MAX;
More information about the mesa-commit
mailing list