--- a/libavformat/avio.h +++ b/libavformat/avio.h @@ -281,12 +281,6 @@ */ int writeout_count; - /** - * Original buffer size - * used internally after probing and ensure seekback to reset the buffer size - * This field is internal to libavformat and access from outside is not allowed. - */ - int orig_buffer_size; /** * Threshold to favor readahead over seek. --- a/libavformat/aviobuf.c +++ b/libavformat/aviobuf.c @@ -33,7 +33,7 @@ #include "url.h" #include -#define IO_BUFFER_SIZE 32768 +#define IO_BUFFER_SIZE 262144 /** * Do seeks within this distance ahead of the current buffer by skipping @@ -88,7 +88,6 @@ int64_t (*seek)(void *opaque, int64_t offset, int whence)) { s->buffer = buffer; - s->orig_buffer_size = s->buffer_size = buffer_size; s->buf_ptr = buffer; s->opaque = opaque; @@ -534,16 +533,16 @@ } /* make buffer smaller in case it ended up large after probing */ - if (s->read_packet && s->orig_buffer_size && s->buffer_size > s->orig_buffer_size) { + if (s->read_packet && s->buffer_size > max_buffer_size) { if (dst == s->buffer) { - int ret = ffio_set_buf_size(s, s->orig_buffer_size); + int ret = ffio_set_buf_size(s, max_buffer_size); if (ret < 0) av_log(s, AV_LOG_WARNING, "Failed to decrease buffer size\n"); s->checksum_ptr = dst = s->buffer; } - av_assert0(len >= s->orig_buffer_size); - len = s->orig_buffer_size; + av_assert0(len >= max_buffer_size); + len = max_buffer_size; } if (s->read_packet) @@ -985,7 +984,6 @@ av_free(s->buffer); s->buffer = buffer; - s->orig_buffer_size = s->buffer_size = buf_size; s->buf_ptr = buffer; url_resetbuf(s, s->write_flag ? AVIO_FLAG_WRITE : AVIO_FLAG_READ); --- a/libavformat/utils.c +++ b/libavformat/utils.c @@ -118,6 +118,25 @@ MAKE_ACCESSORS(AVFormatContext, format, AVOpenCallback, open_cb) FF_ENABLE_DEPRECATION_WARNINGS #endif + +void *av_fast_realloc(void *ptr, unsigned int *size, size_t min_size) +{ + if (min_size < *size) + return ptr; + + min_size = FFMAX(17 * min_size / 16 + 32, min_size); + + ptr = av_realloc(ptr, min_size); + /* we could set this to the unmodified min_size but this is safer + * if the user lost the ptr and uses NULL now + */ + if (!ptr) + min_size = 0; + + *size = min_size; + + return ptr; +} int64_t av_stream_get_end_pts(const AVStream *st) {