[PATCH] vmx: Parse vm.genid
Daniel P. Berrangé
berrange at redhat.com
Mon Aug 2 12:14:52 UTC 2021
On Mon, Aug 02, 2021 at 12:26:56PM +0100, Richard W.M. Jones wrote:
> On Mon, Aug 02, 2021 at 12:12:08PM +0100, Daniel P. Berrangé wrote:
> > On Mon, Aug 02, 2021 at 12:04:49PM +0100, Richard W.M. Jones wrote:
> > > On Mon, Aug 02, 2021 at 01:00:15PM +0200, Michal Prívozník wrote:
> > > > On 7/30/21 2:02 PM, Richard W.M. Jones wrote:
> > > > > On Thu, Jul 29, 2021 at 10:30:30AM +0200, Michal Privoznik wrote:
> > > > >> The VMware metadata file contains genid but we are not parsing
> > > > >> and thus reporting it in domain XML. However, it's not as
> > > > >> straightforward as one might think. The UUID reported by VMware
> > > > >> is not in its usual string form, but split into two signed long
> > > > >> longs. That means, we have to do a bit of trickery when parsing.
> > > > >> But looking around it's the same magic that libguestfs does:
> > > > >>
> > > > >> https://github.com/libguestfs/virt-v2v/blob/master/v2v/input_vmx.ml#L421
> > > > >>
> > > > >> It's also explained by Rich on qemu-devel:
> > > > >>
> > > > >> https://lists.nongnu.org/archive/html/qemu-devel/2018-07/msg02019.html
> > > > >>
> > > > >> Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1598348
> > > > >> Signed-off-by: Michal Privoznik <mprivozn at redhat.com>
> > > > >> ---
> > > > >>
> > > > >> I've successfully ran vmx2xmltest on an s390x machine which means that
> > > > >> there shouldn't be any endiandness problem.
> > > > >>
> > > > >> src/vmx/vmx.c | 30 +++++++++++++++++++
> > > > >> .../vmx2xml-esx-in-the-wild-10.xml | 1 +
> > > > >> 2 files changed, 31 insertions(+)
> > > > >>
> > > >
> > > > >
> > > > > Looked reasonable and seems to match the description here:
> > > > >
> > > > > https://lists.nongnu.org/archive/html/qemu-devel/2018-07/msg02019.html
> > > > >
> > > > > Reviewed-by: Richard W.M. Jones <rjones at redhat.com>
> > > >
> > > > Pushed, thanks.
> > > >
> > > > >
> > > > > Out of interest, what is this being consumed by? I will add this to
> > > > > virt-v2v when it goes upstream.
> > > >
> > > > I don't recall all the specifics (it was John who implemented it), but
> > > > IIRC it was needed for Windows guests. Something about identifying them
> > > > uniquely. John?
> > >
> > > Sure, I understand what it's used for. I was just wondering if there
> > > are other consumers who want to pull the genID from VMware VMX files
> > > using libvirt. Seems like something quite specific to V2V scenarios.
> >
> > Could there even be a a case to be made for V2V to *not* preserve the
> > the genID value. eg If you see a genID in the existing config, then
> > write a /different/ genID value in the new VM, to indicate that this
> > new VM is a fork of the original VM ?
>
> https://images5.alphacoders.com/405/405572.jpg
>
> Noooo! Successfully converted VMs are definitely not forks and
> shouldn't be used that way.
Are we sure it doesn't end up that way indirectly. eg is there any
liklihood that people will do this sequence:
1. Stop original guest
2. Run virt-v2v
3. Start converted guest
4. Find something not right
5. Stop converted guest
6. Start original guest
7. Fix <something>
8. Goto (1)
Step 5/6 here is effectively akin to rolling back to a saved snapshot.
Thus genID ought to change if this is something users are liable todo.
Regards,
Daniel
--
|: https://berrange.com -o- https://www.flickr.com/photos/dberrange :|
|: https://libvirt.org -o- https://fstop138.berrange.com :|
|: https://entangle-photo.org -o- https://www.instagram.com/dberrange :|
More information about the libvir-list
mailing list