@ -673,11 +673,15 @@ int attribute_align_arg swr_convert(struct SwrContext *s, uint8_t *out_arg[SWR_C
const uint8_t * in_arg [ SWR_CH_MAX ] , int in_count ) {
const uint8_t * in_arg [ SWR_CH_MAX ] , int in_count ) {
AudioData * in = & s - > in ;
AudioData * in = & s - > in ;
AudioData * out = & s - > out ;
AudioData * out = & s - > out ;
int av_unused max_output ;
if ( ! swr_is_initialized ( s ) ) {
if ( ! swr_is_initialized ( s ) ) {
av_log ( s , AV_LOG_ERROR , " Context has not been initialized \n " ) ;
av_log ( s , AV_LOG_ERROR , " Context has not been initialized \n " ) ;
return AVERROR ( EINVAL ) ;
return AVERROR ( EINVAL ) ;
}
}
# if ASSERT_LEVEL >1
max_output = swr_get_out_samples ( s , in_count ) ;
# endif
while ( s - > drop_output > 0 ) {
while ( s - > drop_output > 0 ) {
int ret ;
int ret ;
@ -720,6 +724,9 @@ int attribute_align_arg swr_convert(struct SwrContext *s, uint8_t *out_arg[SWR_C
int ret = swr_convert_internal ( s , out , out_count , in , in_count ) ;
int ret = swr_convert_internal ( s , out , out_count , in , in_count ) ;
if ( ret > 0 & & ! s - > drop_output )
if ( ret > 0 & & ! s - > drop_output )
s - > outpts + = ret * ( int64_t ) s - > in_sample_rate ;
s - > outpts + = ret * ( int64_t ) s - > in_sample_rate ;
av_assert2 ( max_output < 0 | | ret < 0 | | ret < = max_output ) ;
return ret ;
return ret ;
} else {
} else {
AudioData tmp = * in ;
AudioData tmp = * in ;
@ -771,6 +778,7 @@ int attribute_align_arg swr_convert(struct SwrContext *s, uint8_t *out_arg[SWR_C
}
}
if ( ret2 > 0 & & ! s - > drop_output )
if ( ret2 > 0 & & ! s - > drop_output )
s - > outpts + = ret2 * ( int64_t ) s - > in_sample_rate ;
s - > outpts + = ret2 * ( int64_t ) s - > in_sample_rate ;
av_assert2 ( max_output < 0 | | ret2 < 0 | | ret2 < = max_output ) ;
return ret2 ;
return ret2 ;
}
}
}
}
@ -822,6 +830,28 @@ int64_t swr_get_delay(struct SwrContext *s, int64_t base){
}
}
}
}
int swr_get_out_samples ( struct SwrContext * s , int in_samples )
{
int64_t out_samples ;
if ( in_samples < 0 )
return AVERROR ( EINVAL ) ;
if ( s - > resampler & & s - > resample ) {
if ( ! s - > resampler - > get_out_samples )
return AVERROR ( ENOSYS ) ;
out_samples = s - > resampler - > get_out_samples ( s , in_samples ) ;
} else {
out_samples = s - > in_buffer_count + in_samples ;
av_assert0 ( s - > out_sample_rate = = s - > in_sample_rate ) ;
}
if ( out_samples > INT_MAX )
return AVERROR ( EINVAL ) ;
return out_samples ;
}
int swr_set_compensation ( struct SwrContext * s , int sample_delta , int compensation_distance ) {
int swr_set_compensation ( struct SwrContext * s , int sample_delta , int compensation_distance ) {
int ret ;
int ret ;