William Douglas 56fbabf1a1 Add basic driver for the Cloud-Hypervisor
Cloud-Hypervisor is a KVM virtualization using hypervisor. It
functions similarly to qemu and the libvirt Cloud-Hypervisor driver
uses a very similar structure to the libvirt driver.

The biggest difference from the libvirt perspective is that the
"monitor" socket is seperated into two sockets one that commands are
issued to and one that events are notified from. The current
implementation only uses the command socket (running over a REST API
with json encoded data) with future changes to add support for the
event socket (to better handle shutdowns from inside the VM).

This patch adds support for the following initial VM actions using the
Cloud-Hypervsior API:
 * vm.create
 * vm.delete
 * vm.boot
 * vm.shutdown
 * vm.reboot
 * vm.pause
 * vm.resume

To use the Cloud-Hypervisor driver, the v15.0 release of
Cloud-Hypervisor is required to be installed.

Some additional notes:
 * The curl handle is persistent but not useful to detect ch process
 shutdown/crash (a future patch will address this shortcoming)
 * On a 64-bit host Cloud-Hypervisor needs to support PVH and so can
 emulate 32-bit mode but it isn't fully tested (a 64-bit kernel and
 32-bit userspace is fine, a 32-bit kernel isn't validated)

Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
Signed-off-by: William Douglas <william.douglas@intel.com>
2021-06-04 10:56:06 +01:00
..
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-25 17:04:51 +02:00
2020-09-01 13:22:24 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00
2021-05-27 09:45:04 +02:00

Libvirt Message Translation

Translation status

Libvirt translatable messages are maintained using the GNU Gettext tools and file formats, in combination with the Fedora Weblate web service.

https://translate.fedoraproject.org/projects/libvirt/libvirt/

Source repository

The libvirt GIT repository stores the master "libvirt.pot" file, which is to be refreshed at time of feature freeze.

The "po" files stored in GIT have source locations removed in order to cut down on storage size, by eliminating information already present in the "pot" file. All files are stored with strings sorted in alphabetical order rather than source location order, to minimize movement of strings when source locations change.

The "po" files are to be EXCLUSIVELY UPDATED by merge requests sent from the Fedora Weblate service. Other contributors MUST NEVER send changes which touch the "po" file content, as that will create merge conflicts for Weblate. IOW any bug fixes to translations should be made via the Weblate application UI.

After the "pot" file in libvirt GIT, Weblate will automatically run "msgmerge" to update the "po" files itself and send back a merge request with the changes.

Translation updates made in the Weblate Web UI will be committed to its fork of the GIT repo once a day. These commits will be submitted back to the master GIT repo via merge requests. If a merge request from Weblate is already open, commits will be added to this existing merge request. Weblate will take care of rebasing whenever changes happen in Git master. In order to avoid having to do translations merges 30 times a month, merge requests from Weblate will usually be left open until feature freeze arrives. During the freeze period, they will be accepted more promptly to ensure they make it into the new release.