mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-08 13:22:53 +02:00
avcodec/aacdec_template: Deduplicate common part of aac_decode_init()
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
This commit is contained in:
parent
980a55fb46
commit
9de66fd449
@ -32,10 +32,12 @@
|
|||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
|
#include "libavcodec/aac.h"
|
||||||
#include "libavcodec/aacsbr.h"
|
#include "libavcodec/aacsbr.h"
|
||||||
#include "libavcodec/aacdec.h"
|
#include "libavcodec/aacdec.h"
|
||||||
#include "libavcodec/avcodec.h"
|
#include "libavcodec/avcodec.h"
|
||||||
#include "libavutil/attributes.h"
|
#include "libavutil/attributes.h"
|
||||||
|
#include "libavutil/error.h"
|
||||||
#include "libavutil/log.h"
|
#include "libavutil/log.h"
|
||||||
#include "libavutil/macros.h"
|
#include "libavutil/macros.h"
|
||||||
#include "libavutil/mem.h"
|
#include "libavutil/mem.h"
|
||||||
@ -76,6 +78,46 @@ av_cold int ff_aac_decode_close(AVCodecContext *avctx)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
av_cold int ff_aac_decode_init_common(AVCodecContext *avctx)
|
||||||
|
{
|
||||||
|
AACDecContext *ac = avctx->priv_data;
|
||||||
|
int is_fixed = ac->is_fixed, ret;
|
||||||
|
float scale_fixed, scale_float;
|
||||||
|
const float *const scalep = is_fixed ? &scale_fixed : &scale_float;
|
||||||
|
enum AVTXType tx_type = is_fixed ? AV_TX_INT32_MDCT : AV_TX_FLOAT_MDCT;
|
||||||
|
|
||||||
|
if (avctx->ch_layout.nb_channels > MAX_CHANNELS) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "Too many channels\n");
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
}
|
||||||
|
|
||||||
|
ac->random_state = 0x1f2e3d4c;
|
||||||
|
|
||||||
|
#define MDCT_INIT(s, fn, len, sval) \
|
||||||
|
scale_fixed = (sval) * 128.0f; \
|
||||||
|
scale_float = (sval) / 32768.0f; \
|
||||||
|
ret = av_tx_init(&s, &fn, tx_type, 1, len, scalep, 0); \
|
||||||
|
if (ret < 0) \
|
||||||
|
return ret
|
||||||
|
|
||||||
|
MDCT_INIT(ac->mdct120, ac->mdct120_fn, 120, 1.0/120);
|
||||||
|
MDCT_INIT(ac->mdct128, ac->mdct128_fn, 128, 1.0/128);
|
||||||
|
MDCT_INIT(ac->mdct480, ac->mdct480_fn, 480, 1.0/480);
|
||||||
|
MDCT_INIT(ac->mdct512, ac->mdct512_fn, 512, 1.0/512);
|
||||||
|
MDCT_INIT(ac->mdct960, ac->mdct960_fn, 960, 1.0/960);
|
||||||
|
MDCT_INIT(ac->mdct1024, ac->mdct1024_fn, 1024, 1.0/1024);
|
||||||
|
#undef MDCT_INIT
|
||||||
|
|
||||||
|
/* LTP forward MDCT */
|
||||||
|
scale_fixed = -1.0;
|
||||||
|
scale_float = -32786.0*2 + 36;
|
||||||
|
ret = av_tx_init(&ac->mdct_ltp, &ac->mdct_ltp_fn, tx_type, 0, 1024, scalep, 0);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
#define AACDEC_FLAGS AV_OPT_FLAG_DECODING_PARAM | AV_OPT_FLAG_AUDIO_PARAM
|
#define AACDEC_FLAGS AV_OPT_FLAG_DECODING_PARAM | AV_OPT_FLAG_AUDIO_PARAM
|
||||||
#define OFF(field) offsetof(AACDecContext, field)
|
#define OFF(field) offsetof(AACDecContext, field)
|
||||||
static const AVOption options[] = {
|
static const AVOption options[] = {
|
||||||
|
@ -42,7 +42,6 @@ typedef int AAC_SIGNE;
|
|||||||
#define Q23(a) (int)((a) * 8388608.0 + 0.5)
|
#define Q23(a) (int)((a) * 8388608.0 + 0.5)
|
||||||
#define Q30(x) (int)((x)*1073741824.0 + 0.5)
|
#define Q30(x) (int)((x)*1073741824.0 + 0.5)
|
||||||
#define Q31(x) (int)((x)*2147483648.0 + 0.5)
|
#define Q31(x) (int)((x)*2147483648.0 + 0.5)
|
||||||
#define TX_SCALE(x) ((x) * 128.0f)
|
|
||||||
#define GET_GAIN(x, y) (-(y) * (1 << (x))) + 1024
|
#define GET_GAIN(x, y) (-(y) * (1 << (x))) + 1024
|
||||||
#define AAC_MUL16(x, y) (int)(((int64_t)(x) * (y) + 0x8000) >> 16)
|
#define AAC_MUL16(x, y) (int)(((int64_t)(x) * (y) + 0x8000) >> 16)
|
||||||
#define AAC_MUL26(x, y) (int)(((int64_t)(x) * (y) + 0x2000000) >> 26)
|
#define AAC_MUL26(x, y) (int)(((int64_t)(x) * (y) + 0x2000000) >> 26)
|
||||||
@ -110,7 +109,6 @@ typedef unsigned AAC_SIGNE;
|
|||||||
#define Q23(x) ((float)(x))
|
#define Q23(x) ((float)(x))
|
||||||
#define Q30(x) ((float)(x))
|
#define Q30(x) ((float)(x))
|
||||||
#define Q31(x) ((float)(x))
|
#define Q31(x) ((float)(x))
|
||||||
#define TX_SCALE(x) ((x) / 32768.0f)
|
|
||||||
#define GET_GAIN(x, y) powf((x), -(y))
|
#define GET_GAIN(x, y) powf((x), -(y))
|
||||||
#define AAC_MUL16(x, y) ((x) * (y))
|
#define AAC_MUL16(x, y) ((x) * (y))
|
||||||
#define AAC_MUL26(x, y) ((x) * (y))
|
#define AAC_MUL26(x, y) ((x) * (y))
|
||||||
|
@ -33,7 +33,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#define USE_FIXED 0
|
#define USE_FIXED 0
|
||||||
#define TX_TYPE AV_TX_FLOAT_MDCT
|
|
||||||
|
|
||||||
#include "libavutil/float_dsp.h"
|
#include "libavutil/float_dsp.h"
|
||||||
#include "avcodec.h"
|
#include "avcodec.h"
|
||||||
|
@ -306,6 +306,7 @@ typedef struct AACDecContext {
|
|||||||
|
|
||||||
extern const struct AVClass ff_aac_decoder_class;
|
extern const struct AVClass ff_aac_decoder_class;
|
||||||
|
|
||||||
|
int ff_aac_decode_init_common(struct AVCodecContext *avctx);
|
||||||
int ff_aac_decode_close(struct AVCodecContext *avctx);
|
int ff_aac_decode_close(struct AVCodecContext *avctx);
|
||||||
|
|
||||||
void ff_aacdec_init_mips(AACDecContext *c);
|
void ff_aacdec_init_mips(AACDecContext *c);
|
||||||
|
@ -59,7 +59,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#define USE_FIXED 1
|
#define USE_FIXED 1
|
||||||
#define TX_TYPE AV_TX_INT32_MDCT
|
|
||||||
|
|
||||||
#include "libavutil/fixed_dsp.h"
|
#include "libavutil/fixed_dsp.h"
|
||||||
#include "avcodec.h"
|
#include "avcodec.h"
|
||||||
|
@ -1145,7 +1145,6 @@ static AVOnce aac_table_init = AV_ONCE_INIT;
|
|||||||
|
|
||||||
static av_cold int aac_decode_init(AVCodecContext *avctx)
|
static av_cold int aac_decode_init(AVCodecContext *avctx)
|
||||||
{
|
{
|
||||||
float scale;
|
|
||||||
AACDecContext *ac = avctx->priv_data;
|
AACDecContext *ac = avctx->priv_data;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@ -1204,11 +1203,6 @@ static av_cold int aac_decode_init(AVCodecContext *avctx)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (avctx->ch_layout.nb_channels > MAX_CHANNELS) {
|
|
||||||
av_log(avctx, AV_LOG_ERROR, "Too many channels\n");
|
|
||||||
return AVERROR_INVALIDDATA;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if USE_FIXED
|
#if USE_FIXED
|
||||||
ac->fdsp = avpriv_alloc_fixed_dsp(avctx->flags & AV_CODEC_FLAG_BITEXACT);
|
ac->fdsp = avpriv_alloc_fixed_dsp(avctx->flags & AV_CODEC_FLAG_BITEXACT);
|
||||||
#else
|
#else
|
||||||
@ -1218,29 +1212,7 @@ static av_cold int aac_decode_init(AVCodecContext *avctx)
|
|||||||
return AVERROR(ENOMEM);
|
return AVERROR(ENOMEM);
|
||||||
}
|
}
|
||||||
|
|
||||||
ac->random_state = 0x1f2e3d4c;
|
return ff_aac_decode_init_common(avctx);
|
||||||
|
|
||||||
#define MDCT_INIT(s, fn, len, sval) \
|
|
||||||
scale = sval; \
|
|
||||||
ret = av_tx_init(&s, &fn, TX_TYPE, 1, len, &scale, 0); \
|
|
||||||
if (ret < 0) \
|
|
||||||
return ret;
|
|
||||||
|
|
||||||
MDCT_INIT(ac->mdct120, ac->mdct120_fn, 120, TX_SCALE(1.0/120))
|
|
||||||
MDCT_INIT(ac->mdct128, ac->mdct128_fn, 128, TX_SCALE(1.0/128))
|
|
||||||
MDCT_INIT(ac->mdct480, ac->mdct480_fn, 480, TX_SCALE(1.0/480))
|
|
||||||
MDCT_INIT(ac->mdct512, ac->mdct512_fn, 512, TX_SCALE(1.0/512))
|
|
||||||
MDCT_INIT(ac->mdct960, ac->mdct960_fn, 960, TX_SCALE(1.0/960))
|
|
||||||
MDCT_INIT(ac->mdct1024, ac->mdct1024_fn, 1024, TX_SCALE(1.0/1024))
|
|
||||||
#undef MDCT_INIT
|
|
||||||
|
|
||||||
/* LTP forward MDCT */
|
|
||||||
scale = USE_FIXED ? -1.0 : -32786.0*2 + 36;
|
|
||||||
ret = av_tx_init(&ac->mdct_ltp, &ac->mdct_ltp_fn, TX_TYPE, 0, 1024, &scale, 0);
|
|
||||||
if (ret < 0)
|
|
||||||
return ret;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user