summaryrefslogtreecommitdiff
path: root/libavcodec/imc.c
diff options
context:
space:
mode:
authorAndreas Rheinhardt <andreas.rheinhardt@gmail.com>2020-11-15 11:42:24 +0100
committerAndreas Rheinhardt <andreas.rheinhardt@gmail.com>2020-12-08 17:51:45 +0100
commit33aaf86192f5ad15e3252c1691dafdcf63885692 (patch)
tree1f6d418bfc14ccee524adc529926cff0b706c4d3 /libavcodec/imc.c
parent83ff99adc4bf04c4ba2e3436ce2d18a5098132d1 (diff)
avcodec/imc: Make imc/iac decoders init-threadsafe
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com>
Diffstat (limited to 'libavcodec/imc.c')
-rw-r--r--libavcodec/imc.c35
1 files changed, 22 insertions, 13 deletions
diff --git a/libavcodec/imc.c b/libavcodec/imc.c
index deb88d4d5d..c26d8b0149 100644
--- a/libavcodec/imc.c
+++ b/libavcodec/imc.c
@@ -38,6 +38,7 @@
#include "libavutil/ffmath.h"
#include "libavutil/float_dsp.h"
#include "libavutil/internal.h"
+#include "libavutil/thread.h"
#include "avcodec.h"
#include "bswapdsp.h"
#include "get_bits.h"
@@ -171,10 +172,27 @@ static av_cold void iac_generate_tabs(IMCContext *q, int sampling_rate)
}
}
+static av_cold void imc_init_static(void)
+{
+ /* initialize the VLC tables */
+ for (int i = 0, offset = 0; i < 4 ; i++) {
+ for (int j = 0; j < 4; j++) {
+ huffman_vlc[i][j].table = &vlc_tables[offset];
+ huffman_vlc[i][j].table_allocated = VLC_TABLES_SIZE - offset;;
+ ff_init_vlc_from_lengths(&huffman_vlc[i][j], IMC_VLC_BITS, imc_huffman_sizes[i],
+ imc_huffman_lens[i][j], 1,
+ imc_huffman_syms[i][j], 1, 1,
+ 0, INIT_VLC_STATIC_OVERLONG, NULL);
+ offset += huffman_vlc[i][j].table_size;
+ }
+ }
+}
+
static av_cold int imc_decode_init(AVCodecContext *avctx)
{
int i, j, ret;
IMCContext *q = avctx->priv_data;
+ static AVOnce init_static_once = AV_ONCE_INIT;
AVFloatDSPContext *fdsp;
double r1, r2;
@@ -229,19 +247,6 @@ static av_cold int imc_decode_init(AVCodecContext *avctx)
for (i = 0; i < 30; i++)
q->sqrt_tab[i] = sqrt(i);
- /* initialize the VLC tables */
- for (int i = 0, offset = 0; i < 4 ; i++) {
- for (j = 0; j < 4; j++) {
- huffman_vlc[i][j].table = &vlc_tables[offset];
- huffman_vlc[i][j].table_allocated = VLC_TABLES_SIZE - offset;;
- ff_init_vlc_from_lengths(&huffman_vlc[i][j], IMC_VLC_BITS, imc_huffman_sizes[i],
- imc_huffman_lens[i][j], 1,
- imc_huffman_syms[i][j], 1, 1,
- 0, INIT_VLC_STATIC_OVERLONG, NULL);
- offset += huffman_vlc[i][j].table_size;
- }
- }
-
if (avctx->codec_id == AV_CODEC_ID_IAC) {
iac_generate_tabs(q, avctx->sample_rate);
} else {
@@ -266,6 +271,8 @@ static av_cold int imc_decode_init(AVCodecContext *avctx)
avctx->channel_layout = avctx->channels == 1 ? AV_CH_LAYOUT_MONO
: AV_CH_LAYOUT_STEREO;
+ ff_thread_once(&init_static_once, imc_init_static);
+
return 0;
}
@@ -1088,6 +1095,7 @@ AVCodec ff_imc_decoder = {
.capabilities = AV_CODEC_CAP_DR1,
.sample_fmts = (const enum AVSampleFormat[]) { AV_SAMPLE_FMT_FLTP,
AV_SAMPLE_FMT_NONE },
+ .caps_internal = FF_CODEC_CAP_INIT_THREADSAFE,
};
#endif
#if CONFIG_IAC_DECODER
@@ -1104,5 +1112,6 @@ AVCodec ff_iac_decoder = {
.capabilities = AV_CODEC_CAP_DR1,
.sample_fmts = (const enum AVSampleFormat[]) { AV_SAMPLE_FMT_FLTP,
AV_SAMPLE_FMT_NONE },
+ .caps_internal = FF_CODEC_CAP_INIT_THREADSAFE,
};
#endif