diff options
author | Muhammad Faiz <mfcc64@gmail.com> | 2016-11-24 15:02:07 +0700 |
---|---|---|
committer | Muhammad Faiz <mfcc64@gmail.com> | 2016-11-25 03:22:04 +0700 |
commit | 06f94149c61fd6beff6fcd0fd7ccc34b77c948dc (patch) | |
tree | c4dbe9dd1b10334394dd98a8f63f7e986b82ba23 /libswresample/arm | |
parent | ebb4c783d025122a20aa6fb21ddf73b861da18ef (diff) |
swresample/resample: optimize exact_rational=on:linear_interp=on case
separate dsp.resample to dsp.resample_common and dsp.resample_linear
and choose to call faster resample_common even when linear_interp=on
when c->frac and c->dst_incr_mod are both zero
speed up resampling when exact_rational and linear_interp are both
enabled because exact_rational force c->frac and c->dst_incr_mod to
be zero when soft compensation does not happen
benchmark on exact_rational=on:linear_interp=on
old new
real 8.432s 5.097s
user 7.679s 4.989s
sys 0.125s 0.107s
Reviewed-by: Michael Niedermayer <michael@niedermayer.cc>
Signed-off-by: Muhammad Faiz <mfcc64@gmail.com>
Diffstat (limited to 'libswresample/arm')
-rw-r--r-- | libswresample/arm/resample_init.c | 6 |
1 files changed, 2 insertions, 4 deletions
diff --git a/libswresample/arm/resample_init.c b/libswresample/arm/resample_init.c index 003fafd29b..e334a27b89 100644 --- a/libswresample/arm/resample_init.c +++ b/libswresample/arm/resample_init.c @@ -111,12 +111,10 @@ av_cold void swri_resample_dsp_arm_init(ResampleContext *c) switch(c->format) { case AV_SAMPLE_FMT_FLTP: - if (!c->linear) - c->dsp.resample = ff_resample_common_float_neon; + c->dsp.resample_common = ff_resample_common_float_neon; break; case AV_SAMPLE_FMT_S16P: - if (!c->linear) - c->dsp.resample = ff_resample_common_s16_neon; + c->dsp.resample_common = ff_resample_common_s16_neon; break; } } |