Commit d42dc217 authored by Justin Ruggles's avatar Justin Ruggles Committed by Mans Rullgard

Add memory allocation failure checks to ff_iir_filter_init_coeffs().

Signed-off-by: 's avatarMans Rullgard <mans@mansr.com>
parent f0f54c29
...@@ -47,7 +47,8 @@ typedef struct FFIIRFilterState{ ...@@ -47,7 +47,8 @@ typedef struct FFIIRFilterState{
/// maximum supported filter order /// maximum supported filter order
#define MAXORDER 30 #define MAXORDER 30
av_cold struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(enum IIRFilterType filt_type, av_cold struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(void *avc,
enum IIRFilterType filt_type,
enum IIRFilterMode filt_mode, enum IIRFilterMode filt_mode,
int order, float cutoff_ratio, int order, float cutoff_ratio,
float stopband, float ripple) float stopband, float ripple)
...@@ -62,9 +63,12 @@ av_cold struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(enum IIRFilterType f ...@@ -62,9 +63,12 @@ av_cold struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(enum IIRFilterType f
if(order <= 1 || (order & 1) || order > MAXORDER || cutoff_ratio >= 1.0) if(order <= 1 || (order & 1) || order > MAXORDER || cutoff_ratio >= 1.0)
return NULL; return NULL;
c = av_malloc(sizeof(FFIIRFilterCoeffs)); FF_ALLOCZ_OR_GOTO(avc, c, sizeof(FFIIRFilterCoeffs),
c->cx = av_malloc(sizeof(c->cx[0]) * ((order >> 1) + 1)); init_fail);
c->cy = av_malloc(sizeof(c->cy[0]) * order); FF_ALLOC_OR_GOTO (avc, c->cx, sizeof(c->cx[0]) * ((order >> 1) + 1),
init_fail);
FF_ALLOC_OR_GOTO (avc, c->cy, sizeof(c->cy[0]) * order,
init_fail);
c->order = order; c->order = order;
wa = 2 * tan(M_PI * 0.5 * cutoff_ratio); wa = 2 * tan(M_PI * 0.5 * cutoff_ratio);
...@@ -110,6 +114,10 @@ av_cold struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(enum IIRFilterType f ...@@ -110,6 +114,10 @@ av_cold struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(enum IIRFilterType f
c->gain /= 1 << order; c->gain /= 1 << order;
return c; return c;
init_fail:
ff_iir_filter_free_coeffs(c);
return NULL;
} }
av_cold struct FFIIRFilterState* ff_iir_filter_init_state(int order) av_cold struct FFIIRFilterState* ff_iir_filter_init_state(int order)
......
...@@ -49,6 +49,8 @@ enum IIRFilterMode{ ...@@ -49,6 +49,8 @@ enum IIRFilterMode{
/** /**
* Initialize filter coefficients. * Initialize filter coefficients.
* *
* @param avc a pointer to an arbitrary struct of which the first
* field is a pointer to an AVClass struct
* @param filt_type filter type (e.g. Butterworth) * @param filt_type filter type (e.g. Butterworth)
* @param filt_mode filter mode (e.g. lowpass) * @param filt_mode filter mode (e.g. lowpass)
* @param order filter order * @param order filter order
...@@ -58,7 +60,8 @@ enum IIRFilterMode{ ...@@ -58,7 +60,8 @@ enum IIRFilterMode{
* *
* @return pointer to filter coefficients structure or NULL if filter cannot be created * @return pointer to filter coefficients structure or NULL if filter cannot be created
*/ */
struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(enum IIRFilterType filt_type, struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(void *avc,
enum IIRFilterType filt_type,
enum IIRFilterMode filt_mode, enum IIRFilterMode filt_mode,
int order, float cutoff_ratio, int order, float cutoff_ratio,
float stopband, float ripple); float stopband, float ripple);
......
...@@ -88,7 +88,7 @@ av_cold struct FFPsyPreprocessContext* ff_psy_preprocess_init(AVCodecContext *av ...@@ -88,7 +88,7 @@ av_cold struct FFPsyPreprocessContext* ff_psy_preprocess_init(AVCodecContext *av
cutoff_coeff = 2.0 * avctx->cutoff / avctx->sample_rate; cutoff_coeff = 2.0 * avctx->cutoff / avctx->sample_rate;
if (cutoff_coeff) if (cutoff_coeff)
ctx->fcoeffs = ff_iir_filter_init_coeffs(FF_FILTER_TYPE_BUTTERWORTH, FF_FILTER_MODE_LOWPASS, ctx->fcoeffs = ff_iir_filter_init_coeffs(avctx, FF_FILTER_TYPE_BUTTERWORTH, FF_FILTER_MODE_LOWPASS,
FILT_ORDER, cutoff_coeff, 0.0, 0.0); FILT_ORDER, cutoff_coeff, 0.0, 0.0);
if (ctx->fcoeffs) { if (ctx->fcoeffs) {
ctx->fstate = av_mallocz(sizeof(ctx->fstate[0]) * avctx->channels); ctx->fstate = av_mallocz(sizeof(ctx->fstate[0]) * avctx->channels);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment