1. 17 7月, 2013 10 次提交
  2. 16 7月, 2013 30 次提交
    • G
      LXC: Change the owner of live attached host devices · 129d25dc
      Gao feng 提交于
      The owner of this host devices should be the root user of container.
      Signed-off-by: NGao feng <gaofeng@cn.fujitsu.com>
      129d25dc
    • G
      LXC: Change the owner of host devices to the root of container · 7a8212aa
      Gao feng 提交于
      These host devices are created for container,
      the owner should be the root user of container.
      Signed-off-by: NGao feng <gaofeng@cn.fujitsu.com>
      7a8212aa
    • G
      LXC: Create host devices for container on host side · f87be04f
      Gao feng 提交于
      Otherwise the container will fail to start if we
      enable user namespace, since there is no rights to
      do mknod in uninit user namespace.
      Signed-off-by: NGao feng <gaofeng@cn.fujitsu.com>
      f87be04f
    • G
      LXC: Change the owner of live attached disk device · 4f41a8e5
      Gao feng 提交于
      The owner of this disk device should be the root user of container.
      Signed-off-by: NGao feng <gaofeng@cn.fujitsu.com>
      4f41a8e5
    • G
      LXC: Move virLXCControllerChown to lxc_container.c · 14a0c408
      Gao feng 提交于
      lxc driver will use this function to change the owner
      of hot added devices.
      
      Move virLXCControllerChown to lxc_container.c and Rename
      it to lxcContainerChown.
      Signed-off-by: NGao feng <gaofeng@cn.fujitsu.com>
      14a0c408
    • G
      LXC: controller: change the owner of disk to the root of container · ae4e916f
      Gao feng 提交于
      These disk devices are created for container,
      the owner should be the root user of container.
      Signed-off-by: NGao feng <gaofeng@cn.fujitsu.com>
      ae4e916f
    • G
      LXC: Setup disks for container on host side · 7161f0a3
      Gao feng 提交于
      Since mknod in container is forbidden, we should setup disks
      on host side.
      Signed-off-by: NGao feng <gaofeng@cn.fujitsu.com>
      7161f0a3
    • P
      qemu: Fix double free of returned JSON array in qemuAgentGetVCPUs() · dfc69235
      Peter Krempa 提交于
      A part of the returned monitor response was freed twice and caused
      crashes of the daemon when using guest agent cpu count retrieval.
      
       # virsh vcpucount dom --guest
      
      Introduced in v1.0.6-48-gc6afcb05
      dfc69235
    • W
      rbd: Do not free the secret if it is not set · d58c8478
      Wido den Hollander 提交于
      Not all RBD (Ceph) storage pools have cephx authentication turned on,
      so "secret" might not be initialized.
      
      It could also be that the secret couldn't be located.
      
      Only call virSecretFree() if "secret" is initialized earlier.
      Signed-off-by: NWido den Hollander <wido@widodh.nl>
      d58c8478
    • J
      Allow balloon driver collection to be adjusted dynamically · 57b65c58
      John Ferlan 提交于
      Use the virDomainSetMemoryStatsPeriodFlags() to pass a period defined by
      usage of a new --period option in order to set the collection period for the
      balloon driver. This may enable or disable the collection based on the value.
      
      Add the --current, --live, & --config options to dommemstat.
      57b65c58
    • J
      Implement the virDomainSetMemoryStatsPeriod for QEMU driver · 2431269b
      John Ferlan 提交于
      Implement the new API that will handle setting the balloon driver statistics
      collection period in order to enable or disable the collection dynamically.
      2431269b
    • J
      Specify remote protocol for virDomainSetMemoryStatsPeriod · ce2bdcbc
      John Ferlan 提交于
      Wire up the remote protocol
      ce2bdcbc
    • J
      Add new public API virDomainSetMemoryStatsPeriod · d5c67e7f
      John Ferlan 提交于
      Add new API in order to set the balloon memory driver statistics collection
      period in order to allow dynamic period adjustment for the virsh dommemstats to
      display balloon stats data
      d5c67e7f
    • J
      Add capability to fetch balloon stats · ab600621
      John Ferlan 提交于
      This patch will add the qemuMonitorJSONGetMemoryStats() to execute a
      "guest-stats" on the balloonpath using "get-qom" replacing the former
      mechanism which looked through the "query-ballon" returned data for
      the fields.  The "query-balloon" code only returns 'actual' memory.
      Rather than duplicating the existing code, have the JSON API use the
      GetBalloonInfo API.
      
      A check in the qemuMonitorGetMemoryStats() will be made to ensure the
      balloon driver path has been set.  Since the underlying JSON code can
      return data not associated with the balloon driver, we don't fail on
      a failure to get the balloonpath.  Of course since we've made the check,
      we can then set the ballooninit flag.  Getting the path here is primarily
      due to the process reconnect path which doesn't attempt to set the
      collection period.
      ab600621
    • J
      Determine whether to start balloon memory stats gathering. · ffdf82a9
      John Ferlan 提交于
      At vm startup and attach attempt to set the balloon driver statistics
      collection period based on the value found in the domain xml file. This
      is not done at reconnect since it's possible that a collection period
      was set on the live guest and making the set period call would reset to
      whatever value is stored in the config file.
      
      Setting the stats collection period has a side effect of searching through
      the qom-list output for the virtio balloon driver and making sure that it
      has the right properties in order to allow setting of a collection period
      and eventually fetching of statistics.
      
      The walk through the qom-list is expensive and thus the balloonpath will
      be saved in the monitor private structure as well as a flag indicating
      that the initialization has already been attempted (in the event that a
      path is not found, no sense to keep checking).
      
      This processing model conforms to the qom object model model which
      requires setting object properties after device startup. That is, it's
      not possible to pass the period along via the startup code as it won't
      be recognized.
      ffdf82a9
    • J
      Add 'period' for Memballoon statistics gathering capability · 9ed3a5ca
      John Ferlan 提交于
      Add a period in seconds to allow/enable statistics gathering from the
      Balloon driver for 'virsh dommemstat <domain>'.
      9ed3a5ca
    • A
      qemu: Prevent crash of libvirtd without guest agent configuration · 96518d43
      Alex Jia 提交于
      If users haven't configured guest agent then qemuAgentCommand() will
      dereference a NULL 'mon' pointer, which causes crash of libvirtd when
      using agent based cpu (un)plug.
      
      With the patch, when the qemu-ga service isn't running in the guest,
      a expected error "error: Guest agent is not responding: Guest agent
      not available for now" will be raised, and the error "error: argument
      unsupported: QEMU guest agent is not configured" is raised when the
      guest hasn't configured guest agent.
      
      GDB backtrace:
      
       (gdb) bt
       #0  virNetServerFatalSignal (sig=11, siginfo=<value optimized out>, context=<value optimized out>) at rpc/virnetserver.c:326
       #1  <signal handler called>
       #2  qemuAgentCommand (mon=0x0, cmd=0x7f39300017b0, reply=0x7f394b090910, seconds=-2) at qemu/qemu_agent.c:975
       #3  0x00007f39429507f6 in qemuAgentGetVCPUs (mon=0x0, info=0x7f394b0909b8) at qemu/qemu_agent.c:1475
       #4  0x00007f39429d9857 in qemuDomainGetVcpusFlags (dom=<value optimized out>, flags=9) at qemu/qemu_driver.c:4849
       #5  0x00007f3957dffd8d in virDomainGetVcpusFlags (domain=0x7f39300009c0, flags=8) at libvirt.c:9843
      
      How to reproduce?
      
       # To start a guest without guest agent configuration
       # then run the following cmdline
      
       # virsh vcpucount foobar --guest
       error: End of file while reading data: Input/output error
       error: One or more references were leaked after disconnect from the hypervisor
       error: Failed to reconnect to the hypervisor
      
      RHBZ: https://bugzilla.redhat.com/show_bug.cgi?id=984821Signed-off-by: NAlex Jia <ajia@redhat.com>
      Signed-off-by: NPeter Krempa <pkrempa@redhat.com>
      96518d43
    • M
      Make logical pools independent on target path · efab27af
      Martin Kletzander 提交于
      When using logical pools, we had to trust the target->path provided.
      This parameter, however, can be completely ommited and we can use
      '/dev/<source.name>' safely and populate it to target.path.
      
      Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=952973
      efab27af
    • M
      qemuhotplugtest: Introduce test for chardev hotplug · 9e45b3df
      Michal Privoznik 提交于
      The test is currently testing just device update function. However,
      chardev hotplug is implemented just for device attach and detach. This
      fact means, the test needs to be rewritten (the majority of the code is
      still shared). Moreover, we are now able to pass VM among multiple test
      runs. So for instance, while we add a device in the first run, we can
      remove it in the second run.
      9e45b3df
    • M
      qemu: Implement chardev hotplug on live level · 24b08219
      Michal Privoznik 提交于
      Since previous patches has prepared everything for us, we may now
      implement live hotplug of a character device.
      24b08219
    • M
      qemu: Implement chardev hotplug on config level · 75f0fd51
      Michal Privoznik 提交于
      There are two levels on which a device may be hotplugged: config
      and live. The config level requires just an insert or remove from
      internal domain definition structure, which is exactly what this
      patch does. There is currently no implementation for a chardev
      update action, as there's not much to be updated. But more
      importantly, the only thing that can be updated is path or socket
      address by which chardevs are distinguished. So the update action
      is currently not supported.
      75f0fd51
    • M
      domain_conf: Auto fill chardev port · 6b9e3dbd
      Michal Privoznik 提交于
      Now that we have callbacks, we should auto fill in omitted pieces of
      information. It's important for chardev hotplug to fill in the correct
      /{serial,parallel,console,channel}/target/@port if no value has been
      provided by user.
      6b9e3dbd
    • P
      cpu: Allow fine tuning of "host-model" cpu · 3c8be55c
      Peter Krempa 提交于
      https://bugzilla.redhat.com/show_bug.cgi?id=799354
      
      Until now, the "host-model" cpu mode couldn't be influenced. This patch
      allows to use the <feature> elements to either enable or disable
      specific CPU flags. This can be used to force flags that can be emulated
      even if the host CPU doesn't support them.
      3c8be55c
    • P
      cpu: Clean up code style · 90f9fb5a
      Peter Krempa 提交于
      90f9fb5a
    • P
      cpu: Add virCPUDefUpdateFeature() · 13cdd389
      Peter Krempa 提交于
      This new function updates or adds a feature to a existing cpu model
      definition. This function will be helpful to allow tuning of
      "host-model" features in later patches.
      13cdd389
    • P
      conf: Clean up error reporting in cpu definition parsing · b4275287
      Peter Krempa 提交于
      Use VIR_ERR_XML_ERROR instead of VIR_ERR_INTERNAL_ERROR in XML parsing
      code and move "%s" formating strings right after the error code.
      b4275287
    • J
      storage_conf: Merge AuthChap and AuthCephx into AuthSecret · 41ac8184
      John Ferlan 提交于
      Merge virStoragePoolDefParseAuthChap and virStoragePoolDefParseAuthCephx
      into a common virStoragePoolDefParseAuthSecret.  Change the output to be
      common for both by putting 'type' first followed by 'username'.
      41ac8184
    • J
      storage_conf: Move username processing into common function · 37029be4
      John Ferlan 提交于
      Move the auth->username processing into virStoragePoolDefParseAuth
      save the resulting username into chap/cephx specific data
      37029be4
    • J
      storage_pool: Rework chap XML to mimic ceph · eb0d79c6
      John Ferlan 提交于
      The existing 'chap' XML logic was never used - just defined.  Rather than
      try to insert a square peg into a round hole, blow it up and rewrite the
      logic to follow the 'ceph' format.
      
      Remove the former "chap.login" and "chap.passwd" fields and replace
      with "chap.username" and "chap.secret" in _virStoragePoolAuthChap.
      Adjust the virStoragePoolDefParseAuthChap() to process.
      
      Change the rng file to describe the new layout
      
      Update the formatstorage.html to describe the usage of the secret element
      to mention that the secret type "iscsi" and "ceph" can be used
      to storage pool too.
      
      Update the formatsecret.html to include a reference to the storage pool
      
      Update tests to handle the changes from 'login' and 'passwd' to 'username'
      and '<secret>' format
      eb0d79c6
    • J
      storage_conf: Move auth processing into virStoragePoolDefParseAuth · 092ca968
      John Ferlan 提交于
      Split processing of "<auth" into its own function
      092ca968