Bug 1035954 - lock mode memoryBacking will make qemu-kvm crashed
Summary: lock mode memoryBacking will make qemu-kvm crashed
Keywords:
Status: CLOSED CURRENTRELEASE
Alias: None
Product: Red Hat Enterprise Linux 7
Classification: Red Hat
Component: libvirt
Version: 7.0
Hardware: x86_64
OS: Linux
medium
high
Target Milestone: rc
: ---
Assignee: Jiri Denemark
QA Contact: Virtualization Bugs
URL:
Whiteboard:
Depends On:
Blocks:
TreeView+ depends on / blocked
 
Reported: 2013-11-29 02:36 UTC by Jincheng Miao
Modified: 2014-06-18 01:00 UTC (History)
8 users (show)

Fixed In Version: libvirt-1.1.1-15.el7
Doc Type: Bug Fix
Doc Text:
Clone Of:
Environment:
Last Closed: 2014-06-13 11:35:16 UTC
Target Upstream Version:


Attachments (Terms of Use)

Description Jincheng Miao 2013-11-29 02:36:23 UTC
Description of problem:
'lock' mode memoryBacking will make qemu-kvm crashed.

Version-Release number of selected component (if applicable):
libvirt-1.1.1-13.el7.x86_64
qemu-kvm-rhev-1.5.3-20.el7.x86_64

How reproducible:
100%

Steps to Reproduce:
1. define a guest with this:
# virsh edit kvm-rhel6.5-x86_64-qcow2-virtio
...
  <memory unit='KiB'>3049024</memory>  // the memory of guest is enough
  <currentMemory unit='KiB'>3049024</currentMemory>
  <memoryBacking>
  <locked/>
  </memoryBacking>
...

2. start it
# virsh start kvm-rhel6.5-x86_64-qcow2-virtio

3. after grub stage, guest will shutdown.
check out qemu.log
# tail /var/log/libvirt/qemu/kvm-rhel6.5-x86_64-qcow2-virtio.log
2013-11-28 09:39:23.710+0000: 30844: debug : virCommandHandshakeChild:388 : Handshake with parent is done
char device redirected to /dev/pts/1 (label charserial0)
GLib (gthread-posix.c): Unexpected error from C library during 'malloc': Resource temporarily unavailable.  Aborting.
2013-11-28 09:39:36.517+0000: shutting down

Actual results:
guest start fails

Expected results:
guest start success

Additional info:
Starting guest only using qemu command line will not crash.

Comment 2 Jiri Denemark 2013-12-02 09:53:13 UTC
You also need to set memtune/hard_limit. But as I can see, there's no documentation about it, which needs to be fixed.

Comment 3 Jiri Denemark 2013-12-09 16:53:01 UTC
The documentation is now fixed upstream by v1.2.0-72-g24fbbb8:

commit 24fbbb82636ee00a5f5ac3c960459696e96f2911
Author: Jiri Denemark <jdenemar>
Date:   Mon Dec 9 15:42:15 2013 +0100

    docs: Enhance memoryBacking/locked documentation
    
    Mention the need to set memtune/hard_limit.
    
    https://bugzilla.redhat.com/show_bug.cgi?id=1035954

Comment 6 Jincheng Miao 2013-12-16 04:15:30 UTC
we can see the patch is applied http://libvirt.org/formatdomain.html#elementsMemoryBacking

When I add hard_limit to 2894304KiB, the guest can boot:
  <memory unit='KiB'>1048576</memory>
  <currentMemory unit='KiB'>1048576</currentMemory>
  <memtune>
    <hard_limit unit='KiB'>2894304</hard_limit>
  </memtune>
  <memoryBacking>
    <locked/>
  </memoryBacking>

So I change the status to VERIFIED.

Comment 7 Ludek Smid 2014-06-13 11:35:16 UTC
This request was resolved in Red Hat Enterprise Linux 7.0.

Contact your manager or support representative in case you have further questions about the request.


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