[FFmpeg-devel] [PATCH v2] libavformat: Account for negative position differences in ff_configure_buffers_for_index

James Almer jamrial at gmail.com
Fri Mar 24 23:54:34 EET 2023


On 3/24/2023 6:50 PM, Martin Storsjö wrote:
> When scanning through the index, account for the fact that the
> compared samples may be located in an unexpected order in the file;
> this function is mainly interested in the absolute difference between
> file locations.
> 
> Signed-off-by: Martin Storsjö <martin at martin.st>
> ---
> v2: Use FFABS instead of llabs, avoid expanding the abs() operation
> twice in the FFMAX arguments.
> ---
>   libavformat/seek.c | 3 ++-
>   1 file changed, 2 insertions(+), 1 deletion(-)
> 
> diff --git a/libavformat/seek.c b/libavformat/seek.c
> index 818549dfef..23fbcb8d84 100644
> --- a/libavformat/seek.c
> +++ b/libavformat/seek.c
> @@ -210,7 +210,8 @@ void ff_configure_buffers_for_index(AVFormatContext *s, int64_t time_tolerance)
>                       int64_t e2_pts = av_rescale_q(e2->timestamp, st2->time_base, AV_TIME_BASE_Q);
>                       if (e2_pts < e1_pts || e2_pts - (uint64_t)e1_pts < time_tolerance)
>                           continue;
> -                    pos_delta = FFMAX(pos_delta, e1->pos - e2->pos);
> +                    int64_t cur_delta = FFABS(e1->pos - e2->pos);

This is going to give a warning about mixed declarations and code. 
Declare it alongside e2_pts above.

> +                    pos_delta = FFMAX(pos_delta, cur_delta);
>                       break;
>                   }
>               }


More information about the ffmpeg-devel mailing list