static void flush_buffer_o_direct(ByteIOContext *s)
{
size_t data_len = s->buf_ptr - s->buffer;
+ size_t to_write = data_len & ~(BLOCK_SIZE - 1);
- /* Write all data in the buffer to the disk together with any
- * additional space at the end of the buffer up to the first
- * multiple of BLOCK_SIZE. The last block is always written to the
- * disk despite not being fully filled. If the last block is not
- * fully filled, we keep it (moved to the begginig of the buffer)
- * and any subsequent call to this function will rewrite the block
- * together with the additional data added to the buffer. */
- size_t to_write = (data_len + BLOCK_SIZE - 1) & ~(BLOCK_SIZE - 1);
- size_t whole_blocks = data_len & ~(BLOCK_SIZE - 1);
- int64_t res = AVERROR(EPIPE);
+ if (s->flush_all) {
+ s->flush_all = 0;
+ to_write = (data_len + BLOCK_SIZE - 1) & ~(BLOCK_SIZE - 1);
+ }
av_log(NULL, AV_LOG_ERROR, " really writing %zx\n", to_write);
if (data_len > 0) {
s->checksum_ptr= s->buffer;
}
s->pos += to_write;
- memcpy(s->buffer, &s->buffer[whole_blocks], data_len - whole_blocks);
- s->buf_ptr -= whole_blocks;
+ if (data_len > to_write) {
+ /* flush_all was not set */
+ memcpy(s->buffer, &s->buffer[to_write], data_len - to_write);
+ s->buf_ptr -= to_write;
+ } else
+ s->buf_ptr = s->buffer;
- if (s->seek)
- res = s->seek(s->opaque, s->pos - to_write + whole_blocks, SEEK_SET);
- if (res < 0)
- av_log(NULL, AV_LOG_ERROR, "seek error inside %s: %lld\n", __func__, res);
//av_log(NULL, AV_LOG_ERROR, "ZZZ tw=%zu, pos=%zd\n", to_write, s->pos);
}
}
#if CONFIG_MUXERS || CONFIG_NETWORK
if (s->write_flag) {
+ s->flush_all = 1;
flush_buffer(s);
s->must_flush = 1;
}
if (!s->seek || (res = s->seek(s->opaque, offset1, SEEK_SET)) < 0)
return res;
s->buf_ptr = s->buffer + offset - offset1;
- s->pos = offset;
+ s->pos = offset1;
} else {
if (!s->seek || (res = s->seek(s->opaque, offset, SEEK_SET)) < 0)
return res;