fix #4476: savevm-async: avoid looping without progress
when pend_postcopy is large. By definition, pend_postcopy won't decrease when iterating, so a value larger than the cutoff of 400000 would lead to essentially empty iterations, filling up the state file until only 30 MiB + pending_size remain and the second half of the check would trigger. Avoid this, by not considering pend_postcopy for the cutoff to enter the final phase. Signed-off-by: Fiona Ebner <f.ebner@proxmox.com>
This commit is contained in:
		
							parent
							
								
									ade9f50160
								
							
						
					
					
						commit
						8051a24b5f
					
				| @ -24,7 +24,8 @@ Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com> | |||||||
| [improve aborting] | [improve aborting] | ||||||
| Signed-off-by: Stefan Reiter <s.reiter@proxmox.com> | Signed-off-by: Stefan Reiter <s.reiter@proxmox.com> | ||||||
| [FE: further improve aborting | [FE: further improve aborting | ||||||
|      adapt to removal of QEMUFileOps] |      adapt to removal of QEMUFileOps | ||||||
|  |      improve condition for entering final stage] | ||||||
| Signed-off-by: Fiona Ebner <f.ebner@proxmox.com> | Signed-off-by: Fiona Ebner <f.ebner@proxmox.com> | ||||||
| ---
 | ---
 | ||||||
|  hmp-commands-info.hx         |  13 + |  hmp-commands-info.hx         |  13 + | ||||||
| @ -32,13 +33,13 @@ Signed-off-by: Fiona Ebner <f.ebner@proxmox.com> | |||||||
|  include/migration/snapshot.h |   2 + |  include/migration/snapshot.h |   2 + | ||||||
|  include/monitor/hmp.h        |   5 + |  include/monitor/hmp.h        |   5 + | ||||||
|  migration/meson.build        |   1 + |  migration/meson.build        |   1 + | ||||||
|  migration/savevm-async.c     | 531 +++++++++++++++++++++++++++++++++++ |  migration/savevm-async.c     | 532 +++++++++++++++++++++++++++++++++++ | ||||||
|  monitor/hmp-cmds.c           |  57 ++++ |  monitor/hmp-cmds.c           |  57 ++++ | ||||||
|  qapi/migration.json          |  34 +++ |  qapi/migration.json          |  34 +++ | ||||||
|  qapi/misc.json               |  32 +++ |  qapi/misc.json               |  32 +++ | ||||||
|  qemu-options.hx              |  12 + |  qemu-options.hx              |  12 + | ||||||
|  softmmu/vl.c                 |  10 + |  softmmu/vl.c                 |  10 + | ||||||
|  11 files changed, 730 insertions(+) |  11 files changed, 731 insertions(+) | ||||||
|  create mode 100644 migration/savevm-async.c |  create mode 100644 migration/savevm-async.c | ||||||
| 
 | 
 | ||||||
| diff --git a/hmp-commands-info.hx b/hmp-commands-info.hx
 | diff --git a/hmp-commands-info.hx b/hmp-commands-info.hx
 | ||||||
| @ -154,10 +155,10 @@ index 8cac83c06c..0842d00cd2 100644 | |||||||
|  ), gnutls) |  ), gnutls) | ||||||
| diff --git a/migration/savevm-async.c b/migration/savevm-async.c
 | diff --git a/migration/savevm-async.c b/migration/savevm-async.c
 | ||||||
| new file mode 100644 | new file mode 100644 | ||||||
| index 0000000000..05d394c0e2
 | index 0000000000..4a4e91a26d
 | ||||||
| --- /dev/null
 | --- /dev/null
 | ||||||
| +++ b/migration/savevm-async.c
 | +++ b/migration/savevm-async.c
 | ||||||
| @@ -0,0 +1,531 @@
 | @@ -0,0 +1,532 @@
 | ||||||
| +#include "qemu/osdep.h"
 | +#include "qemu/osdep.h"
 | ||||||
| +#include "migration/channel-savevm-async.h"
 | +#include "migration/channel-savevm-async.h"
 | ||||||
| +#include "migration/migration.h"
 | +#include "migration/migration.h"
 | ||||||
| @ -415,7 +416,8 @@ index 0000000000..05d394c0e2 | |||||||
| +
 | +
 | ||||||
| +        maxlen = blk_getlength(snap_state.target) - 30*1024*1024;
 | +        maxlen = blk_getlength(snap_state.target) - 30*1024*1024;
 | ||||||
| +
 | +
 | ||||||
