From c33a922faad1de363aa4212edc1a329bd47e52b0 Mon Sep 17 00:00:00 2001 From: Martin Kletzander Date: Tue, 18 Sep 2012 12:30:52 +0200 Subject: [PATCH] Add support for reboot-timeout Whenever the guest machine fails to boot, new parameter (reboot-timeout) controls whether it should reboot and after how many ms it should do so. Docs included. --- docs/formatdomain.html.in | 11 ++++++++--- docs/schemas/domaincommon.rng | 24 ++++++++++++++++++------ src/conf/domain_conf.c | 33 +++++++++++++++++++++++++++------ src/conf/domain_conf.h | 3 +++ 4 files changed, 56 insertions(+), 15 deletions(-) diff --git a/docs/formatdomain.html.in b/docs/formatdomain.html.in index 51f897cd9c..a403ba8c5b 100644 --- a/docs/formatdomain.html.in +++ b/docs/formatdomain.html.in @@ -105,7 +105,7 @@ <boot dev='cdrom'/> <bootmenu enable='yes'/> <smbios mode='sysinfo'/> - <bios useserial='yes'/> + <bios useserial='yes' rebootTimeout='0'/> </os> ... @@ -175,8 +175,13 @@ Serial Graphics Adapter which allows users to see BIOS messages on a serial port. Therefore, one needs to have serial port defined. - Since 0.9.4 - + Since 0.9.4. + Since 0.10.2 (QEMU only) there is + another attribute, rebootTimeout that controls + whether and after how long the guest should start booting + again in case the boot fails (according to BIOS). The value is + in milliseconds with maximum of 65535 and special + value -1 disables the reboot.

Host bootloader

diff --git a/docs/schemas/domaincommon.rng b/docs/schemas/domaincommon.rng index aafb10c575..afa6bbd19f 100644 --- a/docs/schemas/domaincommon.rng +++ b/docs/schemas/domaincommon.rng @@ -3190,12 +3190,19 @@ - - - yes - no - - + + + + yes + no + + + + + + + + @@ -3469,6 +3476,11 @@ -1 + + + -1 + + -1 diff --git a/src/conf/domain_conf.c b/src/conf/domain_conf.c index 35814fb021..d6f2ebfe20 100644 --- a/src/conf/domain_conf.c +++ b/src/conf/domain_conf.c @@ -8136,7 +8136,7 @@ virDomainDefParseBootXML(xmlXPathContextPtr ctxt, { xmlNodePtr *nodes = NULL; int i, n; - char *bootstr; + char *bootstr, *tmp; char *useserial = NULL; int ret = -1; unsigned long deviceBoot, serialPorts; @@ -8214,10 +8214,25 @@ virDomainDefParseBootXML(xmlXPathContextPtr ctxt, } } + tmp = virXPathString("string(./os/bios[1]/@rebootTimeout)", ctxt); + if (tmp) { + /* that was really just for the check if it is there */ + + if (virStrToLong_i(tmp, NULL, 0, &def->os.bios.rt_delay) < 0 || + def->os.bios.rt_delay < -1 || def->os.bios.rt_delay > 65535) { + virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s", + _("invalid value for rebootTimeout, " + "must be in range [-1,65535]")); + goto cleanup; + } + def->os.bios.rt_set = true; + } + *bootCount = deviceBoot; ret = 0; cleanup: + VIR_FREE(tmp); VIR_FREE(useserial); VIR_FREE(nodes); return ret; @@ -13494,11 +13509,17 @@ virDomainDefFormatInternal(virDomainDefPtr def, virBufferAsprintf(buf, " \n", enabled); } - if (def->os.bios.useserial) { - const char *useserial = (def->os.bios.useserial == - VIR_DOMAIN_BIOS_USESERIAL_YES ? "yes" - : "no"); - virBufferAsprintf(buf, " \n", useserial); + if (def->os.bios.useserial || def->os.bios.rt_set) { + virBufferAddLit(buf, " os.bios.useserial) + virBufferAsprintf(buf, " useserial='%s'", + (def->os.bios.useserial == + VIR_DOMAIN_BIOS_USESERIAL_YES ? "yes" + : "no")); + if (def->os.bios.rt_set) + virBufferAsprintf(buf, " rebootTimeout='%d'", def->os.bios.rt_delay); + + virBufferAddLit(buf, "/>\n"); } } diff --git a/src/conf/domain_conf.h b/src/conf/domain_conf.h index 510406a631..d719d57dad 100644 --- a/src/conf/domain_conf.h +++ b/src/conf/domain_conf.h @@ -1420,6 +1420,9 @@ typedef struct _virDomainBIOSDef virDomainBIOSDef; typedef virDomainBIOSDef *virDomainBIOSDefPtr; struct _virDomainBIOSDef { int useserial; + /* reboot-timeout parameters */ + bool rt_set; + int rt_delay; }; /* Operating system configuration data & machine / arch */