Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 25 Mar 2013 22:04:58 -0700
From:      Neel Natu <neelnatu@gmail.com>
To:        Iori YONEJI <fivo.11235813@gmail.com>
Cc:        freebsd-virtualization@freebsd.org
Subject:   Re: suspend/resume on BHyVe
Message-ID:  <CAFgRE9FqqJSTrtTA4PmdSsCdbEGi57jHOLZH0EkK83yJ3HqYpQ@mail.gmail.com>
In-Reply-To: <CAJ-Y7VcZ=EbAesb%2B8Pup1YsSE_yaM_345KZjwibjaC=GMo0xfA@mail.gmail.com>
References:  <CAJ-Y7VcZ=EbAesb%2B8Pup1YsSE_yaM_345KZjwibjaC=GMo0xfA@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
Hi Lori,

On Mon, Mar 25, 2013 at 11:53 AM, Iori=E3=80=80YONEJI <fivo.11235813@gmail.=
com> wrote:
> Hello.
>
> I'm thinking of adding suspend/resume features on BHyVe.
>

Fantastic!

> For this, I think those below must be implemented.
>
>   - virtual machine state command interface
>   - saving registers per CPU
>   - dumping physical memory
>   - saving virt-io and other device emulation state
>
>
> To save registers, the sysctl used in bhyvectl (vmmctl command
> previously) is helpful,
> however, it's interface is no good because getting register value
> cause a sysctl call
> so to context-switch per one register, and for getting all registers,
> it's not efficient.
> I think it's more preferable to make a struct to set or unset boolean
> fields per register,
> to tell which registers kernel should return, and kernel returns those
> state with struct vmxctx.
>
> struct vmxctx is such.
>  struct vmxctx {
>         register_t      tmpstk[32];             /* vmx_return() stack */
>         register_t      tmpstktop;
>
>         register_t      guest_rdi;              /* Guest state */
>         register_t      guest_rsi;
>                 :
>                 :
>
>
> And, considering memory dump, /dev/vmm/vmname is a file that is a map
> of guest memory,
> so memory dump doesn't seem hard, just stop vm, write back all guest
> cache, and copy
> memory file to a regular file.
>
> Finally, I don't know much about device state, but I think there must
> some state to be saved, like
> network stack.
>
> I'm not sure I wrote former, so I appreciate your ideas and suggestions.
>

I think that you are on the right track.

A brute force way of figuring out all the state must be saved is to
look at all the initialization functions that are called when a vm and
a vcpu are created. So, this would be vm_create() and vcpu_init() in
the kernel module.

There is also the hardware assist state that is maintained by the
processor (VT-x or SVM) and this includes things like guest
interruptibility, guest run state etc. I am assuming that it would be
sufficient to save the VMCS page after telling the processor to flush
any state it may be caching on chip.

There is also emulated pci bus, virtio devices and legacy isa device
state that would need to be saved by the userspace 'bhyve' process.

And finally there is the matter of how to communicate with 'bhyve'
process that it needs to suspend the virtual machine and write its
state to disk - perhaps a signal would be good enough place to start.

This certainly sounds like an interesting and challenging project and
we would be happy to help in any way we can.

best
Neel

> Thanks, Iori.
> _______________________________________________
> freebsd-virtualization@freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-virtualization
> To unsubscribe, send any mail to "freebsd-virtualization-unsubscribe@free=
bsd.org"



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CAFgRE9FqqJSTrtTA4PmdSsCdbEGi57jHOLZH0EkK83yJ3HqYpQ>