All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v2 repost 0/7] Extend virtio-balloon for fast (de)inflating & fast live migration
@ 2016-07-27  1:23 ` Liang Li
  0 siblings, 0 replies; 171+ messages in thread
From: Liang Li @ 2016-07-27  1:23 UTC (permalink / raw)
  To: linux-kernel
  Cc: virtualization, linux-mm, virtio-dev, kvm, qemu-devel, dgilbert,
	quintela, Liang Li

This patchset is for kernel and contains two parts of change to the
virtio-balloon. 

One is the change for speeding up the inflating & deflating process,
the main idea of this optimization is to use bitmap to send the page
information to host instead of the PFNs, to reduce the overhead of
virtio data transmission, address translation and madvise(). This can
help to improve the performance by about 85%.

Another change is for speeding up live migration. By skipping process
guest's free pages in the first round of data copy, to reduce needless
data processing, this can help to save quite a lot of CPU cycles and
network bandwidth. We put guest's free page information in bitmap and
send it to host with the virt queue of virtio-balloon. For an idle 8GB
guest, this can help to shorten the total live migration time from 2Sec
to about 500ms in the 10Gbps network environment.  


Changes from v1 to v2:
    * Abandon the patch for dropping page cache.
    * Put some structures to uapi head file.
    * Use a new way to determine the page bitmap size.
    * Use a unified way to send the free page information with the bitmap 
    * Address the issues referred in MST's comments

Liang Li (7):
  virtio-balloon: rework deflate to add page to a list
  virtio-balloon: define new feature bit and page bitmap head
  mm: add a function to get the max pfn
  virtio-balloon: speed up inflate/deflate process
  virtio-balloon: define feature bit and head for misc virt queue
  mm: add the related functions to get free page info
  virtio-balloon: tell host vm's free page info

 drivers/virtio/virtio_balloon.c     | 306 +++++++++++++++++++++++++++++++-----
 include/uapi/linux/virtio_balloon.h |  41 +++++
 mm/page_alloc.c                     |  52 ++++++
 3 files changed, 359 insertions(+), 40 deletions(-)

-- 
1.9.1

^ permalink raw reply	[flat|nested] 171+ messages in thread

end of thread, other threads:[~2016-08-02  0:34 UTC | newest]

Thread overview: 171+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-07-27  1:23 [PATCH v2 repost 0/7] Extend virtio-balloon for fast (de)inflating & fast live migration Liang Li
2016-07-27  1:23 ` [Qemu-devel] " Liang Li
2016-07-27  1:23 ` Liang Li
2016-07-27  1:23 ` [PATCH v2 repost 1/7] virtio-balloon: rework deflate to add page to a list Liang Li
2016-07-27  1:23 ` Liang Li
2016-07-27  1:23   ` [Qemu-devel] " Liang Li
2016-07-27  1:23   ` Liang Li
2016-07-27  1:23 ` [PATCH v2 repost 2/7] virtio-balloon: define new feature bit and page bitmap head Liang Li
2016-07-27  1:23 ` Liang Li
2016-07-27  1:23   ` [Qemu-devel] " Liang Li
2016-07-27  1:23   ` Liang Li
2016-07-27  1:23 ` [PATCH v2 repost 3/7] mm: add a function to get the max pfn Liang Li
2016-07-27  1:23 ` Liang Li
2016-07-27  1:23   ` [Qemu-devel] " Liang Li
2016-07-27  1:23   ` Liang Li
2016-07-27 22:08   ` Michael S. Tsirkin
2016-07-27 22:08     ` [Qemu-devel] " Michael S. Tsirkin
2016-07-27 22:08     ` Michael S. Tsirkin
2016-07-27 22:52     ` Dave Hansen
2016-07-27 22:52     ` Dave Hansen
2016-07-27 22:52       ` [Qemu-devel] " Dave Hansen
2016-07-27 22:52       ` Dave Hansen
2016-07-27 22:08   ` Michael S. Tsirkin
2016-07-27  1:23 ` [PATCH v2 repost 4/7] virtio-balloon: speed up inflate/deflate process Liang Li
2016-07-27  1:23 ` Liang Li
2016-07-27  1:23   ` [Qemu-devel] " Liang Li
2016-07-27  1:23   ` Liang Li
2016-07-27 16:03   ` Dave Hansen
2016-07-27 16:03   ` Dave Hansen
2016-07-27 16:03     ` [Qemu-devel] " Dave Hansen
2016-07-27 16:03     ` Dave Hansen
2016-07-27 16:03     ` Dave Hansen
2016-07-27 21:39     ` Michael S. Tsirkin
2016-07-27 21:39       ` [Qemu-devel] " Michael S. Tsirkin
2016-07-27 21:39       ` Michael S. Tsirkin
2016-07-28  3:30       ` Li, Liang Z
2016-07-28  3:30         ` [Qemu-devel] " Li, Liang Z
2016-07-28  3:30         ` Li, Liang Z
2016-07-28  3:30         ` Li, Liang Z
2016-07-28 22:15         ` Michael S. Tsirkin
2016-07-28 22:15           ` [Qemu-devel] " Michael S. Tsirkin
2016-07-28 22:15           ` Michael S. Tsirkin
2016-07-28 22:15           ` Michael S. Tsirkin
2016-07-29  1:08           ` [virtio-dev] " Li, Liang Z
2016-07-29  1:08             ` [Qemu-devel] " Li, Liang Z
2016-07-29  1:08             ` Li, Liang Z
2016-07-29  1:08             ` Li, Liang Z
2016-07-28 22:15         ` Michael S. Tsirkin
2016-07-28  3:30       ` Li, Liang Z
2016-07-27 21:39     ` Michael S. Tsirkin
2016-07-28  1:13     ` Li, Liang Z
2016-07-28  1:13       ` [Qemu-devel] " Li, Liang Z
2016-07-28  1:13       ` Li, Liang Z
2016-07-28  1:13       ` Li, Liang Z
2016-07-28  1:45       ` Michael S. Tsirkin
2016-07-28  1:45       ` Michael S. Tsirkin
2016-07-28  1:45         ` [Qemu-devel] " Michael S. Tsirkin
2016-07-28  1:45         ` Michael S. Tsirkin
2016-07-28  1:45         ` Michael S. Tsirkin
2016-07-28  6:36         ` [virtio-dev] " Li, Liang Z
2016-07-28  6:36         ` Li, Liang Z
2016-07-28  6:36           ` [Qemu-devel] " Li, Liang Z
2016-07-28  6:36           ` Li, Liang Z
2016-07-28  6:36           ` Li, Liang Z
2016-07-28 21:51           ` [virtio-dev] " Michael S. Tsirkin
2016-07-28 21:51           ` Michael S. Tsirkin
2016-07-28 21:51             ` [Qemu-devel] " Michael S. Tsirkin
2016-07-28 21:51             ` Michael S. Tsirkin
2016-07-28 21:51             ` Michael S. Tsirkin
2016-07-29  0:46             ` [virtio-dev] " Li, Liang Z
2016-07-29  0:46             ` Li, Liang Z
2016-07-29  0:46               ` [Qemu-devel] " Li, Liang Z
2016-07-29  0:46               ` Li, Liang Z
2016-07-29  0:46               ` Li, Liang Z
2016-07-29 19:48             ` Dave Hansen
2016-07-29 19:48             ` Dave Hansen
2016-07-29 19:48               ` [Qemu-devel] " Dave Hansen
2016-07-29 19:48               ` Dave Hansen
2016-08-02  0:28               ` Li, Liang Z
2016-08-02  0:28               ` Li, Liang Z
2016-08-02  0:28                 ` [Qemu-devel] " Li, Liang Z
2016-08-02  0:28                 ` Li, Liang Z
2016-08-02  0:28                 ` Li, Liang Z
2016-07-27 21:36   ` Michael S. Tsirkin
2016-07-27 21:36   ` Michael S. Tsirkin
2016-07-27 21:36     ` [Qemu-devel] " Michael S. Tsirkin
2016-07-27 21:36     ` Michael S. Tsirkin
2016-07-28  3:06     ` Li, Liang Z
2016-07-28  3:06       ` [Qemu-devel] " Li, Liang Z
2016-07-28  3:06       ` Li, Liang Z
2016-07-28  3:06       ` Li, Liang Z
2016-07-28 22:17       ` Michael S. Tsirkin
2016-07-28 22:17       ` Michael S. Tsirkin
2016-07-28 22:17         ` [Qemu-devel] " Michael S. Tsirkin
2016-07-28 22:17         ` Michael S. Tsirkin
2016-07-28 22:17         ` Michael S. Tsirkin
2016-07-29  0:38         ` Li, Liang Z
2016-07-29  0:38           ` [Qemu-devel] " Li, Liang Z
2016-07-29  0:38           ` Li, Liang Z
2016-07-29  0:38           ` Li, Liang Z
2016-07-27 22:07   ` Michael S. Tsirkin
2016-07-27 22:07     ` [Qemu-devel] " Michael S. Tsirkin
2016-07-27 22:07     ` Michael S. Tsirkin
2016-07-27 22:07     ` Michael S. Tsirkin
2016-07-28  3:48     ` Li, Liang Z
2016-07-28  3:48       ` [Qemu-devel] " Li, Liang Z
2016-07-28  3:48       ` Li, Liang Z
2016-07-28  3:48       ` Li, Liang Z
2016-07-27  1:23 ` [PATCH v2 repost 5/7] virtio-balloon: define feature bit and head for misc virt queue Liang Li
2016-07-27  1:23   ` [Qemu-devel] " Liang Li
2016-07-27  1:23   ` Liang Li
2016-07-27  1:23 ` Liang Li
2016-07-27  1:23 ` [PATCH v2 repost 6/7] mm: add the related functions to get free page info Liang Li
2016-07-27  1:23   ` [Qemu-devel] " Liang Li
2016-07-27  1:23   ` Liang Li
2016-07-27 16:40   ` Dave Hansen
2016-07-27 16:40   ` Dave Hansen
2016-07-27 16:40     ` [Qemu-devel] " Dave Hansen
2016-07-27 16:40     ` Dave Hansen
2016-07-27 22:05     ` Michael S. Tsirkin
2016-07-27 22:05     ` Michael S. Tsirkin
2016-07-27 22:05       ` [Qemu-devel] " Michael S. Tsirkin
2016-07-27 22:05       ` Michael S. Tsirkin
2016-07-27 22:16       ` Dave Hansen
2016-07-27 22:16         ` [Qemu-devel] " Dave Hansen
2016-07-27 22:16         ` Dave Hansen
2016-07-27 23:05         ` Michael S. Tsirkin
2016-07-27 23:05           ` [Qemu-devel] " Michael S. Tsirkin
2016-07-27 23:05           ` Michael S. Tsirkin
2016-07-27 23:05         ` Michael S. Tsirkin
2016-07-28  4:36         ` Li, Liang Z
2016-07-28  4:36           ` [Qemu-devel] " Li, Liang Z
2016-07-28  4:36           ` Li, Liang Z
2016-07-28  4:36         ` Li, Liang Z
2016-07-27 22:16       ` Dave Hansen
2016-07-28  0:10     ` Li, Liang Z
2016-07-28  0:10     ` Li, Liang Z
2016-07-28  0:10       ` [Qemu-devel] " Li, Liang Z
2016-07-28  0:10       ` Li, Liang Z
2016-07-28  0:17       ` Michael S. Tsirkin
2016-07-28  0:17         ` [Qemu-devel] " Michael S. Tsirkin
2016-07-28  0:17         ` Michael S. Tsirkin
2016-07-28  0:17         ` Michael S. Tsirkin
2016-07-28  0:17       ` Michael S. Tsirkin
2016-07-27 22:13   ` Michael S. Tsirkin
2016-07-27 22:13     ` [Qemu-devel] " Michael S. Tsirkin
2016-07-27 22:13     ` Michael S. Tsirkin
2016-07-28  5:30     ` [virtio-dev] " Li, Liang Z
2016-07-28  5:30     ` Li, Liang Z
2016-07-28  5:30       ` [Qemu-devel] " Li, Liang Z
2016-07-28  5:30       ` Li, Liang Z
2016-07-28  5:30       ` Li, Liang Z
2016-07-27 22:13   ` Michael S. Tsirkin
2016-07-27  1:23 ` Liang Li
2016-07-27  1:23 ` [PATCH v2 repost 7/7] virtio-balloon: tell host vm's " Liang Li
2016-07-27  1:23   ` [Qemu-devel] " Liang Li
2016-07-27  1:23   ` Liang Li
2016-07-27 22:00   ` Michael S. Tsirkin
2016-07-27 22:00     ` [Qemu-devel] " Michael S. Tsirkin
2016-07-27 22:00     ` Michael S. Tsirkin
2016-07-27 22:00     ` Michael S. Tsirkin
2016-07-28  7:50     ` Li, Liang Z
2016-07-28  7:50     ` Li, Liang Z
2016-07-28  7:50       ` [Qemu-devel] " Li, Liang Z
2016-07-28  7:50       ` Li, Liang Z
2016-07-28  7:50       ` Li, Liang Z
2016-07-28 21:37       ` Michael S. Tsirkin
2016-07-28 21:37       ` Michael S. Tsirkin
2016-07-28 21:37         ` [Qemu-devel] " Michael S. Tsirkin
2016-07-28 21:37         ` Michael S. Tsirkin
2016-07-27  1:23 ` Liang Li

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.