summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarton Balint <cus@passwd.hu>2022-03-14 21:02:18 +0100
committerMarton Balint <cus@passwd.hu>2022-03-16 20:20:56 +0100
commitd5722d578e6dd713c2b81536c23151044e0eb96f (patch)
treeccf2e9028d09d5985afaf46994b04d7dfa491b67
parentc0351ee5c58e0640066d0430a8c9af88a3918504 (diff)
avfilter/vf_zscale: properly check return value of slice threads
Signed-off-by: Marton Balint <cus@passwd.hu>
-rw-r--r--libavfilter/vf_zscale.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/libavfilter/vf_zscale.c b/libavfilter/vf_zscale.c
index bab87b0c94..ceefc95224 100644
--- a/libavfilter/vf_zscale.c
+++ b/libavfilter/vf_zscale.c
@@ -117,6 +117,7 @@ typedef struct ZScaleContext {
void *tmp[MAX_THREADS]; //separate for each thread;
int nb_threads;
+ int jobs_ret[MAX_THREADS];
zimg_image_format src_format, dst_format;
zimg_image_format alpha_src_format, alpha_dst_format;
@@ -858,12 +859,14 @@ static int filter_frame(AVFilterLink *link, AVFrame *in)
td.desc = desc;
td.odesc = odesc;
- ret = ff_filter_execute(ctx, filter_slice, &td, NULL, s->nb_threads);
- if (ret < 0 || !s->graph[0]) {
+ memset(s->jobs_ret, 0, s->nb_threads * sizeof(*s->jobs_ret));
+ ret = ff_filter_execute(ctx, filter_slice, &td, s->jobs_ret, s->nb_threads);
+ for (int i = 0; ret >= 0 && i < s->nb_threads; i++)
+ if (s->jobs_ret[i] < 0)
+ ret = s->jobs_ret[i];
+ if (ret < 0) {
av_frame_free(&in);
av_frame_free(&out);
- if (ret >= 0)
- ret = AVERROR(EINVAL);
return ret;
}