diff options
author | Scott Cheloha <cheloha@linux.vnet.ibm.com> | 2019-10-17 15:59:53 -0500 |
---|---|---|
committer | Juan Quintela <quintela@redhat.com> | 2020-01-20 09:10:22 +0100 |
commit | 174723ffe586e453f8ed4010ea07bbf79805b63f (patch) | |
tree | 2f58b2e1797ce0b72e4cba4592adc8bf885d5d34 /LICENSE | |
parent | bd5de61e7b926b5bb9dae254630bf3c8be575bc0 (diff) | |
download | qemu-174723ffe586e453f8ed4010ea07bbf79805b63f.zip qemu-174723ffe586e453f8ed4010ea07bbf79805b63f.tar.gz qemu-174723ffe586e453f8ed4010ea07bbf79805b63f.tar.bz2 |
migration: savevm_state_handler_insert: constant-time element insertion
savevm_state's SaveStateEntry TAILQ is a priority queue. Priority
sorting is maintained by searching from head to tail for a suitable
insertion spot. Insertion is thus an O(n) operation.
If we instead keep track of the head of each priority's subqueue
within that larger queue we can reduce this operation to O(1) time.
savevm_state_handler_remove() becomes slightly more complex to
accomodate these gains: we need to replace the head of a priority's
subqueue when removing it.
With O(1) insertion, booting VMs with many SaveStateEntry objects is
more plausible. For example, a ppc64 VM with maxmem=8T has 40000 such
objects to insert.
Signed-off-by: Scott Cheloha <cheloha@linux.vnet.ibm.com>
Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Reviewed-by: Juan Quintela <quintela@redhat.com>
Signed-off-by: Juan Quintela <quintela@redhat.com>
Diffstat (limited to 'LICENSE')
0 files changed, 0 insertions, 0 deletions