migration/compress: compress QEMUFile is not writable
We open a file with empty_ops for compress QEMUFile, which means this is not writable. Signed-off-by: Wei Yang <richardw.yang@linux.intel.com> Reviewed-by: Juan Quintela <quintela@redhat.com> Signed-off-by: Juan Quintela <quintela@redhat.com>
This commit is contained in:
parent
a085664f21
commit
42d24611af
@ -764,11 +764,8 @@ static int qemu_compress_data(z_stream *stream, uint8_t *dest, size_t dest_len,
|
|||||||
/* Compress size bytes of data start at p and store the compressed
|
/* Compress size bytes of data start at p and store the compressed
|
||||||
* data to the buffer of f.
|
* data to the buffer of f.
|
||||||
*
|
*
|
||||||
* When f is not writable, return -1 if f has no space to save the
|
* Since the file is dummy file with empty_ops, return -1 if f has no space to
|
||||||
* compressed data.
|
* save the compressed data.
|
||||||
* When f is wirtable and it has no space to save the compressed data,
|
|
||||||
* do fflush first, if f still has no space to save the compressed
|
|
||||||
* data, return -1.
|
|
||||||
*/
|
*/
|
||||||
ssize_t qemu_put_compression_data(QEMUFile *f, z_stream *stream,
|
ssize_t qemu_put_compression_data(QEMUFile *f, z_stream *stream,
|
||||||
const uint8_t *p, size_t size)
|
const uint8_t *p, size_t size)
|
||||||
@ -776,14 +773,7 @@ ssize_t qemu_put_compression_data(QEMUFile *f, z_stream *stream,
|
|||||||
ssize_t blen = IO_BUF_SIZE - f->buf_index - sizeof(int32_t);
|
ssize_t blen = IO_BUF_SIZE - f->buf_index - sizeof(int32_t);
|
||||||
|
|
||||||
if (blen < compressBound(size)) {
|
if (blen < compressBound(size)) {
|
||||||
if (!qemu_file_is_writable(f)) {
|
return -1;
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
qemu_fflush(f);
|
|
||||||
blen = IO_BUF_SIZE - sizeof(int32_t);
|
|
||||||
if (blen < compressBound(size)) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
blen = qemu_compress_data(stream, f->buf + f->buf_index + sizeof(int32_t),
|
blen = qemu_compress_data(stream, f->buf + f->buf_index + sizeof(int32_t),
|
||||||
|
Loading…
Reference in New Issue
Block a user