From 29b85234cee5b44b1297af881a420b68763f294a Mon Sep 17 00:00:00 2001 From: Wyatt Borsos Date: Thu, 9 May 2024 10:36:22 -0700 Subject: [PATCH] Let users pass max_threads manually as an argument --- src/pillow_avif/AvifImagePlugin.py | 2 +- src/pillow_avif/_avif.c | 12 ++++++++---- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/src/pillow_avif/AvifImagePlugin.py b/src/pillow_avif/AvifImagePlugin.py index 80dfb52..e888b71 100644 --- a/src/pillow_avif/AvifImagePlugin.py +++ b/src/pillow_avif/AvifImagePlugin.py @@ -62,7 +62,7 @@ def load_seek(self, pos): def _open(self): self._decoder = _avif.AvifDecoder( - self.fp.read(), DECODE_CODEC_CHOICE, CHROMA_UPSAMPLING + self.fp.read(), DECODE_CODEC_CHOICE, CHROMA_UPSAMPLING, DEFAULT_MAX_THREADS ) # Get info from decoder diff --git a/src/pillow_avif/_avif.c b/src/pillow_avif/_avif.c index 59516f8..0fece9e 100644 --- a/src/pillow_avif/_avif.c +++ b/src/pillow_avif/_avif.c @@ -731,10 +731,11 @@ AvifDecoderNew(PyObject *self_, PyObject *args) { char *codec_str; avifCodecChoice codec; avifChromaUpsampling upsampling; + int max_threads = 0; avifResult result; - if (!PyArg_ParseTuple(args, "Sss", &avif_bytes, &codec_str, &upsampling_str)) { + if (!PyArg_ParseTuple(args, "Sssi", &avif_bytes, &codec_str, &upsampling_str, &max_threads)) { return NULL; } @@ -782,10 +783,13 @@ AvifDecoderNew(PyObject *self_, PyObject *args) { self->decoder = avifDecoderCreate(); #if AVIF_VERSION >= 80400 - if (default_max_threads == 0) { - init_max_threads(); + if (max_threads == 0) { + if (default_max_threads == 0) { + init_max_threads(); + } + max_threads = default_max_threads; } - self->decoder->maxThreads = default_max_threads; + self->decoder->maxThreads = max_threads; #endif self->decoder->codecChoice = codec;