RHEL Engineering is moving the tracking of its product development work on RHEL 6 through RHEL 9 to Red Hat Jira (issues.redhat.com). If you're a Red Hat customer, please continue to file support cases via the Red Hat customer portal. If you're not, please head to the "RHEL project" in Red Hat Jira and file new tickets here. Individual Bugzilla bugs in the statuses "NEW", "ASSIGNED", and "POST" are being migrated throughout September 2023. Bugs of Red Hat partners with an assigned Engineering Partner Manager (EPM) are migrated in late September as per pre-agreed dates. Bugs against components "kernel", "kernel-rt", and "kpatch" are only migrated if still in "NEW" or "ASSIGNED". If you cannot log in to RH Jira, please consult article #7032570. That failing, please send an e-mail to the RH Jira admins at rh-issues@redhat.com to troubleshoot your issue as a user management inquiry. The email creates a ServiceNow ticket with Red Hat. Individual Bugzilla bugs that are migrated will be moved to status "CLOSED", resolution "MIGRATED", and set with "MigratedToJIRA" in "Keywords". The link to the successor Jira issue will be found under "Links", have a little "two-footprint" icon next to it, and direct you to the "RHEL project" in Red Hat Jira (issue links are of type "https://issues.redhat.com/browse/RHEL-XXXX", where "X" is a digit). This same link will be available in a blue banner at the top of the page informing you that that bug has been migrated.
Bug 1466099 - guest which start on 7.3 fail to migrate to migrate to 7.4 host after update
Summary: guest which start on 7.3 fail to migrate to migrate to 7.4 host after update
Keywords:
Status: CLOSED DUPLICATE of bug 1463957
Alias: None
Product: Red Hat Enterprise Linux 7
Classification: Red Hat
Component: libvirt
Version: 7.4
Hardware: x86_64
OS: Linux
medium
medium
Target Milestone: rc
: ---
Assignee: Jiri Denemark
QA Contact: Luyao Huang
URL:
Whiteboard:
Depends On:
Blocks:
TreeView+ depends on / blocked
 
Reported: 2017-06-29 03:12 UTC by Luyao Huang
Modified: 2017-07-12 08:00 UTC (History)
6 users (show)

Fixed In Version:
Doc Type: If docs needed, set a value
Doc Text:
Clone Of:
Environment:
Last Closed: 2017-07-12 08:00:01 UTC
Target Upstream Version:
Embargoed:


Attachments (Terms of Use)

Description Luyao Huang 2017-06-29 03:12:23 UTC
Description of problem:
guest which start on 7.3 fail to migrate to migrate to 7.4 host after update 

Version-Release number of selected component (if applicable):
libvirt-3.2.0-14.el7.x86_64

How reproducible:
100%

Steps to Reproduce:
1. start a guest on libvirt-2.0.0-10 (rhel7.3) and qemu-kvm-rhev-2.6.0-28.el7_3.12.x86_64 with host-model:

  <cpu mode='host-model'>
    <model fallback='allow'/>
    <numa>
      <cell id='0' cpus='0-2' memory='524288' unit='KiB'/>
      <cell id='1' cpus='3-5' memory='524288' unit='KiB'/>
    </numa>
  </cpu>

# virsh start r7-mig
Domain r7-mig started

2. check qemu command line:

# ps aux|grep qemu
...-cpu Opteron_G5,+vme,+ht,+monitor,+osxsave,+bmi1,+mmxext,+fxsr_opt,+cmp_legacy,+extapic,+cr8legacy,+osvw,+ibs,+skinit,+wdt,+lwp,+tce,+nodeid_msr,+topoext,+perfctr_core,+perfctr_nb

3. update libvirt to libvirt-3.2.0-14.el7 (rhel 7.4):

4. recheck the running guest xml:
# virsh dumpxml r7-mig

  <cpu mode='host-model' check='partial'>
    <model fallback='allow'/>

# virsh dumpxml r7-mig --migratable

  <cpu mode='host-model' check='partial'>
    <model fallback='allow'/>


