Compare commits
138 Commits
libvirt-0_
...
libvirt-0_
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d23e6c285b | ||
|
|
2c139b45d8 | ||
|
|
762435e3b7 | ||
|
|
6383d6b056 | ||
|
|
3712441ea6 | ||
|
|
9d0bc882fa | ||
|
|
90dddf3d3d | ||
|
|
86abd54d02 | ||
|
|
4ab5ad5425 | ||
|
|
f9c1b758c3 | ||
|
|
38cf1bd5ba | ||
|
|
aeda455930 | ||
|
|
288291b795 | ||
|
|
7c2073faca | ||
|
|
5b528ba717 | ||
|
|
4f731a7250 | ||
|
|
f1ac0031f5 | ||
|
|
e45b9c9030 | ||
|
|
3cf75c269d | ||
|
|
585033f372 | ||
|
|
897506e66a | ||
|
|
e4bf8ffa42 | ||
|
|
20367a58a6 | ||
|
|
aa037364ed | ||
|
|
c034c1a3b2 | ||
|
|
da05e02884 | ||
|
|
e1b7b518ac | ||
|
|
581b5f5022 | ||
|
|
c476c8b683 | ||
|
|
b93eafc59f | ||
|
|
2105d62ca8 | ||
|
|
743adffffe | ||
|
|
11e3b51c0d | ||
|
|
66df925739 | ||
|
|
b20a5c6d3b | ||
|
|
7f58f3aa54 | ||
|
|
6577b14441 | ||
|
|
2e7812764f | ||
|
|
854b878580 | ||
|
|
89c28e4013 | ||
|
|
db269c2d21 | ||
|
|
98e4f7ee9f | ||
|
|
0c4afc5ee9 | ||
|
|
593255292e | ||
|
|
ccafc8ecb4 | ||
|
|
a38fb9cbc1 | ||
|
|
6359121866 | ||
|
|
b20d669e88 | ||
|
|
a3e1cc37ed | ||
|
|
a6eca3382d | ||
|
|
c6c5072e90 | ||
|
|
705fd20a0e | ||
|
|
e0e9927d93 | ||
|
|
bae7a0fb84 | ||
|
|
36aee593bc | ||
|
|
dc0cb0e91a | ||
|
|
84d66312fe | ||
|
|
4f644ce267 | ||
|
|
cdd5b3d62d | ||
|
|
53f63aa62d | ||
|
|
748df35c5f | ||
|
|
a6e23d00fa | ||
|
|
c6d11b43c9 | ||
|
|
83091ff0dd | ||
|
|
4465a63872 | ||
|
|
3f397d9786 | ||
|
|
750aec5507 | ||
|
|
d7c1d3bbc0 | ||
|
|
fa0f21c263 | ||
|
|
afdaf5d354 | ||
|
|
26bba5aea9 | ||
|
|
1a4185bdcc | ||
|
|
6a73119e65 | ||
|
|
1e2f9fce0a | ||
|
|
f5edf79c95 | ||
|
|
b59e64bf44 | ||
|
|
a09fc2658a | ||
|
|
a008fcf27e | ||
|
|
511f6cd625 | ||
|
|
48b90fefc1 | ||
|
|
bc4bbabdf6 | ||
|
|
905627c8fd | ||
|
|
a16d752c10 | ||
|
|
29b1292019 | ||
|
|
f3546be64b | ||
|
|
fb9044931e | ||
|
|
03c5fec4d2 | ||
|
|
ce373a25b6 | ||
|
|
996d0e4709 | ||
|
|
8c01426c44 | ||
|
|
e859f7e59e | ||
|
|
25ea2f59bd | ||
|
|
c80b7f0d5a | ||
|
|
958f1c3dff | ||
|
|
4a8ca1017f | ||
|
|
1e122ee5dc | ||
|
|
6a6307bcdc | ||
|
|
6e8332946a | ||
|
|
982683e56f | ||
|
|
7244d1a339 | ||
|
|
2a3935580c | ||
|
|
28f7f11450 | ||
|
|
ca07bc4597 | ||
|
|
8e23194a2b | ||
|
|
fe09090e2d | ||
|
|
b5868cf8cf | ||
|
|
f294b40ba5 | ||
|
|
c0c1a7bb79 | ||
|
|
1b864048bd | ||
|
|
072c9c45ab | ||
|
|
af111679c3 | ||
|
|
dd9f21eaa2 | ||
|
|
f0e356df98 | ||
|
|
140bcf9ffc | ||
|
|
af69660412 | ||
|
|
6dc94c6252 | ||
|
|
eb34165670 | ||
|
|
7ce08f2148 | ||
|
|
049a8c79d9 | ||
|
|
f7a6d90012 | ||
|
|
67a2f29a89 | ||
|
|
82422fa1ff | ||
|
|
a73cf1d010 | ||
|
|
481419ebb6 | ||
|
|
1e65165c3a | ||
|
|
bca27d9111 | ||
|
|
08b9144b41 | ||
|
|
2063007248 | ||
|
|
81e46cb6da | ||
|
|
263e2f2021 | ||
|
|
2b9efc3de2 | ||
|
|
69f6239766 | ||
|
|
bf744f9872 | ||
|
|
45b0b2bfa6 | ||
|
|
f29ea218b7 | ||
|
|
7d193b7810 | ||
|
|
3182a4df5a | ||
|
|
4f667910e9 |
38
.cvsignore
38
.cvsignore
@@ -1,24 +1,14 @@
|
||||
libvirt-0.0.3.tar.gz
|
||||
libvirt-0.0.4.tar.gz
|
||||
libvirt-0.0.5.tar.gz
|
||||
libvirt-0.0.6.tar.gz
|
||||
libvirt-0.1.0.tar.gz
|
||||
libvirt-0.1.2.tar.gz
|
||||
libvirt-0.1.1.tar.gz
|
||||
libvirt-0.1.3.tar.gz
|
||||
libvirt-0.1.4.tar.gz
|
||||
libvirt-0.1.5.tar.gz
|
||||
libvirt-0.1.6.tar.gz
|
||||
libvirt-0.1.7.tar.gz
|
||||
libvirt-0.1.8.tar.gz
|
||||
libvirt-0.1.9.tar.gz
|
||||
libvirt-0.1.10.tar.gz
|
||||
libvirt-0.1.11.tar.gz
|
||||
libvirt-0.2.0.tar.gz
|
||||
libvirt-0.2.1.tar.gz
|
||||
libvirt-0.2.2.tar.gz
|
||||
libvirt-0.2.3.tar.gz
|
||||
libvirt-0.3.0.tar.gz
|
||||
libvirt-0.3.1.tar.gz
|
||||
libvirt-0.3.2.tar.gz
|
||||
libvirt-0.3.3.tar.gz
|
||||
.build*.log
|
||||
*.rpm
|
||||
i686
|
||||
x86_64
|
||||
libvirt-*.tar.gz
|
||||
libvirt-0.6.0.tar.gz
|
||||
libvirt-0.6.1.tar.gz
|
||||
libvirt-0.6.2.tar.gz
|
||||
libvirt-0.6.3.tar.gz
|
||||
libvirt-0.6.4.tar.gz
|
||||
libvirt-0.6.5.tar.gz
|
||||
libvirt-0.7.0.tar.gz
|
||||
libvirt-0.7.1.tar.gz
|
||||
libvirt-0.7.2.tar.gz
|
||||
|
||||
@@ -1,207 +0,0 @@
|
||||
changeset: 1147:7481eafdde8d
|
||||
user: berrange
|
||||
date: Fri Oct 12 18:54:15 2007 +0000
|
||||
files: libvirt.spec.in qemud/Makefile.am qemud/libvirtd.conf src/Makefile.am src/qemu.conf
|
||||
description:
|
||||
Added default example configs for libvirtd/qemu driver
|
||||
|
||||
|
||||
diff -r c48e81e685a3 -r 7481eafdde8d qemud/libvirtd.conf
|
||||
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
|
||||
+++ b/qemud/libvirtd.conf Fri Oct 12 18:54:15 2007 +0000
|
||||
@@ -0,0 +1,141 @@
|
||||
+# Master libvirt daemon configuration file
|
||||
+#
|
||||
+# For further information consult http://libvirt.org/format.html
|
||||
+
|
||||
+
|
||||
+# Flag listening for secure TLS connections on the public TCP/IP port.
|
||||
+# NB, must pass the --listen flag to the libvirtd process for this to
|
||||
+# have any effect.
|
||||
+#
|
||||
+# It is neccessary to setup a CA and issue server certificates before
|
||||
+# using this capability.
|
||||
+#
|
||||
+# This is enabled by default, uncomment this to disable it
|
||||
+# listen_tls = 0
|
||||
+
|
||||
+# Listen for unencrypted TCP connections on the public TCP/IP port.
|
||||
+# NB, must pass the --listen flag to the libvirtd process for this to
|
||||
+# have any effect.
|
||||
+#
|
||||
+# NB, this is insecure. Do not use except for development.
|
||||
+#
|
||||
+# This is disabled by default, uncomment this to enable it.
|
||||
+# listen_tcp = 1
|
||||
+
|
||||
+
|
||||
+
|
||||
+# Override the port for accepting secure TLS connections
|
||||
+# This can be a port number, or service name
|
||||
+#
|
||||
+# tls_port = "16514"
|
||||
+
|
||||
+# Override the port for accepting insecure TCP connections
|
||||
+# This can be a port number, or service name
|
||||
+#
|
||||
+# tcp_port = "16509"
|
||||
+
|
||||
+
|
||||
+
|
||||
+# Flag toggling mDNS advertizement of the libvirt service.
|
||||
+#
|
||||
+# Alternatively can disable for all services on a host by
|
||||
+# stopping the Avahi daemon
|
||||
+#
|
||||
+# This is enabled by default, uncomment this to disable it
|
||||
+# mdns_adv = 0
|
||||
+
|
||||
+# Override the default mDNS advertizement name. This must be
|
||||
+# unique on the immediate broadcast network.
|
||||
+#
|
||||
+# The default is "Virtualization Host HOSTNAME", where HOSTNAME
|
||||
+# is subsituted for the short hostname of the machine (without domain)
|
||||
+#
|
||||
+# mdns_name "Virtualization Host Joe Demo"
|
||||
+
|
||||
+
|
||||
+
|
||||
+# Set the UNIX domain socket group ownership. This can be used to
|
||||
+# allow a 'trusted' set of users access to management capabilities
|
||||
+# without becoming root.
|
||||
+#
|
||||
+# This is restricted to 'root' by default.
|
||||
+# unix_sock_group "libvirt"
|
||||
+
|
||||
+# Set the UNIX socket permissions for the R/O socket. This is used
|
||||
+# for monitoring VM status only
|
||||
+#
|
||||
+# Default allows any user. If setting group ownership may want to
|
||||
+# restrict this to:
|
||||
+# unix_sock_ro_perms "0777"
|
||||
+
|
||||
+# Set the UNIX socket permissions for the R/W socket. This is used
|
||||
+# for full management of VMs
|
||||
+#
|
||||
+# Default allows only root. If setting group ownership may want to
|
||||
+# relax this to:
|
||||
+# unix_sock_rw_perms "octal-perms" "0770"
|
||||
+
|
||||
+
|
||||
+
|
||||
+# Flag to disable verification of client certificates
|
||||
+#
|
||||
+# Client certificate verification is the primary authentication mechanism.
|
||||
+# Any client which does not present a certificate signed by the CA
|
||||
+# will be rejected.
|
||||
+#
|
||||
+# Default is to always verify. Uncommenting this will disable
|
||||
+# verification - make sure an IP whitelist is set
|
||||
+# tls_no_verify_certificate 1
|
||||
+
|
||||
+# Flag to disable verification of client IP address
|
||||
+#
|
||||
+# Client IP address will be verified against the CommonName field
|
||||
+# of the x509 certificate. This has minimal security benefit since
|
||||
+# it is easy to spoof source IP.
|
||||
+#
|
||||
+# Uncommenting this will disable verification
|
||||
+# tls_no_verify_address 1
|
||||
+
|
||||
+# Override the default server key file path
|
||||
+#
|
||||
+# key_file "/etc/pki/libvirt/private/serverkey.pem"
|
||||
+
|
||||
+# Override the default server certificate file path
|
||||
+#
|
||||
+# cert_file "/etc/pki/libvirt/servercert.pem"
|
||||
+
|
||||
+# Override the default CA certificate path
|
||||
+#
|
||||
+# ca_file "/etc/pki/CA/cacert.pem"
|
||||
+
|
||||
+# Specify a certificate revocation list.
|
||||
+#
|
||||
+# Defaults to not using a CRL, uncomment to enable it
|
||||
+# crl_file "/etc/pki/CA/crl.pem"
|
||||
+
|
||||
+# A whitelist of allowed x509 Distinguished Names
|
||||
+# This list may contain wildcards such as
|
||||
+#
|
||||
+# "C=GB,ST=London,L=London,O=Red Hat,CN=*"
|
||||
+#
|
||||
+# See the POSIX fnmatch function for the format of the wildcards.
|
||||
+#
|
||||
+# NB If this is an empty list, no client can connect, so comment out
|
||||
+# entirely rather than using empty list to disable these checks
|
||||
+#
|
||||
+# By default, no DN's are checked
|
||||
+# tls_allowed_dn_list ["DN1", "DN2"]
|
||||
+
|
||||
+
|
||||
+# A whitelist of allowed client IP addresses
|
||||
+#
|
||||
+# This list may contain wildcards such as 192.168.* See the POSIX fnmatch
|
||||
+# function for the format of the wildcards.
|
||||
+#
|
||||
+# NB If this is an empty list, no client can connect, so comment out
|
||||
+# entirely rather than using empty list to disable these checks
|
||||
+#
|
||||
+# By default, no IP's are checked. This can be IPv4 or IPv6 addresses
|
||||
+# tls_allowed_ip_list ["ip1", "ip2", "ip3"]
|
||||
+
|
||||
+
|
||||
diff -r c48e81e685a3 -r 7481eafdde8d src/qemu.conf
|
||||
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
|
||||
+++ b/src/qemu.conf Fri Oct 12 18:54:15 2007 +0000
|
||||
@@ -0,0 +1,49 @@
|
||||
+# Master configuration file for the QEMU driver.
|
||||
+# All settings described here are optional - if omitted, sensible
|
||||
+# defaults are used.
|
||||
+
|
||||
+# VNC is configured to listen on 127.0.0.1 by default.
|
||||
+# To make it listen on all public interfaces, uncomment
|
||||
+# this next option.
|
||||
+#
|
||||
+# NB, strong recommendation to enable TLS + x509 certificate
|
||||
+# verification when allowing public access
|
||||
+#
|
||||
+# vnc_listen = "0.0.0.0"
|
||||
+
|
||||
+
|
||||
+# Enable use of TLS encryption on the VNC server. This requires
|
||||
+# a VNC client which supports the VeNCrypt protocol extension.
|
||||
+# Examples include vinagre, virt-viewer, virt-manager and vencrypt
|
||||
+# itself. UltraVNC, RealVNC, TightVNC do not support this
|
||||
+#
|
||||
+# It is neccessary to setup CA and issue a server certificate
|
||||
+# before enabling this.
|
||||
+#
|
||||
+# vnc_tls = 1
|
||||
+
|
||||
+
|
||||
+# Use of TLS requires that x509 certificates be issued. The
|
||||
+# default it to keep them in /etc/pki/libvirt-vnc. This directory
|
||||
+# must contain
|
||||
+#
|
||||
+# ca-cert.pem - the CA master certificate
|
||||
+# server-cert.pem - the server certificate signed with ca-cert.pem
|
||||
+# server-key.pem - the server private key
|
||||
+#
|
||||
+# This option allows the certificate directory to be changed
|
||||
+#
|
||||
+# vnc_tls_x509_cert_dir = "/etc/pki/libvirt-vnc"
|
||||
+
|
||||
+
|
||||
+# The default TLS configuration only uses certificates for the server
|
||||
+# allowing the client to verify the server's identity and establish
|
||||
+# and encrypted channel.
|
||||
+#
|
||||
+# It is possible to use x509 certificates for authentication too, by
|
||||
+# issuing a x509 certificate to every client who needs to connect.
|
||||
+#
|
||||
+# Enabling this option will reject any client who does not have a
|
||||
+# certificate signed by the CA in /etc/pki/libvirt-vnc/ca-cert.pem
|
||||
+#
|
||||
+# vnc_tls_x509_verify = 1
|
||||
|
||||
@@ -1,230 +0,0 @@
|
||||
changeset: 1146:c48e81e685a3
|
||||
user: berrange
|
||||
date: Fri Oct 12 15:05:44 2007 +0000
|
||||
files: ChangeLog src/qemu_conf.c src/qemu_conf.h src/qemu_driver.c
|
||||
description:
|
||||
Added QEMU driver config file
|
||||
|
||||
|
||||
diff -r 522efe7f7e8f -r c48e81e685a3 src/qemu_conf.c
|
||||
--- a/src/qemu_conf.c Wed Oct 10 18:46:17 2007 +0000
|
||||
+++ b/src/qemu_conf.c Fri Oct 12 15:05:44 2007 +0000
|
||||
@@ -45,6 +45,7 @@
|
||||
#include "qemu_conf.h"
|
||||
#include "uuid.h"
|
||||
#include "buf.h"
|
||||
+#include "conf.h"
|
||||
|
||||
#define qemudLog(level, msg...) fprintf(stderr, msg)
|
||||
|
||||
@@ -65,6 +66,68 @@ void qemudReportError(virConnectPtr conn
|
||||
__virRaiseError(conn, dom, net, VIR_FROM_QEMU, code, VIR_ERR_ERROR,
|
||||
NULL, NULL, NULL, -1, -1, errorMessage);
|
||||
}
|
||||
+
|
||||
+int qemudLoadDriverConfig(struct qemud_driver *driver,
|
||||
+ const char *filename) {
|
||||
+ virConfPtr conf;
|
||||
+ virConfValuePtr p;
|
||||
+
|
||||
+ /* Setup 2 critical defaults */
|
||||
+ strcpy(driver->vncListen, "127.0.0.1");
|
||||
+ if (!(driver->vncTLSx509certdir = strdup(SYSCONF_DIR "/pki/libvirt-vnc"))) {
|
||||
+ qemudReportError(NULL, NULL, NULL, VIR_ERR_NO_MEMORY,
|
||||
+ "vncTLSx509certdir");
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ /* Just check the file is readable before opening it, otherwise
|
||||
+ * libvirt emits an error.
|
||||
+ */
|
||||
+ if (access (filename, R_OK) == -1) return 0;
|
||||
+
|
||||
+ conf = virConfReadFile (filename);
|
||||
+ if (!conf) return 0;
|
||||
+
|
||||
+
|
||||
+#define CHECK_TYPE(name,typ) if (p && p->type != (typ)) { \
|
||||
+ qemudReportError(NULL, NULL, NULL, VIR_ERR_INTERNAL_ERROR, \
|
||||
+ "remoteReadConfigFile: %s: %s: expected type " #typ "\n", \
|
||||
+ filename, (name)); \
|
||||
+ virConfFree(conf); \
|
||||
+ return -1; \
|
||||
+ }
|
||||
+
|
||||
+ p = virConfGetValue (conf, "vnc_tls");
|
||||
+ CHECK_TYPE ("vnc_tls", VIR_CONF_LONG);
|
||||
+ if (p) driver->vncTLS = p->l;
|
||||
+
|
||||
+ p = virConfGetValue (conf, "vnc_tls_x509_verify");
|
||||
+ CHECK_TYPE ("vnc_tls_x509_verify", VIR_CONF_LONG);
|
||||
+ if (p) driver->vncTLSx509verify = p->l;
|
||||
+
|
||||
+ p = virConfGetValue (conf, "vnc_tls_x509_cert_dir");
|
||||
+ CHECK_TYPE ("vnc_tls_x509_cert_dir", VIR_CONF_STRING);
|
||||
+ if (p && p->str) {
|
||||
+ free(driver->vncTLSx509certdir);
|
||||
+ if (!(driver->vncTLSx509certdir = strdup(p->str))) {
|
||||
+ qemudReportError(NULL, NULL, NULL, VIR_ERR_NO_MEMORY,
|
||||
+ "vncTLSx509certdir");
|
||||
+ virConfFree(conf);
|
||||
+ return -1;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ p = virConfGetValue (conf, "vnc_listen");
|
||||
+ CHECK_TYPE ("vnc_listen", VIR_CONF_STRING);
|
||||
+ if (p && p->str) {
|
||||
+ strncpy(driver->vncListen, p->str, sizeof(driver->vncListen));
|
||||
+ driver->vncListen[sizeof(driver->vncListen)-1] = '\0';
|
||||
+ }
|
||||
+
|
||||
+ virConfFree (conf);
|
||||
+ return 0;
|
||||
+}
|
||||
+
|
||||
|
||||
struct qemud_vm *qemudFindVMByID(const struct qemud_driver *driver, int id) {
|
||||
struct qemud_vm *vm = driver->vms;
|
||||
@@ -1234,7 +1297,7 @@ static struct qemud_vm_def *qemudParseXM
|
||||
if (vnclisten && *vnclisten)
|
||||
strncpy(def->vncListen, (char *)vnclisten, BR_INET_ADDR_MAXLEN-1);
|
||||
else
|
||||
- strcpy(def->vncListen, "127.0.0.1");
|
||||
+ strcpy(def->vncListen, driver->vncListen);
|
||||
def->vncListen[BR_INET_ADDR_MAXLEN-1] = '\0';
|
||||
xmlFree(vncport);
|
||||
xmlFree(vnclisten);
|
||||
@@ -1750,15 +1813,30 @@ int qemudBuildCommandLine(virConnectPtr
|
||||
}
|
||||
|
||||
if (vm->def->graphicsType == QEMUD_GRAPHICS_VNC) {
|
||||
- char vncdisplay[BR_INET_ADDR_MAXLEN+20];
|
||||
+ char vncdisplay[PATH_MAX];
|
||||
int ret;
|
||||
- if (vm->qemuCmdFlags & QEMUD_CMD_FLAG_VNC_COLON)
|
||||
- ret = snprintf(vncdisplay, sizeof(vncdisplay), "%s:%d",
|
||||
+
|
||||
+ if (vm->qemuCmdFlags & QEMUD_CMD_FLAG_VNC_COLON) {
|
||||
+ char options[PATH_MAX] = "";
|
||||
+ if (driver->vncTLS) {
|
||||
+ strcat(options, ",tls");
|
||||
+ if (driver->vncTLSx509verify) {
|
||||
+ strcat(options, ",x509verify=");
|
||||
+ } else {
|
||||
+ strcat(options, ",x509=");
|
||||
+ }
|
||||
+ strncat(options, driver->vncTLSx509certdir,
|
||||
+ sizeof(options) - (strlen(driver->vncTLSx509certdir)-1));
|
||||
+ options[sizeof(options)-1] = '\0';
|
||||
+ }
|
||||
+ ret = snprintf(vncdisplay, sizeof(vncdisplay), "%s:%d%s",
|
||||
vm->def->vncListen,
|
||||
- vm->def->vncActivePort - 5900);
|
||||
- else
|
||||
+ vm->def->vncActivePort - 5900,
|
||||
+ options);
|
||||
+ } else {
|
||||
ret = snprintf(vncdisplay, sizeof(vncdisplay), "%d",
|
||||
vm->def->vncActivePort - 5900);
|
||||
+ }
|
||||
if (ret < 0 || ret >= (int)sizeof(vncdisplay))
|
||||
goto error;
|
||||
|
||||
diff -r 522efe7f7e8f -r c48e81e685a3 src/qemu_conf.h
|
||||
--- a/src/qemu_conf.h Wed Oct 10 18:46:17 2007 +0000
|
||||
+++ b/src/qemu_conf.h Fri Oct 12 15:05:44 2007 +0000
|
||||
@@ -289,6 +289,10 @@ struct qemud_driver {
|
||||
char *networkConfigDir;
|
||||
char *networkAutostartDir;
|
||||
char logDir[PATH_MAX];
|
||||
+ int vncTLS : 1;
|
||||
+ int vncTLSx509verify : 1;
|
||||
+ char *vncTLSx509certdir;
|
||||
+ char vncListen[BR_INET_ADDR_MAXLEN];
|
||||
};
|
||||
|
||||
|
||||
@@ -311,6 +315,8 @@ void qemudReportError(virConnectPtr conn
|
||||
ATTRIBUTE_FORMAT(printf,5,6);
|
||||
|
||||
|
||||
+int qemudLoadDriverConfig(struct qemud_driver *driver,
|
||||
+ const char *filename);
|
||||
|
||||
struct qemud_vm *qemudFindVMByID(const struct qemud_driver *driver,
|
||||
int id);
|
||||
diff -r 522efe7f7e8f -r c48e81e685a3 src/qemu_driver.c
|
||||
--- a/src/qemu_driver.c Wed Oct 10 18:46:17 2007 +0000
|
||||
+++ b/src/qemu_driver.c Fri Oct 12 15:05:44 2007 +0000
|
||||
@@ -155,6 +155,7 @@ qemudStartup(void) {
|
||||
uid_t uid = geteuid();
|
||||
struct passwd *pw;
|
||||
char *base = NULL;
|
||||
+ char driverConf[PATH_MAX];
|
||||
|
||||
if (!(qemu_driver = calloc(1, sizeof(struct qemud_driver)))) {
|
||||
return -1;
|
||||
@@ -167,7 +168,7 @@ qemudStartup(void) {
|
||||
if (snprintf(qemu_driver->logDir, PATH_MAX, "%s/log/libvirt/qemu", LOCAL_STATE_DIR) >= PATH_MAX)
|
||||
goto snprintf_error;
|
||||
|
||||
- if ((base = strdup (SYSCONF_DIR "/libvirt/qemu")) == NULL)
|
||||
+ if ((base = strdup (SYSCONF_DIR "/libvirt")) == NULL)
|
||||
goto out_of_memory;
|
||||
} else {
|
||||
if (!(pw = getpwuid(uid))) {
|
||||
@@ -179,7 +180,7 @@ qemudStartup(void) {
|
||||
if (snprintf(qemu_driver->logDir, PATH_MAX, "%s/.libvirt/qemu/log", pw->pw_dir) >= PATH_MAX)
|
||||
goto snprintf_error;
|
||||
|
||||
- if (asprintf (&base, "%s/.libvirt/qemu", pw->pw_dir) == -1) {
|
||||
+ if (asprintf (&base, "%s/.libvirt", pw->pw_dir) == -1) {
|
||||
qemudLog (QEMUD_ERR, "out of memory in asprintf");
|
||||
goto out_of_memory;
|
||||
}
|
||||
@@ -188,24 +189,36 @@ qemudStartup(void) {
|
||||
/* Configuration paths are either ~/.libvirt/qemu/... (session) or
|
||||
* /etc/libvirt/qemu/... (system).
|
||||
*/
|
||||
- if (asprintf (&qemu_driver->configDir, "%s", base) == -1)
|
||||
+ if (snprintf (driverConf, sizeof(driverConf), "%s/qemu.conf", base) == -1)
|
||||
goto out_of_memory;
|
||||
-
|
||||
- if (asprintf (&qemu_driver->autostartDir, "%s/autostart", base) == -1)
|
||||
+ driverConf[sizeof(driverConf)-1] = '\0';
|
||||
+
|
||||
+ if (asprintf (&qemu_driver->configDir, "%s/qemu", base) == -1)
|
||||
goto out_of_memory;
|
||||
|
||||
- if (asprintf (&qemu_driver->networkConfigDir, "%s/networks", base) == -1)
|
||||
+ if (asprintf (&qemu_driver->autostartDir, "%s/qemu/autostart", base) == -1)
|
||||
goto out_of_memory;
|
||||
|
||||
- if (asprintf (&qemu_driver->networkAutostartDir, "%s/networks/autostart",
|
||||
+ if (asprintf (&qemu_driver->networkConfigDir, "%s/qemu/networks", base) == -1)
|
||||
+ goto out_of_memory;
|
||||
+
|
||||
+ if (asprintf (&qemu_driver->networkAutostartDir, "%s/qemu/networks/autostart",
|
||||
base) == -1)
|
||||
goto out_of_memory;
|
||||
|
||||
- if (qemudScanConfigs(qemu_driver) < 0)
|
||||
+ free(base);
|
||||
+
|
||||
+ if (qemudLoadDriverConfig(qemu_driver, driverConf) < 0) {
|
||||
qemudShutdown();
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ if (qemudScanConfigs(qemu_driver) < 0) {
|
||||
+ qemudShutdown();
|
||||
+ return -1;
|
||||
+ }
|
||||
qemudAutostartConfigs(qemu_driver);
|
||||
|
||||
- free(base);
|
||||
return 0;
|
||||
|
||||
snprintf_error:
|
||||
|
||||
31
libvirt-logrotate-avoid-compressing-small-logs.patch
Normal file
31
libvirt-logrotate-avoid-compressing-small-logs.patch
Normal file
@@ -0,0 +1,31 @@
|
||||
From d7cca87f6c5ad2316934af8ecb95829b95b662c6 Mon Sep 17 00:00:00 2001
|
||||
From: Dan Kenigsberg <danken@redhat.com>
|
||||
Date: Wed, 21 Oct 2009 13:56:04 +0200
|
||||
Subject: [PATCH] Do not log rotate very small logs
|
||||
|
||||
Without this, after few weeks without use, each defined domain grows a
|
||||
tail of empty gzipped logs, instead of keeping just the last log of
|
||||
interest.
|
||||
|
||||
* daemon/libvirtd.logrotate.in: only rotate when the log is over 100 KBytes
|
||||
|
||||
(cherry picked from commit b03fe2d0aefb57a096a102bf23375f0a167ca189)
|
||||
|
||||
Fedora-patch: libvirt-logrotate-avoid-compressing-small-logs.patch
|
||||
---
|
||||
daemon/libvirtd.logrotate.in | 1 +
|
||||
1 files changed, 1 insertions(+), 0 deletions(-)
|
||||
|
||||
diff --git a/daemon/libvirtd.logrotate.in b/daemon/libvirtd.logrotate.in
|
||||
index 093651c..0c51fd3 100644
|
||||
--- a/daemon/libvirtd.logrotate.in
|
||||
+++ b/daemon/libvirtd.logrotate.in
|
||||
@@ -5,4 +5,5 @@
|
||||
compress
|
||||
delaycompress
|
||||
copytruncate
|
||||
+ minsize 100k
|
||||
}
|
||||
--
|
||||
1.6.2.5
|
||||
|
||||
42
libvirt-qemu-machine-type-fixes2.patch
Normal file
42
libvirt-qemu-machine-type-fixes2.patch
Normal file
@@ -0,0 +1,42 @@
|
||||
From b7b6a28eb9eae641762de9408a90971d849ce92e Mon Sep 17 00:00:00 2001
|
||||
From: Mark McLoughlin <markmc@redhat.com>
|
||||
Date: Thu, 15 Oct 2009 12:09:17 +0100
|
||||
Subject: [PATCH] Don't copy old machines from a domain which has none
|
||||
|
||||
If the the qemu and kvm binaries are the same, we don't include machine
|
||||
types in the kvm domain info.
|
||||
|
||||
However, the code which refreshes the machine types info from the
|
||||
previous capabilities structure first looks at the kvm domain's info,
|
||||
finds it matches and then copies the empty machine types list over
|
||||
for the top-level qemu domain.
|
||||
|
||||
That doesn't make sense, we shouldn't copy an empty machin types list.
|
||||
|
||||
* src/qemu/qemu_conf.c: qemudGetOldMachinesFromInfo(): don't copy an
|
||||
empty machine types list.
|
||||
|
||||
(cherry picked from commit 2210f8a3a8e2774ca4fb8b42e21899e5b85ca913)
|
||||
|
||||
Fedora-patch: libvirt-qemu-machine-type-fixes2.patch
|
||||
---
|
||||
src/qemu/qemu_conf.c | 3 +++
|
||||
1 files changed, 3 insertions(+), 0 deletions(-)
|
||||
|
||||
diff --git a/src/qemu/qemu_conf.c b/src/qemu/qemu_conf.c
|
||||
index ac63570..b881f1e 100644
|
||||
--- a/src/qemu/qemu_conf.c
|
||||
+++ b/src/qemu/qemu_conf.c
|
||||
@@ -505,6 +505,9 @@ qemudGetOldMachinesFromInfo(virCapsGuestDomainInfoPtr info,
|
||||
virCapsGuestMachinePtr *list;
|
||||
int i;
|
||||
|
||||
+ if (!info->nmachines)
|
||||
+ return 0;
|
||||
+
|
||||
if (!info->emulator || !STREQ(emulator, info->emulator))
|
||||
return 0;
|
||||
|
||||
--
|
||||
1.6.2.5
|
||||
|
||||
897
libvirt.spec
897
libvirt.spec
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user