anv: Fix deadlock in anv_timelines_wait
Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/2945
Fixes: 34f32a6d66
Signed-off-by: Danylo Piliaiev <danylo.piliaiev@globallogic.com>
Reviewed-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/5005>
This commit is contained in:
parent
c059b22707
commit
06b6c687e2
|
@ -2246,9 +2246,10 @@ anv_timelines_wait(struct anv_device *device,
|
||||||
uint64_t abs_timeout_ns)
|
uint64_t abs_timeout_ns)
|
||||||
{
|
{
|
||||||
if (!wait_all && n_timelines > 1) {
|
if (!wait_all && n_timelines > 1) {
|
||||||
|
pthread_mutex_lock(&device->mutex);
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
VkResult result;
|
VkResult result;
|
||||||
pthread_mutex_lock(&device->mutex);
|
|
||||||
for (uint32_t i = 0; i < n_timelines; i++) {
|
for (uint32_t i = 0; i < n_timelines; i++) {
|
||||||
result =
|
result =
|
||||||
anv_timeline_wait_locked(device, timelines[i], serials[i], 0);
|
anv_timeline_wait_locked(device, timelines[i], serials[i], 0);
|
||||||
|
|
Loading…
Reference in New Issue