123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- #ifndef SWR_INTERNAL_H
- #define SWR_INTERNAL_H
- #include "swresample.h"
- typedef void (mix_1_1_func_type)(void *out, const void *in, void *coeffp, int index, int len);
- typedef void (mix_2_1_func_type)(void *out, const void *in1, const void *in2, void *coeffp, int index1, int index2, int len);
- typedef void (mix_any_func_type)(uint8_t **out, const uint8_t **in1, void *coeffp, int len);
- typedef struct AudioData{
- uint8_t *ch[SWR_CH_MAX];
- uint8_t *data;
- int ch_count;
- int bps;
- int count;
- int planar;
- enum AVSampleFormat fmt;
- } AudioData;
- struct SwrContext {
- const AVClass *av_class;
- int log_level_offset;
- void *log_ctx;
- enum AVSampleFormat in_sample_fmt;
- enum AVSampleFormat int_sample_fmt;
- enum AVSampleFormat out_sample_fmt;
- int64_t in_ch_layout;
- int64_t out_ch_layout;
- int in_sample_rate;
- int out_sample_rate;
- int flags;
- float slev;
- float clev;
- float lfe_mix_level;
- float rematrix_volume;
- const int *channel_map;
- int used_ch_count;
- enum SwrDitherType dither_method;
- int dither_pos;
- float dither_scale;
- int filter_size;
- int phase_shift;
- int linear_interp;
- double cutoff;
- enum SwrFilterType filter_type;
- int kaiser_beta;
- float min_compensation;
- float min_hard_compensation;
- float soft_compensation_duration;
- float max_soft_compensation;
- int resample_first;
- int rematrix;
- int rematrix_custom;
- AudioData in;
- AudioData postin;
- AudioData midbuf;
- AudioData preout;
- AudioData out;
- AudioData in_buffer;
- AudioData dither;
- int in_buffer_index;
- int in_buffer_count;
- int resample_in_constraint;
- int flushed;
- int64_t outpts;
- int drop_output;
- struct AudioConvert *in_convert;
- struct AudioConvert *out_convert;
- struct AudioConvert *full_convert;
- struct ResampleContext *resample;
- float matrix[SWR_CH_MAX][SWR_CH_MAX];
- uint8_t *native_matrix;
- uint8_t *native_one;
- uint8_t *native_simd_matrix;
- int32_t matrix32[SWR_CH_MAX][SWR_CH_MAX];
- uint8_t matrix_ch[SWR_CH_MAX][SWR_CH_MAX+1];
- mix_1_1_func_type *mix_1_1_f;
- mix_1_1_func_type *mix_1_1_simd;
- mix_2_1_func_type *mix_2_1_f;
- mix_2_1_func_type *mix_2_1_simd;
- mix_any_func_type *mix_any_f;
-
- };
- struct ResampleContext *swri_resample_init(struct ResampleContext *, int out_rate, int in_rate, int filter_size, int phase_shift, int linear, double cutoff, enum AVSampleFormat, enum SwrFilterType, int kaiser_beta);
- void swri_resample_free(struct ResampleContext **c);
- int swri_multiple_resample(struct ResampleContext *c, AudioData *dst, int dst_size, AudioData *src, int src_size, int *consumed);
- void swri_resample_compensate(struct ResampleContext *c, int sample_delta, int compensation_distance);
- int swri_resample_int16(struct ResampleContext *c, int16_t *dst, const int16_t *src, int *consumed, int src_size, int dst_size, int update_ctx);
- int swri_resample_int32(struct ResampleContext *c, int32_t *dst, const int32_t *src, int *consumed, int src_size, int dst_size, int update_ctx);
- int swri_resample_float(struct ResampleContext *c, float *dst, const float *src, int *consumed, int src_size, int dst_size, int update_ctx);
- int swri_resample_double(struct ResampleContext *c,double *dst, const double *src, int *consumed, int src_size, int dst_size, int update_ctx);
- int swri_rematrix_init(SwrContext *s);
- void swri_rematrix_free(SwrContext *s);
- int swri_rematrix(SwrContext *s, AudioData *out, AudioData *in, int len, int mustcopy);
- void swri_rematrix_init_x86(struct SwrContext *s);
- void swri_get_dither(SwrContext *s, void *dst, int len, unsigned seed, enum AVSampleFormat out_fmt, enum AVSampleFormat in_fmt);
- void swri_audio_convert_init_x86(struct AudioConvert *ac,
- enum AVSampleFormat out_fmt,
- enum AVSampleFormat in_fmt,
- int channels);
- #endif
|