ram_load: Factor out host_from_stream_offset call and check
The main RAM load loop has a call to host_from_stream_offset for each page type that actually loads data with the same test; factor it out before the switch. The host = NULL is to silence a bogus gcc warning of an unitialised in the RAM_SAVE_COMPRESS_PAGE case, it doesn't seem to realise that host is always initialised by the if at the top in the cases the switch takes. Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com> Reviewed-by: Juan Quintela <quintela@redhat.com> Signed-off-by: Juan Quintela <quintela@redhat.com>
This commit is contained in:
parent
4f2e425267
commit
a776aa15a7
@ -1592,13 +1592,23 @@ static int ram_load(QEMUFile *f, void *opaque, int version_id)
|
|||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
while (!ret && !(flags & RAM_SAVE_FLAG_EOS)) {
|
while (!ret && !(flags & RAM_SAVE_FLAG_EOS)) {
|
||||||
ram_addr_t addr, total_ram_bytes;
|
ram_addr_t addr, total_ram_bytes;
|
||||||
void *host;
|
void *host = NULL;
|
||||||
uint8_t ch;
|
uint8_t ch;
|
||||||
|
|
||||||
addr = qemu_get_be64(f);
|
addr = qemu_get_be64(f);
|
||||||
flags = addr & ~TARGET_PAGE_MASK;
|
flags = addr & ~TARGET_PAGE_MASK;
|
||||||
addr &= TARGET_PAGE_MASK;
|
addr &= TARGET_PAGE_MASK;
|
||||||
|
|
||||||
|
if (flags & (RAM_SAVE_FLAG_COMPRESS | RAM_SAVE_FLAG_PAGE |
|
||||||
|
RAM_SAVE_FLAG_COMPRESS_PAGE | RAM_SAVE_FLAG_XBZRLE)) {
|
||||||
|
host = host_from_stream_offset(f, addr, flags);
|
||||||
|
if (!host) {
|
||||||
|
error_report("Illegal RAM offset " RAM_ADDR_FMT, addr);
|
||||||
|
ret = -EINVAL;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
switch (flags & ~RAM_SAVE_FLAG_CONTINUE) {
|
switch (flags & ~RAM_SAVE_FLAG_CONTINUE) {
|
||||||
case RAM_SAVE_FLAG_MEM_SIZE:
|
case RAM_SAVE_FLAG_MEM_SIZE:
|
||||||
/* Synchronize RAM block list */
|
/* Synchronize RAM block list */
|
||||||
@ -1635,33 +1645,17 @@ static int ram_load(QEMUFile *f, void *opaque, int version_id)
|
|||||||
total_ram_bytes -= length;
|
total_ram_bytes -= length;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RAM_SAVE_FLAG_COMPRESS:
|
case RAM_SAVE_FLAG_COMPRESS:
|
||||||
host = host_from_stream_offset(f, addr, flags);
|
|
||||||
if (!host) {
|
|
||||||
error_report("Illegal RAM offset " RAM_ADDR_FMT, addr);
|
|
||||||
ret = -EINVAL;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
ch = qemu_get_byte(f);
|
ch = qemu_get_byte(f);
|
||||||
ram_handle_compressed(host, ch, TARGET_PAGE_SIZE);
|
ram_handle_compressed(host, ch, TARGET_PAGE_SIZE);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RAM_SAVE_FLAG_PAGE:
|
case RAM_SAVE_FLAG_PAGE:
|
||||||
host = host_from_stream_offset(f, addr, flags);
|
|
||||||
if (!host) {
|
|
||||||
error_report("Illegal RAM offset " RAM_ADDR_FMT, addr);
|
|
||||||
ret = -EINVAL;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
qemu_get_buffer(f, host, TARGET_PAGE_SIZE);
|
qemu_get_buffer(f, host, TARGET_PAGE_SIZE);
|
||||||
break;
|
break;
|
||||||
case RAM_SAVE_FLAG_COMPRESS_PAGE:
|
|
||||||
host = host_from_stream_offset(f, addr, flags);
|
|
||||||
if (!host) {
|
|
||||||
error_report("Invalid RAM offset " RAM_ADDR_FMT, addr);
|
|
||||||
ret = -EINVAL;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
case RAM_SAVE_FLAG_COMPRESS_PAGE:
|
||||||
len = qemu_get_be32(f);
|
len = qemu_get_be32(f);
|
||||||
if (len < 0 || len > compressBound(TARGET_PAGE_SIZE)) {
|
if (len < 0 || len > compressBound(TARGET_PAGE_SIZE)) {
|
||||||
error_report("Invalid compressed data length: %d", len);
|
error_report("Invalid compressed data length: %d", len);
|
||||||
@ -1671,13 +1665,8 @@ static int ram_load(QEMUFile *f, void *opaque, int version_id)
|
|||||||
qemu_get_buffer(f, compressed_data_buf, len);
|
qemu_get_buffer(f, compressed_data_buf, len);
|
||||||
decompress_data_with_multi_threads(compressed_data_buf, host, len);
|
decompress_data_with_multi_threads(compressed_data_buf, host, len);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RAM_SAVE_FLAG_XBZRLE:
|
case RAM_SAVE_FLAG_XBZRLE:
|
||||||
host = host_from_stream_offset(f, addr, flags);
|
|
||||||
if (!host) {
|
|
||||||
error_report("Illegal RAM offset " RAM_ADDR_FMT, addr);
|
|
||||||
ret = -EINVAL;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (load_xbzrle(f, addr, host) < 0) {
|
if (load_xbzrle(f, addr, host) < 0) {
|
||||||
error_report("Failed to decompress XBZRLE page at "
|
error_report("Failed to decompress XBZRLE page at "
|
||||||
RAM_ADDR_FMT, addr);
|
RAM_ADDR_FMT, addr);
|
||||||
|
Loading…
Reference in New Issue
Block a user