Compare commits
139 Commits
libvirt-0_
...
F-12-split
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
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 | ||
|
|
b395a39f7b | ||
|
|
fdd7e87fe3 | ||
|
|
f06c387ab5 | ||
|
|
5ad8bc8190 | ||
|
|
31802de821 | ||
|
|
cc39758e17 | ||
|
|
55fabd69c0 | ||
|
|
b2a1a0e9ba | ||
|
|
cbe377ed29 | ||
|
|
06a21e388f | ||
|
|
d1a886ab31 | ||
|
|
c70baa5133 | ||
|
|
52b4d91272 |
32
.cvsignore
32
.cvsignore
@@ -1,19 +1,13 @@
|
|||||||
libvirt-0.0.3.tar.gz
|
.build*.log
|
||||||
libvirt-0.0.4.tar.gz
|
*.rpm
|
||||||
libvirt-0.0.5.tar.gz
|
i686
|
||||||
libvirt-0.0.6.tar.gz
|
x86_64
|
||||||
libvirt-0.1.0.tar.gz
|
libvirt-*.tar.gz
|
||||||
libvirt-0.1.2.tar.gz
|
libvirt-0.6.0.tar.gz
|
||||||
libvirt-0.1.1.tar.gz
|
libvirt-0.6.1.tar.gz
|
||||||
libvirt-0.1.3.tar.gz
|
libvirt-0.6.2.tar.gz
|
||||||
libvirt-0.1.4.tar.gz
|
libvirt-0.6.3.tar.gz
|
||||||
libvirt-0.1.5.tar.gz
|
libvirt-0.6.4.tar.gz
|
||||||
libvirt-0.1.6.tar.gz
|
libvirt-0.6.5.tar.gz
|
||||||
libvirt-0.1.7.tar.gz
|
libvirt-0.7.0.tar.gz
|
||||||
libvirt-0.1.8.tar.gz
|
libvirt-0.7.1.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
|
|
||||||
|
|||||||
17
Makefile
17
Makefile
@@ -3,4 +3,19 @@
|
|||||||
NAME := libvirt
|
NAME := libvirt
|
||||||
SPECFILE = $(firstword $(wildcard *.spec))
|
SPECFILE = $(firstword $(wildcard *.spec))
|
||||||
|
|
||||||
include ../common/Makefile.common
|
define find-makefile-common
|
||||||
|
for d in common ../common ../../common ; do if [ -f $$d/Makefile.common ] ; then if [ -f $$d/CVS/Root -a -w $$/Makefile.common ] ; then cd $$d ; cvs -Q update ; fi ; echo "$$d/Makefile.common" ; break ; fi ; done
|
||||||
|
endef
|
||||||
|
|
||||||
|
MAKEFILE_COMMON := $(shell $(find-makefile-common))
|
||||||
|
|
||||||
|
ifeq ($(MAKEFILE_COMMON),)
|
||||||
|
# attempt a checkout
|
||||||
|
define checkout-makefile-common
|
||||||
|
test -f CVS/Root && { cvs -Q -d $$(cat CVS/Root) checkout common && echo "common/Makefile.common" ; } || { echo "ERROR: I can't figure out how to checkout the 'common' module." ; exit -1 ; } >&2
|
||||||
|
endef
|
||||||
|
|
||||||
|
MAKEFILE_COMMON := $(shell $(checkout-makefile-common))
|
||||||
|
endif
|
||||||
|
|
||||||
|
include $(MAKEFILE_COMMON)
|
||||||
|
|||||||
@@ -1,17 +0,0 @@
|
|||||||
diff -rup libvirt-0.2.2/qemud/conf.c libvirt-0.2.2.new/qemud/conf.c
|
|
||||||
--- libvirt-0.2.2/qemud/conf.c 2007-05-14 10:38:52.000000000 -0400
|
|
||||||
+++ libvirt-0.2.2.new/qemud/conf.c 2007-05-14 10:38:34.000000000 -0400
|
|
||||||
@@ -1151,6 +1151,12 @@ qemudNetworkIfaceConnect(struct qemud_se
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ if (!server->brctl && (err = brInit(&server->brctl))) {
|
|
||||||
+ qemudReportError(server, VIR_ERR_INTERNAL_ERROR,
|
|
||||||
+ "cannot initialize bridge support: %s", strerror(err));
|
|
||||||
+ goto error;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
if ((err = brAddTap(server->brctl, brname,
|
|
||||||
ifname, BR_IFNAME_MAXLEN, &tapfd))) {
|
|
||||||
qemudReportError(server, VIR_ERR_INTERNAL_ERROR,
|
|
||||||
Only in libvirt-0.2.2.new/qemud: conf.c.orig
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
diff -rup libvirt-0.2.2/src/xen_unified.c libvirt-0.2.2.new/src/xen_unified.c
|
|
||||||
--- libvirt-0.2.2/src/xen_unified.c 2007-04-17 04:38:52.000000000 -0400
|
|
||||||
+++ libvirt-0.2.2.new/src/xen_unified.c 2007-05-01 16:49:54.000000000 -0400
|
|
||||||
@@ -112,6 +112,11 @@ xenUnifiedOpen (virConnectPtr conn, cons
|
|
||||||
for (i = 0; i < nb_drivers; ++i) {
|
|
||||||
int failed_to_open = 1;
|
|
||||||
|
|
||||||
+ /* Only use XM driver for Xen <= 3.0.3 (ie xendConfigVersion <= 2) */
|
|
||||||
+ if (drivers[i] == &xenXMDriver &&
|
|
||||||
+ priv->xendConfigVersion > 2)
|
|
||||||
+ continue;
|
|
||||||
+
|
|
||||||
/* Ignore proxy for root */
|
|
||||||
if (i == proxy_offset && getuid() == 0)
|
|
||||||
continue;
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
diff -rup libvirt-0.2.2/qemud/qemud.c libvirt-0.2.2.new/qemud/qemud.c
|
|
||||||
--- libvirt-0.2.2/qemud/qemud.c 2007-04-11 10:13:36.000000000 -0400
|
|
||||||
+++ libvirt-0.2.2.new/qemud/qemud.c 2007-05-01 16:51:15.000000000 -0400
|
|
||||||
@@ -1110,6 +1110,7 @@ qemudBuildDnsmasqArgv(struct qemud_serve
|
|
||||||
len =
|
|
||||||
1 + /* dnsmasq */
|
|
||||||
1 + /* --keep-in-foreground */
|
|
||||||
+ 1 + /* --strict-order */
|
|
||||||
1 + /* --bind-interfaces */
|
|
||||||
2 + /* --pid-file "" */
|
|
||||||
2 + /* --conf-file "" */
|
|
||||||
@@ -1133,6 +1134,11 @@ qemudBuildDnsmasqArgv(struct qemud_serve
|
|
||||||
APPEND_ARG(*argv, i++, "dnsmasq");
|
|
||||||
|
|
||||||
APPEND_ARG(*argv, i++, "--keep-in-foreground");
|
|
||||||
+ /*
|
|
||||||
+ * Needed to ensure dnsmasq uses same algorithm for processing
|
|
||||||
+ * multiple nameserver entries in /etc/resolv.conf as GLibC.
|
|
||||||
+ */
|
|
||||||
+ APPEND_ARG(*argv, i++, "--strict-order");
|
|
||||||
APPEND_ARG(*argv, i++, "--bind-interfaces");
|
|
||||||
|
|
||||||
APPEND_ARG(*argv, i++, "--pid-file");
|
|
||||||
@@ -1,70 +0,0 @@
|
|||||||
diff -rup libvirt-0.2.2.new/src/xend_internal.c libvirt-0.2.2/src/xend_internal.c
|
|
||||||
--- libvirt-0.2.2.new/src/xend_internal.c 2007-04-15 16:09:10.000000000 -0400
|
|
||||||
+++ libvirt-0.2.2/src/xend_internal.c 2007-05-03 14:52:42.000000000 -0400
|
|
||||||
@@ -1676,35 +1676,38 @@ xend_parse_sexp_desc(virConnectPtr conn,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- /* Graphics device (HVM <= 3.0.4, or PV <= 3.0.4) vnc config */
|
|
||||||
- tmp = sexpr_fmt_node(root, "domain/image/%s/vnc", hvm ? "hvm" : "linux");
|
|
||||||
- if (tmp != NULL) {
|
|
||||||
- if (tmp[0] == '1') {
|
|
||||||
- int port = xenStoreDomainGetVNCPort(conn, domid);
|
|
||||||
- const char *listenAddr = sexpr_fmt_node(root, "domain/image/%s/vnclisten", hvm ? "hvm" : "linux");
|
|
||||||
- const char *keymap = sexpr_fmt_node(root, "domain/image/%s/keymap", hvm ? "hvm" : "linux");
|
|
||||||
- /* For Xen >= 3.0.3, don't generate a fixed port mapping
|
|
||||||
- * because it will almost certainly be wrong ! Just leave
|
|
||||||
- * it as -1 which lets caller see that the VNC server isn't
|
|
||||||
- * present yet. Subsquent dumps of the XML will eventually
|
|
||||||
- * find the port in XenStore once VNC server has started
|
|
||||||
- */
|
|
||||||
- if (port == -1 && xendConfigVersion < 2)
|
|
||||||
- port = 5900 + domid;
|
|
||||||
- virBufferVSprintf(&buf, " <graphics type='vnc' port='%d'", port);
|
|
||||||
- if (listenAddr)
|
|
||||||
- virBufferVSprintf(&buf, " listen='%s'", listenAddr);
|
|
||||||
- if (keymap)
|
|
||||||
- virBufferVSprintf(&buf, " keymap='%s'", keymap);
|
|
||||||
- virBufferAdd(&buf, "/>\n", 3);
|
|
||||||
+ /* Graphics device (HVM <= 3.0.4, or PV <= 3.0.3) vnc config */
|
|
||||||
+ if ((hvm && xendConfigVersion < 4) ||
|
|
||||||
+ (!hvm && xendConfigVersion < 3)) {
|
|
||||||
+ tmp = sexpr_fmt_node(root, "domain/image/%s/vnc", hvm ? "hvm" : "linux");
|
|
||||||
+ if (tmp != NULL) {
|
|
||||||
+ if (tmp[0] == '1') {
|
|
||||||
+ int port = xenStoreDomainGetVNCPort(conn, domid);
|
|
||||||
+ const char *listenAddr = sexpr_fmt_node(root, "domain/image/%s/vnclisten", hvm ? "hvm" : "linux");
|
|
||||||
+ const char *keymap = sexpr_fmt_node(root, "domain/image/%s/keymap", hvm ? "hvm" : "linux");
|
|
||||||
+ /* For Xen >= 3.0.3, don't generate a fixed port mapping
|
|
||||||
+ * because it will almost certainly be wrong ! Just leave
|
|
||||||
+ * it as -1 which lets caller see that the VNC server isn't
|
|
||||||
+ * present yet. Subsquent dumps of the XML will eventually
|
|
||||||
+ * find the port in XenStore once VNC server has started
|
|
||||||
+ */
|
|
||||||
+ if (port == -1 && xendConfigVersion < 2)
|
|
||||||
+ port = 5900 + domid;
|
|
||||||
+ virBufferVSprintf(&buf, " <graphics type='vnc' port='%d'", port);
|
|
||||||
+ if (listenAddr)
|
|
||||||
+ virBufferVSprintf(&buf, " listen='%s'", listenAddr);
|
|
||||||
+ if (keymap)
|
|
||||||
+ virBufferVSprintf(&buf, " keymap='%s'", keymap);
|
|
||||||
+ virBufferAdd(&buf, "/>\n", 3);
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
- }
|
|
||||||
|
|
||||||
- /* Graphics device (HVM, or old (pre-3.0.4) style PV sdl config) */
|
|
||||||
- tmp = sexpr_fmt_node(root, "domain/image/%s/sdl", hvm ? "hvm" : "linux");
|
|
||||||
- if (tmp != NULL) {
|
|
||||||
- if (tmp[0] == '1')
|
|
||||||
- virBufferAdd(&buf, " <graphics type='sdl'/>\n", 27 );
|
|
||||||
+ /* Graphics device (HVM, or old (pre-3.0.4) style PV sdl config) */
|
|
||||||
+ tmp = sexpr_fmt_node(root, "domain/image/%s/sdl", hvm ? "hvm" : "linux");
|
|
||||||
+ if (tmp != NULL) {
|
|
||||||
+ if (tmp[0] == '1')
|
|
||||||
+ virBufferAdd(&buf, " <graphics type='sdl'/>\n", 27 );
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
|
|
||||||
tty = xenStoreDomainGetConsolePath(conn, domid);
|
|
||||||
Only in libvirt-0.2.2/src: xend_internal.c.orig
|
|
||||||
@@ -1,128 +0,0 @@
|
|||||||
diff -rup libvirt-0.2.2/qemud/conf.c libvirt-0.2.2.new/qemud/conf.c
|
|
||||||
--- libvirt-0.2.2/qemud/conf.c 2007-04-17 04:34:42.000000000 -0400
|
|
||||||
+++ libvirt-0.2.2.new/qemud/conf.c 2007-05-14 10:36:12.000000000 -0400
|
|
||||||
@@ -245,21 +245,25 @@ static int qemudExtractVersionInfo(const
|
|
||||||
cleanup1:
|
|
||||||
_exit(-1); /* Just in case */
|
|
||||||
} else { /* Parent */
|
|
||||||
- char help[4096]; /* Ought to be enough to hold QEMU help screen */
|
|
||||||
- int got, ret = -1;
|
|
||||||
+ char help[8192]; /* Ought to be enough to hold QEMU help screen */
|
|
||||||
+ int got = 0, ret = -1;
|
|
||||||
int major, minor, micro;
|
|
||||||
|
|
||||||
if (close(newstdout[1]) < 0)
|
|
||||||
goto cleanup2;
|
|
||||||
|
|
||||||
- reread:
|
|
||||||
- if ((got = read(newstdout[0], help, sizeof(help)-1)) < 0) {
|
|
||||||
- if (errno == EINTR)
|
|
||||||
- goto reread;
|
|
||||||
- goto cleanup2;
|
|
||||||
+ while (got < (sizeof(help)-1)) {
|
|
||||||
+ int len;
|
|
||||||
+ if ((len = read(newstdout[0], help+got, sizeof(help)-got-1)) <= 0) {
|
|
||||||
+ if (!len)
|
|
||||||
+ break;
|
|
||||||
+ if (errno == EINTR)
|
|
||||||
+ continue;
|
|
||||||
+ goto cleanup2;
|
|
||||||
+ }
|
|
||||||
+ got += len;
|
|
||||||
}
|
|
||||||
help[got] = '\0';
|
|
||||||
-
|
|
||||||
if (sscanf(help, "QEMU PC emulator version %d.%d.%d", &major,&minor, µ) != 3) {
|
|
||||||
goto cleanup2;
|
|
||||||
}
|
|
||||||
@@ -267,6 +271,8 @@ static int qemudExtractVersionInfo(const
|
|
||||||
*version = (major * 1000 * 1000) + (minor * 1000) + micro;
|
|
||||||
if (strstr(help, "-no-kqemu"))
|
|
||||||
*flags |= QEMUD_CMD_FLAG_KQEMU;
|
|
||||||
+ if (strstr(help, "-no-reboot"))
|
|
||||||
+ *flags |= QEMUD_CMD_FLAG_NO_REBOOT;
|
|
||||||
if (*version >= 9000)
|
|
||||||
*flags |= QEMUD_CMD_FLAG_VNC_COLON;
|
|
||||||
ret = 0;
|
|
||||||
@@ -858,6 +864,22 @@ static struct qemud_vm_def *qemudParseXM
|
|
||||||
}
|
|
||||||
xmlXPathFreeObject(obj);
|
|
||||||
|
|
||||||
+
|
|
||||||
+ /* See if we disable reboots */
|
|
||||||
+ obj = xmlXPathEval(BAD_CAST "string(/domain/on_reboot)", ctxt);
|
|
||||||
+ if ((obj == NULL) || (obj->type != XPATH_STRING) ||
|
|
||||||
+ (obj->stringval == NULL) || (obj->stringval[0] == 0)) {
|
|
||||||
+ def->noReboot = 0;
|
|
||||||
+ } else {
|
|
||||||
+ if (!strcmp((char*)obj->stringval, "destroy"))
|
|
||||||
+ def->noReboot = 1;
|
|
||||||
+ else
|
|
||||||
+ def->noReboot = 0;
|
|
||||||
+ }
|
|
||||||
+ if (obj)
|
|
||||||
+ xmlXPathFreeObject(obj);
|
|
||||||
+
|
|
||||||
+
|
|
||||||
/* Extract OS type info */
|
|
||||||
obj = xmlXPathEval(BAD_CAST "string(/domain/os/type[1])", ctxt);
|
|
||||||
if ((obj == NULL) || (obj->type != XPATH_STRING) ||
|
|
||||||
@@ -1220,6 +1242,8 @@ int qemudBuildCommandLine(struct qemud_s
|
|
||||||
2 + /* cpus */
|
|
||||||
2 + /* boot device */
|
|
||||||
2 + /* monitor */
|
|
||||||
+ (server->qemuCmdFlags & QEMUD_CMD_FLAG_NO_REBOOT &&
|
|
||||||
+ vm->def->noReboot ? 1 : 0) + /* no-reboot */
|
|
||||||
(vm->def->features & QEMUD_FEATURE_ACPI ? 0 : 1) + /* acpi */
|
|
||||||
(vm->def->os.kernel[0] ? 2 : 0) + /* kernel */
|
|
||||||
(vm->def->os.initrd[0] ? 2 : 0) + /* initrd */
|
|
||||||
@@ -1255,6 +1279,11 @@ int qemudBuildCommandLine(struct qemud_s
|
|
||||||
goto no_memory;
|
|
||||||
if (!((*argv)[++n] = strdup("pty")))
|
|
||||||
goto no_memory;
|
|
||||||
+ if (server->qemuCmdFlags & QEMUD_CMD_FLAG_NO_REBOOT &&
|
|
||||||
+ vm->def->noReboot) {
|
|
||||||
+ if (!((*argv)[++n] = strdup("-no-reboot")))
|
|
||||||
+ goto no_memory;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
if (!(vm->def->features & QEMUD_FEATURE_ACPI)) {
|
|
||||||
if (!((*argv)[++n] = strdup("-no-acpi")))
|
|
||||||
@@ -2517,6 +2546,17 @@ char *qemudGenerateXML(struct qemud_serv
|
|
||||||
goto no_memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ if (bufferAdd(buf, " <on_poweroff>destroy</on_poweroff>\n", -1) < 0)
|
|
||||||
+ goto no_memory;
|
|
||||||
+ if (def->noReboot) {
|
|
||||||
+ if (bufferAdd(buf, " <on_reboot>destroy</on_reboot>\n", -1) < 0)
|
|
||||||
+ goto no_memory;
|
|
||||||
+ } else {
|
|
||||||
+ if (bufferAdd(buf, " <on_reboot>restart</on_reboot>\n", -1) < 0)
|
|
||||||
+ goto no_memory;
|
|
||||||
+ }
|
|
||||||
+ if (bufferAdd(buf, " <on_crash>destroy</on_crash>\n", -1) < 0)
|
|
||||||
+ goto no_memory;
|
|
||||||
|
|
||||||
if (bufferAdd(buf, " <devices>\n", -1) < 0)
|
|
||||||
goto no_memory;
|
|
||||||
diff -rup libvirt-0.2.2/qemud/internal.h libvirt-0.2.2.new/qemud/internal.h
|
|
||||||
--- libvirt-0.2.2/qemud/internal.h 2007-04-11 10:13:36.000000000 -0400
|
|
||||||
+++ libvirt-0.2.2.new/qemud/internal.h 2007-05-14 10:36:02.000000000 -0400
|
|
||||||
@@ -161,6 +161,7 @@ enum qemud_vm_grapics_type {
|
|
||||||
enum qemud_cmd_flags {
|
|
||||||
QEMUD_CMD_FLAG_KQEMU = 1,
|
|
||||||
QEMUD_CMD_FLAG_VNC_COLON = 2,
|
|
||||||
+ QEMUD_CMD_FLAG_NO_REBOOT = 4,
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
@@ -191,6 +192,8 @@ struct qemud_vm_def {
|
|
||||||
int maxmem;
|
|
||||||
int vcpus;
|
|
||||||
|
|
||||||
+ int noReboot;
|
|
||||||
+
|
|
||||||
struct qemud_vm_os_def os;
|
|
||||||
|
|
||||||
int features;
|
|
||||||
@@ -1,19 +0,0 @@
|
|||||||
--- libvirt-0.2.2/ChangeLog.sync-restart 2007-05-02 13:07:21.719425000 -0400
|
|
||||||
+++ libvirt-0.2.2/ChangeLog 2007-05-02 13:08:23.204879000 -0400
|
|
||||||
@@ -0,0 +1,5 @@
|
|
||||||
+Wed May 2 17:55:12 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|
||||||
+
|
|
||||||
+ * qemud/libvirtd.in: synchronously restart the daemon in
|
|
||||||
+ order to avoid https://bugzilla.redhat.com/238492
|
|
||||||
+
|
|
||||||
--- libvirt-0.2.2/qemud/libvirtd.in.sync-restart 2007-02-23 07:50:58.000000000 -0500
|
|
||||||
+++ libvirt-0.2.2/qemud/libvirtd.in 2007-05-02 13:08:23.209868000 -0400
|
|
||||||
@@ -34,7 +34,7 @@
|
|
||||||
stop() {
|
|
||||||
echo -n $"Stopping $SERVICE daemon: "
|
|
||||||
|
|
||||||
- killproc $PROCESS -TERM
|
|
||||||
+ killproc $PROCESS
|
|
||||||
RETVAL=$?
|
|
||||||
echo
|
|
||||||
if [ $RETVAL -eq 0 ]; then
|
|
||||||
51
libvirt-0.6.4-svirt-sound.patch
Normal file
51
libvirt-0.6.4-svirt-sound.patch
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
From 127a39777e9809053bb98a9082e27c73543ccfa2 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
Date: Mon, 17 Aug 2009 08:32:08 +0100
|
||||||
|
Subject: [PATCH] Disable sound cards when running sVirt
|
||||||
|
|
||||||
|
Temporary hack till PulseAudio autostart problems are sorted out when
|
||||||
|
SELinux enforcing (bz 486112)
|
||||||
|
|
||||||
|
Fedora-patch: libvirt-0.6.4-svirt-sound.patch
|
||||||
|
---
|
||||||
|
src/qemu_conf.c | 17 ++++++++++++++++-
|
||||||
|
1 files changed, 16 insertions(+), 1 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/qemu_conf.c b/src/qemu_conf.c
|
||||||
|
index f92bcef..f3b4ef0 100644
|
||||||
|
--- a/src/qemu_conf.c
|
||||||
|
+++ b/src/qemu_conf.c
|
||||||
|
@@ -1510,6 +1510,20 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
||||||
|
char uuid[VIR_UUID_STRING_BUFLEN];
|
||||||
|
char domid[50];
|
||||||
|
const char *cpu = NULL;
|
||||||
|
+ int skipSound = 0;
|
||||||
|
+
|
||||||
|
+ if (driver->securityDriver &&
|
||||||
|
+ driver->securityDriver->name &&
|
||||||
|
+ STREQ(driver->securityDriver->name, "selinux") &&
|
||||||
|
+ getuid() == 0) {
|
||||||
|
+ static int soundWarned = 0;
|
||||||
|
+ skipSound = 1;
|
||||||
|
+ if (def->nsounds &&
|
||||||
|
+ !soundWarned) {
|
||||||
|
+ soundWarned = 1;
|
||||||
|
+ VIR_WARN0("Sound cards for VMs are disabled while SELinux security model is active");
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
|
||||||
|
uname_normalize(&ut);
|
||||||
|
|
||||||
|
@@ -2181,7 +2195,8 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Add sound hardware */
|
||||||
|
- if (def->nsounds) {
|
||||||
|
+ if (def->nsounds &&
|
||||||
|
+ !skipSound) {
|
||||||
|
int size = 100;
|
||||||
|
char *modstr;
|
||||||
|
if (VIR_ALLOC_N(modstr, size+1) < 0)
|
||||||
|
--
|
||||||
|
1.6.2.5
|
||||||
|
|
||||||
32
libvirt-fix-drv-supports-feature-bogus-error.patch
Normal file
32
libvirt-fix-drv-supports-feature-bogus-error.patch
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
From 2f6e857ac7d6ed5cd417e684147dd9c98775ab3d Mon Sep 17 00:00:00 2001
|
||||||
|
From: Chris Lalancette <clalance@redhat.com>
|
||||||
|
Date: Mon, 21 Sep 2009 14:53:31 +0200
|
||||||
|
Subject: [PATCH] Don't do virSetConnError when virDrvSupportsFeature is successful.
|
||||||
|
|
||||||
|
Signed-off-by: Chris Lalancette <clalance@redhat.com>
|
||||||
|
Fedora-patch: libvirt-fix-drv-supports-feature-bogus-error.patch
|
||||||
|
---
|
||||||
|
src/libvirt.c | 7 +++++--
|
||||||
|
1 files changed, 5 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/libvirt.c b/src/libvirt.c
|
||||||
|
index 4a11688..fa59dc7 100644
|
||||||
|
--- a/src/libvirt.c
|
||||||
|
+++ b/src/libvirt.c
|
||||||
|
@@ -1349,8 +1349,11 @@ virDrvSupportsFeature (virConnectPtr conn, int feature)
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = VIR_DRV_SUPPORTS_FEATURE (conn->driver, conn, feature);
|
||||||
|
- /* Copy to connection error object for back compatability */
|
||||||
|
- virSetConnError(conn);
|
||||||
|
+
|
||||||
|
+ if (ret < 0)
|
||||||
|
+ /* Copy to connection error object for back compatability */
|
||||||
|
+ virSetConnError(conn);
|
||||||
|
+
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
--
|
||||||
|
1.6.2.5
|
||||||
|
|
||||||
46
libvirt-fix-net-hotunplug-double-free.patch
Normal file
46
libvirt-fix-net-hotunplug-double-free.patch
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
From d09ff3c35c29d14760d5ea03559042cc024e09ab Mon Sep 17 00:00:00 2001
|
||||||
|
From: Mark McLoughlin <markmc@redhat.com>
|
||||||
|
Date: Thu, 17 Sep 2009 15:31:08 +0100
|
||||||
|
Subject: [PATCH] Fix net/disk hot-unplug segfault
|
||||||
|
|
||||||
|
When we hot-unplug the last device, we're currently double-freeing
|
||||||
|
the device definition.
|
||||||
|
|
||||||
|
Reported by Michal Nowak here:
|
||||||
|
|
||||||
|
https://bugzilla.redhat.com/523953
|
||||||
|
|
||||||
|
* src/qemu_driver.c: fix double free
|
||||||
|
|
||||||
|
(cherry-picked from commit 8881ae1bf8783006777429403cc543c33187175d)
|
||||||
|
|
||||||
|
Fedora-patch: libvirt-fix-net-hotunplug-double-free.patch
|
||||||
|
---
|
||||||
|
src/qemu_driver.c | 4 ++--
|
||||||
|
1 files changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/qemu_driver.c b/src/qemu_driver.c
|
||||||
|
index a65334f..de31581 100644
|
||||||
|
--- a/src/qemu_driver.c
|
||||||
|
+++ b/src/qemu_driver.c
|
||||||
|
@@ -5998,7 +5998,7 @@ try_command:
|
||||||
|
/* ignore, harmless */
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
- VIR_FREE(vm->def->disks[0]);
|
||||||
|
+ VIR_FREE(vm->def->disks);
|
||||||
|
vm->def->ndisks = 0;
|
||||||
|
}
|
||||||
|
virDomainDiskDefFree(detach);
|
||||||
|
@@ -6100,7 +6100,7 @@ qemudDomainDetachNetDevice(virConnectPtr conn,
|
||||||
|
/* ignore, harmless */
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
- VIR_FREE(vm->def->nets[0]);
|
||||||
|
+ VIR_FREE(vm->def->nets);
|
||||||
|
vm->def->nnets = 0;
|
||||||
|
}
|
||||||
|
virDomainNetDefFree(detach);
|
||||||
|
--
|
||||||
|
1.6.2.5
|
||||||
|
|
||||||
50
libvirt-fix-pci-hostdev-hotunplug-leak.patch
Normal file
50
libvirt-fix-pci-hostdev-hotunplug-leak.patch
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
From d04ac8624f5fabe7587982796f2e2161220b0fcc Mon Sep 17 00:00:00 2001
|
||||||
|
From: Mark McLoughlin <markmc@redhat.com>
|
||||||
|
Date: Thu, 17 Sep 2009 15:32:45 +0100
|
||||||
|
Subject: [PATCH] Fix leak in PCI hostdev hot-unplug
|
||||||
|
|
||||||
|
* src/qemu_driver.c: sync the hostdev hot-unplug code with the disk/net
|
||||||
|
code.
|
||||||
|
|
||||||
|
(cherry-picked from commit a70da51ff76ed860bfc0cdee2e1d556da997c557)
|
||||||
|
|
||||||
|
Fedora-patch: libvirt-fix-pci-hostdev-hotunplug-leak.patch
|
||||||
|
---
|
||||||
|
src/qemu_driver.c | 20 +++++++++++++-------
|
||||||
|
1 files changed, 13 insertions(+), 7 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/qemu_driver.c b/src/qemu_driver.c
|
||||||
|
index de31581..2ddcdc0 100644
|
||||||
|
--- a/src/qemu_driver.c
|
||||||
|
+++ b/src/qemu_driver.c
|
||||||
|
@@ -6206,14 +6206,20 @@ static int qemudDomainDetachHostPciDevice(virConnectPtr conn,
|
||||||
|
pciFreeDevice(conn, pci);
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (i != --vm->def->nhostdevs)
|
||||||
|
- memmove(&vm->def->hostdevs[i],
|
||||||
|
- &vm->def->hostdevs[i+1],
|
||||||
|
- sizeof(*vm->def->hostdevs) * (vm->def->nhostdevs-i));
|
||||||
|
- if (VIR_REALLOC_N(vm->def->hostdevs, vm->def->nhostdevs) < 0) {
|
||||||
|
- virReportOOMError(conn);
|
||||||
|
- ret = -1;
|
||||||
|
+ if (vm->def->nhostdevs > 1) {
|
||||||
|
+ memmove(vm->def->hostdevs + i,
|
||||||
|
+ vm->def->hostdevs + i + 1,
|
||||||
|
+ sizeof(*vm->def->hostdevs) *
|
||||||
|
+ (vm->def->nhostdevs - (i + 1)));
|
||||||
|
+ vm->def->nhostdevs--;
|
||||||
|
+ if (VIR_REALLOC_N(vm->def->hostdevs, vm->def->nhostdevs) < 0) {
|
||||||
|
+ /* ignore, harmless */
|
||||||
|
+ }
|
||||||
|
+ } else {
|
||||||
|
+ VIR_FREE(vm->def->hostdevs);
|
||||||
|
+ vm->def->nhostdevs = 0;
|
||||||
|
}
|
||||||
|
+ virDomainHostdevDefFree(detach);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
--
|
||||||
|
1.6.2.5
|
||||||
|
|
||||||
53
libvirt-fix-qemu-raw-format-save.patch
Normal file
53
libvirt-fix-qemu-raw-format-save.patch
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
From e50c91fdcea5d81e3eb2051c05f4e51a16c3e692 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Charles Duffy <Charles_Duffy@dell.com>
|
||||||
|
Date: Fri, 18 Sep 2009 11:32:35 -0500
|
||||||
|
Subject: [PATCH] Prevent attempt to call cat -c during virDomainSave to raw
|
||||||
|
|
||||||
|
Fedora-patch: libvirt-fix-qemu-raw-format-save.patch
|
||||||
|
---
|
||||||
|
src/qemu_driver.c | 28 ++++++++++++++++++----------
|
||||||
|
1 files changed, 18 insertions(+), 10 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/qemu_driver.c b/src/qemu_driver.c
|
||||||
|
index 2ddcdc0..7c7b985 100644
|
||||||
|
--- a/src/qemu_driver.c
|
||||||
|
+++ b/src/qemu_driver.c
|
||||||
|
@@ -3905,17 +3905,25 @@ static int qemudDomainSave(virDomainPtr dom,
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
- const char *prog = qemudSaveCompressionTypeToString(header.compressed);
|
||||||
|
- if (prog == NULL) {
|
||||||
|
- qemudReportError(dom->conn, dom, NULL, VIR_ERR_INTERNAL_ERROR,
|
||||||
|
- _("Invalid compress format %d"), header.compressed);
|
||||||
|
- goto cleanup;
|
||||||
|
- }
|
||||||
|
+ {
|
||||||
|
+ const char *prog = qemudSaveCompressionTypeToString(header.compressed);
|
||||||
|
+ const char *args;
|
||||||
|
|
||||||
|
- if (STREQ (prog, "raw"))
|
||||||
|
- prog = "cat";
|
||||||
|
- internalret = virAsprintf(&command, "migrate \"exec:"
|
||||||
|
- "%s -c >> '%s' 2>/dev/null\"", prog, safe_path);
|
||||||
|
+ if (prog == NULL) {
|
||||||
|
+ qemudReportError(dom->conn, dom, NULL, VIR_ERR_INTERNAL_ERROR,
|
||||||
|
+ _("Invalid compress format %d"), header.compressed);
|
||||||
|
+ goto cleanup;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (STREQ (prog, "raw")) {
|
||||||
|
+ prog = "cat";
|
||||||
|
+ args = "";
|
||||||
|
+ } else {
|
||||||
|
+ args = "-c";
|
||||||
|
+ }
|
||||||
|
+ internalret = virAsprintf(&command, "migrate \"exec:"
|
||||||
|
+ "%s %s >> '%s' 2>/dev/null\"", prog, args, safe_path);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
if (internalret < 0) {
|
||||||
|
virReportOOMError(dom->conn);
|
||||||
|
--
|
||||||
|
1.6.2.5
|
||||||
|
|
||||||
884
libvirt.spec
884
libvirt.spec
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user