* Optimization for the virtio-balloon feature on the ARM platform
[not found] <8c6d264163574d8b886afdd3e4b77a2d@huawei.com>
@ 2023-02-20 1:33 ` Yangming via
2023-02-20 9:15 ` David Hildenbrand
0 siblings, 1 reply; 3+ messages in thread
From: Yangming via @ 2023-02-20 1:33 UTC (permalink / raw)
To: mst@redhat.com, david@redhat.com, qemu-devel@nongnu.org
Cc: wangzhigang (O), zhangliang (AG), xiqi
[-- Attachment #1: Type: text/plain, Size: 1296 bytes --]
Dear QEMU maintainers,
I am writing to discuss a possible optimization for the virtio-balloon feature on the ARM platform. The 'virtio_balloon_set_config' function is called frequently during the balloon inflation process, and its subfunction 'get_current_ram_size' needs to traverse the virtual machine's memory modules in order to count the current virtual machine's memory (i.e initial ram size + hotplugged memory). This can be very time consuming on the ARM platform, as the ARM virtual machine has much more complex memory modules than the x86 virtual machine.
Therefore, I suggest introducing a global variable, 'total_ram_size', that would be updated only when the balloon is initialized and hotplug memory has completed. This would increase the efficiency of balloon inflation by more than 60% on the ARM platform.
The following code is part of the optimization for balloon:
--- a/qemu/hw/virtio/virtio-balloon.c
+++ b/qemu/hw/virtio/virtio-balloon.c
static void virtio_balloon_set_config(...)
...
- ram_addr_t vm_ram_size = get_current_ram_size();
+ ram_addr_t vm_ram_size = total_ram_size;
...
I hope this suggestion could be considered or discussed by QEMU developers. I would love to seeing this improvement added to QEMU in the future.
Best regards,
Qi
[-- Attachment #2: Type: text/html, Size: 5466 bytes --]
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: Optimization for the virtio-balloon feature on the ARM platform
2023-02-20 1:33 ` Optimization for the virtio-balloon feature on the ARM platform Yangming via
@ 2023-02-20 9:15 ` David Hildenbrand
2023-02-20 12:11 ` Michael S. Tsirkin
0 siblings, 1 reply; 3+ messages in thread
From: David Hildenbrand @ 2023-02-20 9:15 UTC (permalink / raw)
To: Yangming, mst@redhat.com, qemu-devel@nongnu.org
Cc: wangzhigang (O), zhangliang (AG), xiqi
On 20.02.23 02:33, Yangming via wrote:
> Dear QEMU maintainers,
>
> I am writing to discuss a possible optimization for the virtio-balloon
> feature on the ARM platform. The ‘virtio_balloon_set_config’ function is
> called frequently during the balloon inflation process, and its
> subfunction ‘get_current_ram_size’ needs to traverse the virtual
> machine's memory modules in order to count the current virtual machine's
> memory (i.e initial ram size + hotplugged memory). This can be very time
> consuming on the ARM platform, as the ARM virtual machine has much more
> complex memory modules than the x86 virtual machine.
>
> Therefore, I suggest introducing a global variable, ‘total_ram_size’,
> that would be updated only when the balloon is initialized and hotplug
> memory has completed. This would increase the efficiency of balloon
> inflation by more than 60% on the ARM platform.
>
> The following code is part of the optimization for balloon:
>
> --- a/qemu/hw/virtio/virtio-balloon.c
>
> +++ b/qemu/hw/virtio/virtio-balloon.c
>
> static void virtio_balloon_set_config(…)
>
> …
>
> - ram_addr_t vm_ram_size = get_current_ram_size();
>
> + ram_addr_t vm_ram_size = total_ram_size;
>
> …
>
> I hope this suggestion could be considered or discussed by QEMU
> developers. I would love to seeing this improvement added to QEMU in the
> future.
I'd suggest keeping track of the plugged DIMM size inside
ms->device_memory->dimm_size. We can update it from
pc_dimm_plug/pc_dimm_unplug. We just have to make sure to exclude NVDIMMs.
We can then optimize get_current_ram_size() to return "ms->ram_size +
ms->device_memory->dimm_size", of course taking care of
ms->device_memory == NULL on some machines.
--
Thanks,
David / dhildenb
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: Optimization for the virtio-balloon feature on the ARM platform
2023-02-20 9:15 ` David Hildenbrand
@ 2023-02-20 12:11 ` Michael S. Tsirkin
0 siblings, 0 replies; 3+ messages in thread
From: Michael S. Tsirkin @ 2023-02-20 12:11 UTC (permalink / raw)
To: David Hildenbrand
Cc: Yangming, qemu-devel@nongnu.org, wangzhigang (O), zhangliang (AG),
xiqi
On Mon, Feb 20, 2023 at 10:15:37AM +0100, David Hildenbrand wrote:
> On 20.02.23 02:33, Yangming via wrote:
> > Dear QEMU maintainers,
> >
> > I am writing to discuss a possible optimization for the virtio-balloon
> > feature on the ARM platform. The ‘virtio_balloon_set_config’ function is
> > called frequently during the balloon inflation process, and its
> > subfunction ‘get_current_ram_size’ needs to traverse the virtual
> > machine's memory modules in order to count the current virtual machine's
> > memory (i.e initial ram size + hotplugged memory). This can be very time
> > consuming on the ARM platform, as the ARM virtual machine has much more
> > complex memory modules than the x86 virtual machine.
> >
> > Therefore, I suggest introducing a global variable, ‘total_ram_size’,
> > that would be updated only when the balloon is initialized and hotplug
> > memory has completed. This would increase the efficiency of balloon
> > inflation by more than 60% on the ARM platform.
> >
> > The following code is part of the optimization for balloon:
> >
> > --- a/qemu/hw/virtio/virtio-balloon.c
> >
> > +++ b/qemu/hw/virtio/virtio-balloon.c
> >
> > static void virtio_balloon_set_config(…)
> >
> > …
> >
> > - ram_addr_t vm_ram_size = get_current_ram_size();
> >
> > + ram_addr_t vm_ram_size = total_ram_size;
> >
> > …
> >
> > I hope this suggestion could be considered or discussed by QEMU
> > developers. I would love to seeing this improvement added to QEMU in the
> > future.
>
> I'd suggest keeping track of the plugged DIMM size inside
> ms->device_memory->dimm_size. We can update it from
> pc_dimm_plug/pc_dimm_unplug. We just have to make sure to exclude NVDIMMs.
>
> We can then optimize get_current_ram_size() to return "ms->ram_size +
> ms->device_memory->dimm_size", of course taking care of ms->device_memory ==
> NULL on some machines.
And as any optimization, patches are welcome accompanied by
a measurement showing it's a net improvement.
> --
> Thanks,
>
> David / dhildenb
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2023-02-20 12:11 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <8c6d264163574d8b886afdd3e4b77a2d@huawei.com>
2023-02-20 1:33 ` Optimization for the virtio-balloon feature on the ARM platform Yangming via
2023-02-20 9:15 ` David Hildenbrand
2023-02-20 12:11 ` Michael S. Tsirkin
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).