PR #21654 opened by Steven Xiao (younengxiao)
URL: https://code.ffmpeg.org/FFmpeg/FFmpeg/pulls/21654
Patch URL: https://code.ffmpeg.org/FFmpeg/FFmpeg/pulls/21654.patch

When using `dnn_processing` filter with torch backend, FFmpeg hangs 
indefinitely because no inference is actually performed.
Resolve this problem by add "else" branch for synchronous execution path.

Usage:
    ffmpeg -i input.mp4 -vf 
scale=224:224,format=rgb24,dnn_processing=dnn_backend=torch:model=sr_model_torch.pt:device=cpu
 output.mp4


>From 5b5324d6242eee72cba10365ac9c36ad69481d78 Mon Sep 17 00:00:00 2001
From: stevxiao <[email protected]>
Date: Thu, 5 Feb 2026 11:34:07 -0500
Subject: [PATCH] avfilter/dnn: add synchronous execution path in torch backend

When using `dnn_processing` filter with torch backend, FFmpeg hangs 
indefinitely because no inference is actually performed.
Resolve this problem by add "else" branch for synchronous execution path.

Usage:
    ffmpeg -i input.mp4 -vf 
scale=224:224,format=rgb24,dnn_processing=dnn_backend=torch:model=sr_model_torch.pt:device=cpu
 output.mp4
---
 libavfilter/dnn/dnn_backend_torch.cpp | 8 ++++++++
 1 file changed, 8 insertions(+)

diff --git a/libavfilter/dnn/dnn_backend_torch.cpp 
b/libavfilter/dnn/dnn_backend_torch.cpp
index 33809bf983..56fbe372d1 100644
--- a/libavfilter/dnn/dnn_backend_torch.cpp
+++ b/libavfilter/dnn/dnn_backend_torch.cpp
@@ -424,6 +424,14 @@ static int execute_model_th(THRequestItem *request, Queue 
*lltask_queue)
         }
         th_model->cond->notify_one();
         return 0;
+    } else {
+        // Synchronous execution path
+        ret = th_start_inference((void *)(request));
+        if (ret != 0) {
+            goto err;
+        }
+        infer_completion_callback(request);
+        return (task->inference_done == task->inference_todo) ? 0 : 
DNN_GENERIC_ERROR;
     }
 
 err:
-- 
2.52.0

_______________________________________________
ffmpeg-devel mailing list -- [email protected]
To unsubscribe send an email to [email protected]

Reply via email to