5. migrate guest to 7.4 host without --xml:

# virsh migrate r7-mig qemu+tcp://target/system --live
error: internal error: qemu unexpectedly closed the monitor: -no-user-config -nodefaults -chardev socket,id=charmonitor,path=/var/lib/libvirt/qemu/domain-12-r7-mig/monitor.sock,server,nowait -mon chardev=charmonitor,id=monitor,mode=control -rtc base=utc,driftfix=slew -global kvm-pit.lost_tick_policy=delay -no-hpet -no-shutdown -global PIIX4_PM.disable_s3=0 -global PIIX4_PM.disable_s4=0 -boot strict=on -device ich9-usb-ehci1,id=usb,bus=pci.0,addr=0x6.0x7 -device ich9-usb-uhci1,masterbus=usb.0,firstport=0,bus=pci.0,multifunction=on,addr=0x6 -device ich9-usb-uhci2,masterbus=usb.0,firstport=2,bus=pci.0,addr=0x6.0x1 -device ich9-usb-uhci3,masterbus=usb.0,firstport=4,bus=pci.0,addr=0x6.0x2 -device virtio-serial-pci,id=virtio-serial0,bus=pci.0,addr=0x5 -chardev pty,id=charserial0 -device pci-serial,chardev=charserial0,id=serial0,bus=pci.0,addr=0x9 -chardev spicevmc,id=charchannel0,name=vdagent -device virtserialport,bus=virtio-serial0.0,nr=1,chardev=charchannel0,id=channel0,name=com.redhat.spice.0 -chardev socket,id=charchannel1,path=

6. check the target host guest log:

2017-06-28T01:25:00.982589Z qemu-kvm: State blocked by non-migratable device 'cpu'
2017-06-28T01:25:00.982703Z qemu-kvm: load of migration failed: Invalid argument

7. check the target qemu command line:

-cpu Opteron_G5,vme=on,ht=on,monitor=on,osxsave=on,bmi1=on,mmxext=on,fxsr_opt=on,cmp_legacy=on,extapic=on,cr8legacy=on,osvw=on,ibs=on,skinit=on,wdt=on,lwp=on,tce=on,nodeid_msr=on,topoext=on,perfctr_core=on,perfctr_nb=on,invtsc=on

you can see that libvirt add a invtsc=on in the qemu command line.

8. src and tgt host have the same cpu:

virsh # capabilities 
...
      <model>Opteron_G5</model>
      <vendor>AMD</vendor>
      <topology sockets='1' cores='4' threads='1'/>
      <feature name='vme'/>
      <feature name='ht'/>
      <feature name='monitor'/>
      <feature name='osxsave'/>
      <feature name='bmi1'/>
      <feature name='mmxext'/>
      <feature name='fxsr_opt'/>
      <feature name='cmp_legacy'/>
      <feature name='extapic'/>
      <feature name='cr8legacy'/>
      <feature name='osvw'/>
      <feature name='ibs'/>
      <feature name='skinit'/>
      <feature name='wdt'/>
      <feature name='lwp'/>
      <feature name='tce'/>
      <feature name='nodeid_msr'/>
      <feature name='topoext'/>
      <feature name='perfctr_core'/>
      <feature name='perfctr_nb'/>
      <feature name='invtsc'/>


Actual results:
guest fail to migrate to target host

Expected results:
migrate success

Additional info:

Comment 5 Jiri Denemark 2017-07-12 07:59:27 UTC
So after some investigation and patch writing, it appeared this BZ is actually very similar to bug 1463957 even though I originally thought they were different. The old libvirt didn't change a host-model CPU into a custom one when starting a domain. Thus when new libvirt is installed and the daemon reconnects to the existing domain (started by the old libvirt), it will see a rather unexpected host-model CPU in a running domain which breaks several things.

Comment 6 Jiri Denemark 2017-07-12 08:00:01 UTC

*** This bug has been marked as a duplicate of bug 1463957 ***


Note You need to log in before you can comment on or make changes to this bug.