| +        if (pending_size > 400000 && snap_state.bs_pos + pending_size < maxlen) {
 | +        /* Note that there is no progress for pend_postcopy when iterating */
 | ||||||
|  | +        if (pending_size - pend_postcopy > 400000 && snap_state.bs_pos + pending_size < maxlen) {
 | ||||||
| +            ret = qemu_savevm_state_iterate(snap_state.file, false);
 | +            ret = qemu_savevm_state_iterate(snap_state.file, false);
 | ||||||
| +            if (ret < 0) {
 | +            if (ret < 0) {
 | ||||||
| +                save_snapshot_error("qemu_savevm_state_iterate error %d", ret);
 | +                save_snapshot_error("qemu_savevm_state_iterate error %d", ret);
 | ||||||
|  | |||||||
| @ -192,10 +192,10 @@ index fa13d04d78..914f1a63a8 100644 | |||||||
|  int qemu_fclose(QEMUFile *f); |  int qemu_fclose(QEMUFile *f); | ||||||
|   |   | ||||||
| diff --git a/migration/savevm-async.c b/migration/savevm-async.c
 | diff --git a/migration/savevm-async.c b/migration/savevm-async.c
 | ||||||
| index 05d394c0e2..bafe6ae5eb 100644
 | index 4a4e91a26d..20aae335ca 100644
 | ||||||
| --- a/migration/savevm-async.c
 | --- a/migration/savevm-async.c
 | ||||||
| +++ b/migration/savevm-async.c
 | +++ b/migration/savevm-async.c
 | ||||||
| @@ -367,7 +367,7 @@ void qmp_savevm_start(bool has_statefile, const char *statefile, Error **errp)
 | @@ -368,7 +368,7 @@ void qmp_savevm_start(bool has_statefile, const char *statefile, Error **errp)
 | ||||||
|   |   | ||||||
|      QIOChannel *ioc = QIO_CHANNEL(qio_channel_savevm_async_new(snap_state.target, |      QIOChannel *ioc = QIO_CHANNEL(qio_channel_savevm_async_new(snap_state.target, | ||||||
|                                                                 &snap_state.bs_pos)); |                                                                 &snap_state.bs_pos)); | ||||||
| @ -204,7 +204,7 @@ index 05d394c0e2..bafe6ae5eb 100644 | |||||||
|   |   | ||||||
|      if (!snap_state.file) { |      if (!snap_state.file) { | ||||||
|          error_set(errp, ERROR_CLASS_GENERIC_ERROR, "failed to open '%s'", statefile); |          error_set(errp, ERROR_CLASS_GENERIC_ERROR, "failed to open '%s'", statefile); | ||||||
| @@ -500,7 +500,8 @@ int load_snapshot_from_blockdev(const char *filename, Error **errp)
 | @@ -501,7 +501,8 @@ int load_snapshot_from_blockdev(const char *filename, Error **errp)
 | ||||||
|      blk_op_block_all(be, blocker); |      blk_op_block_all(be, blocker); | ||||||
|   |   | ||||||
|      /* restore the VM state */ |      /* restore the VM state */ | ||||||
|  | |||||||
| @ -11,7 +11,7 @@ Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> | |||||||
|  1 file changed, 5 insertions(+) |  1 file changed, 5 insertions(+) | ||||||
| 
 | 
 | ||||||
| diff --git a/migration/savevm-async.c b/migration/savevm-async.c
 | diff --git a/migration/savevm-async.c b/migration/savevm-async.c
 | ||||||
| index bafe6ae5eb..da3634048f 100644
 | index 20aae335ca..94c5ae1c81 100644
 | ||||||
| --- a/migration/savevm-async.c
 | --- a/migration/savevm-async.c
 | ||||||
| +++ b/migration/savevm-async.c
 | +++ b/migration/savevm-async.c
 | ||||||
| @@ -20,6 +20,7 @@
 | @@ -20,6 +20,7 @@
 | ||||||
| @ -22,7 +22,7 @@ index bafe6ae5eb..da3634048f 100644 | |||||||
|   |   | ||||||
|  /* #define DEBUG_SAVEVM_STATE */ |  /* #define DEBUG_SAVEVM_STATE */ | ||||||
|   |   | ||||||
| @@ -514,6 +515,10 @@ int load_snapshot_from_blockdev(const char *filename, Error **errp)
 | @@ -515,6 +516,10 @@ int load_snapshot_from_blockdev(const char *filename, Error **errp)
 | ||||||
|      dirty_bitmap_mig_before_vm_start(); |      dirty_bitmap_mig_before_vm_start(); | ||||||
|   |   | ||||||
|      qemu_fclose(f); |      qemu_fclose(f); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Fiona Ebner
						Fiona Ebner