]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
dma-buf: fix timeout handling in dma_resv_wait_timeout v2
authorChristian König <christian.koenig@amd.com>
Sat, 12 Jul 2025 09:23:25 +0000 (05:23 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 17 Jul 2025 16:27:58 +0000 (18:27 +0200)
[ Upstream commit 2b95a7db6e0f75587bffddbb490399cbb87e4985 ]

Even the kerneldoc says that with a zero timeout the function should not
wait for anything, but still return 1 to indicate that the fences are
signaled now.

Unfortunately that isn't what was implemented, instead of only returning
1 we also waited for at least one jiffies.

Fix that by adjusting the handling to what the function is actually
documented to do.

v2: improve code readability

Reported-by: Marek Olšák <marek.olsak@amd.com>
Reported-by: Lucas Stach <l.stach@pengutronix.de>
Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Lucas Stach <l.stach@pengutronix.de>
Cc: <stable@vger.kernel.org>
Link: https://lore.kernel.org/r/20250129105841.1806-1-christian.koenig@amd.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/dma-buf/dma-resv.c

index 1187e5e80eded5fbbe76da0fb6558a3b2e47598d..539cb4e0433865cbe1254f77b7f67a075e5d906e 100644 (file)
@@ -591,7 +591,7 @@ retry:
                        goto retry;
                }
 
-               ret = dma_fence_wait_timeout(fence, intr, ret);
+               ret = dma_fence_wait_timeout(fence, intr, timeout);
                dma_fence_put(fence);
                if (ret > 0 && wait_all && (i + 1 < shared_count))
                        goto retry;