xen: Remove virConnectPtr from virXMError

This commit is contained in:
Matthias Bolte 2010-04-03 01:29:12 +02:00
parent 5cec7af469
commit f2192637b0

View File

@ -121,8 +121,8 @@ struct xenUnifiedDriver xenXMDriver = {
NULL, /* domainSetSchedulerParameters */ NULL, /* domainSetSchedulerParameters */
}; };
#define xenXMError(conn, code, ...) \ #define xenXMError(code, ...) \
virReportErrorHelper(conn, VIR_FROM_XENXM, code, __FILE__, \ virReportErrorHelper(NULL, VIR_FROM_XENXM, code, __FILE__, \
__FUNCTION__, __LINE__, __VA_ARGS__) __FUNCTION__, __LINE__, __VA_ARGS__)
#ifndef WITH_XEN_INOTIFY #ifndef WITH_XEN_INOTIFY
@ -139,8 +139,7 @@ static int xenInotifyActive(virConnectPtr conn)
#endif #endif
/* Convenience method to grab a int from the config file object */ /* Convenience method to grab a int from the config file object */
static int xenXMConfigGetBool(virConnectPtr conn, static int xenXMConfigGetBool(virConfPtr conf,
virConfPtr conf,
const char *name, const char *name,
int *value, int *value,
int def) { int def) {
@ -157,7 +156,7 @@ static int xenXMConfigGetBool(virConnectPtr conn,
} else if (val->type == VIR_CONF_STRING) { } else if (val->type == VIR_CONF_STRING) {
*value = STREQ(val->str, "1") ? 1 : 0; *value = STREQ(val->str, "1") ? 1 : 0;
} else { } else {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("config value %s was malformed"), name); _("config value %s was malformed"), name);
return -1; return -1;
} }
@ -166,8 +165,7 @@ static int xenXMConfigGetBool(virConnectPtr conn,
/* Convenience method to grab a int from the config file object */ /* Convenience method to grab a int from the config file object */
static int xenXMConfigGetULong(virConnectPtr conn, static int xenXMConfigGetULong(virConfPtr conf,
virConfPtr conf,
const char *name, const char *name,
unsigned long *value, unsigned long *value,
int def) { int def) {
@ -185,12 +183,12 @@ static int xenXMConfigGetULong(virConnectPtr conn,
char *ret; char *ret;
*value = strtol(val->str, &ret, 10); *value = strtol(val->str, &ret, 10);
if (ret == val->str) { if (ret == val->str) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("config value %s was malformed"), name); _("config value %s was malformed"), name);
return -1; return -1;
} }
} else { } else {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("config value %s was malformed"), name); _("config value %s was malformed"), name);
return -1; return -1;
} }
@ -199,8 +197,7 @@ static int xenXMConfigGetULong(virConnectPtr conn,
/* Convenience method to grab a string from the config file object */ /* Convenience method to grab a string from the config file object */
static int xenXMConfigGetString(virConnectPtr conn, static int xenXMConfigGetString(virConfPtr conf,
virConfPtr conf,
const char *name, const char *name,
const char **value, const char **value,
const char *def) { const char *def) {
@ -213,7 +210,7 @@ static int xenXMConfigGetString(virConnectPtr conn,
} }
if (val->type != VIR_CONF_STRING) { if (val->type != VIR_CONF_STRING) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("config value %s was malformed"), name); _("config value %s was malformed"), name);
return -1; return -1;
} }
@ -224,8 +221,7 @@ static int xenXMConfigGetString(virConnectPtr conn,
return 0; return 0;
} }
static int xenXMConfigCopyStringInternal(virConnectPtr conn, static int xenXMConfigCopyStringInternal(virConfPtr conf,
virConfPtr conf,
const char *name, const char *name,
char **value, char **value,
int allowMissing) { int allowMissing) {
@ -235,20 +231,20 @@ static int xenXMConfigCopyStringInternal(virConnectPtr conn,
if (!(val = virConfGetValue(conf, name))) { if (!(val = virConfGetValue(conf, name))) {
if (allowMissing) if (allowMissing)
return 0; return 0;
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("config value %s was missing"), name); _("config value %s was missing"), name);
return -1; return -1;
} }
if (val->type != VIR_CONF_STRING) { if (val->type != VIR_CONF_STRING) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("config value %s was not a string"), name); _("config value %s was not a string"), name);
return -1; return -1;
} }
if (!val->str) { if (!val->str) {
if (allowMissing) if (allowMissing)
return 0; return 0;
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("config value %s was missing"), name); _("config value %s was missing"), name);
return -1; return -1;
} }
@ -262,18 +258,16 @@ static int xenXMConfigCopyStringInternal(virConnectPtr conn,
} }
static int xenXMConfigCopyString(virConnectPtr conn, static int xenXMConfigCopyString(virConfPtr conf,
virConfPtr conf,
const char *name, const char *name,
char **value) { char **value) {
return xenXMConfigCopyStringInternal(conn, conf, name, value, 0); return xenXMConfigCopyStringInternal(conf, name, value, 0);
} }
static int xenXMConfigCopyStringOpt(virConnectPtr conn, static int xenXMConfigCopyStringOpt(virConfPtr conf,
virConfPtr conf,
const char *name, const char *name,
char **value) { char **value) {
return xenXMConfigCopyStringInternal(conn, conf, name, value, 1); return xenXMConfigCopyStringInternal(conf, name, value, 1);
} }
@ -456,7 +450,7 @@ xenXMConfigCacheAddFile(virConnectPtr conn, const char *filename)
if (virHashAddEntry(priv->configCache, entry->filename, entry) < 0) { if (virHashAddEntry(priv->configCache, entry->filename, entry) < 0) {
virDomainDefFree(entry->def); virDomainDefFree(entry->def);
VIR_FREE(entry); VIR_FREE(entry);
xenXMError (conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("xenXMConfigCacheRefresh: virHashAddEntry")); "%s", _("xenXMConfigCacheRefresh: virHashAddEntry"));
return -1; return -1;
} }
@ -633,8 +627,7 @@ int xenXMDomainGetInfo(virDomainPtr domain, virDomainInfoPtr info) {
const char *filename; const char *filename;
xenXMConfCachePtr entry; xenXMConfCachePtr entry;
if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) { if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) {
xenXMError((domain ? domain->conn : NULL), VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return(-1); return(-1);
} }
@ -694,13 +687,13 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
def->virtType = VIR_DOMAIN_VIRT_XEN; def->virtType = VIR_DOMAIN_VIRT_XEN;
def->id = -1; def->id = -1;
if (xenXMConfigCopyString(conn, conf, "name", &def->name) < 0) if (xenXMConfigCopyString(conf, "name", &def->name) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigGetUUID(conf, "uuid", def->uuid) < 0) if (xenXMConfigGetUUID(conf, "uuid", def->uuid) < 0)
goto cleanup; goto cleanup;
if ((xenXMConfigGetString(conn, conf, "builder", &str, "linux") == 0) && if ((xenXMConfigGetString(conf, "builder", &str, "linux") == 0) &&
STREQ(str, "hvm")) STREQ(str, "hvm"))
hvm = 1; hvm = 1;
@ -709,7 +702,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
defaultArch = virCapabilitiesDefaultGuestArch(priv->caps, def->os.type, virDomainVirtTypeToString(def->virtType)); defaultArch = virCapabilitiesDefaultGuestArch(priv->caps, def->os.type, virDomainVirtTypeToString(def->virtType));
if (defaultArch == NULL) { if (defaultArch == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("no supported architecture for os type '%s'"), _("no supported architecture for os type '%s'"),
def->os.type); def->os.type);
goto cleanup; goto cleanup;
@ -728,10 +721,10 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
if (hvm) { if (hvm) {
const char *boot; const char *boot;
if (xenXMConfigCopyString(conn, conf, "kernel", &def->os.loader) < 0) if (xenXMConfigCopyString(conf, "kernel", &def->os.loader) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigGetString(conn, conf, "boot", &boot, "c") < 0) if (xenXMConfigGetString(conf, "boot", &boot, "c") < 0)
goto cleanup; goto cleanup;
for (i = 0 ; i < VIR_DOMAIN_BOOT_LAST && boot[i] ; i++) { for (i = 0 ; i < VIR_DOMAIN_BOOT_LAST && boot[i] ; i++) {
@ -753,33 +746,33 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
def->os.nBootDevs++; def->os.nBootDevs++;
} }
} else { } else {
if (xenXMConfigCopyStringOpt(conn, conf, "bootloader", &def->os.bootloader) < 0) if (xenXMConfigCopyStringOpt(conf, "bootloader", &def->os.bootloader) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigCopyStringOpt(conn, conf, "bootargs", &def->os.bootloaderArgs) < 0) if (xenXMConfigCopyStringOpt(conf, "bootargs", &def->os.bootloaderArgs) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigCopyStringOpt(conn, conf, "kernel", &def->os.kernel) < 0) if (xenXMConfigCopyStringOpt(conf, "kernel", &def->os.kernel) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigCopyStringOpt(conn, conf, "ramdisk", &def->os.initrd) < 0) if (xenXMConfigCopyStringOpt(conf, "ramdisk", &def->os.initrd) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigCopyStringOpt(conn, conf, "extra", &def->os.cmdline) < 0) if (xenXMConfigCopyStringOpt(conf, "extra", &def->os.cmdline) < 0)
goto cleanup; goto cleanup;
} }
if (xenXMConfigGetULong(conn, conf, "memory", &def->memory, MIN_XEN_GUEST_SIZE * 2) < 0) if (xenXMConfigGetULong(conf, "memory", &def->memory, MIN_XEN_GUEST_SIZE * 2) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigGetULong(conn, conf, "maxmem", &def->maxmem, def->memory) < 0) if (xenXMConfigGetULong(conf, "maxmem", &def->maxmem, def->memory) < 0)
goto cleanup; goto cleanup;
def->memory *= 1024; def->memory *= 1024;
def->maxmem *= 1024; def->maxmem *= 1024;
if (xenXMConfigGetULong(conn, conf, "vcpus", &def->vcpus, 1) < 0) if (xenXMConfigGetULong(conf, "vcpus", &def->vcpus, 1) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigGetString(conn, conf, "cpus", &str, NULL) < 0) if (xenXMConfigGetString(conf, "cpus", &str, NULL) < 0)
goto cleanup; goto cleanup;
if (str) { if (str) {
def->cpumasklen = 4096; def->cpumasklen = 4096;
@ -792,26 +785,26 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
} }
if (xenXMConfigGetString(conn, conf, "on_poweroff", &str, "destroy") < 0) if (xenXMConfigGetString(conf, "on_poweroff", &str, "destroy") < 0)
goto cleanup; goto cleanup;
if ((def->onPoweroff = virDomainLifecycleTypeFromString(str)) < 0) { if ((def->onPoweroff = virDomainLifecycleTypeFromString(str)) < 0) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("unexpected value %s for on_poweroff"), str); _("unexpected value %s for on_poweroff"), str);
goto cleanup; goto cleanup;
} }
if (xenXMConfigGetString(conn, conf, "on_reboot", &str, "restart") < 0) if (xenXMConfigGetString(conf, "on_reboot", &str, "restart") < 0)
goto cleanup; goto cleanup;
if ((def->onReboot = virDomainLifecycleTypeFromString(str)) < 0) { if ((def->onReboot = virDomainLifecycleTypeFromString(str)) < 0) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("unexpected value %s for on_reboot"), str); _("unexpected value %s for on_reboot"), str);
goto cleanup; goto cleanup;
} }
if (xenXMConfigGetString(conn, conf, "on_crash", &str, "restart") < 0) if (xenXMConfigGetString(conf, "on_crash", &str, "restart") < 0)
goto cleanup; goto cleanup;
if ((def->onCrash = virDomainLifecycleTypeFromString(str)) < 0) { if ((def->onCrash = virDomainLifecycleTypeFromString(str)) < 0) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("unexpected value %s for on_crash"), str); _("unexpected value %s for on_crash"), str);
goto cleanup; goto cleanup;
} }
@ -819,27 +812,27 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
if (hvm) { if (hvm) {
if (xenXMConfigGetBool(conn, conf, "pae", &val, 0) < 0) if (xenXMConfigGetBool(conf, "pae", &val, 0) < 0)
goto cleanup; goto cleanup;
else if (val) else if (val)
def->features |= (1 << VIR_DOMAIN_FEATURE_PAE); def->features |= (1 << VIR_DOMAIN_FEATURE_PAE);
if (xenXMConfigGetBool(conn, conf, "acpi", &val, 0) < 0) if (xenXMConfigGetBool(conf, "acpi", &val, 0) < 0)
goto cleanup; goto cleanup;
else if (val) else if (val)
def->features |= (1 << VIR_DOMAIN_FEATURE_ACPI); def->features |= (1 << VIR_DOMAIN_FEATURE_ACPI);
if (xenXMConfigGetBool(conn, conf, "apic", &val, 0) < 0) if (xenXMConfigGetBool(conf, "apic", &val, 0) < 0)
goto cleanup; goto cleanup;
else if (val) else if (val)
def->features |= (1 << VIR_DOMAIN_FEATURE_APIC); def->features |= (1 << VIR_DOMAIN_FEATURE_APIC);
} }
if (xenXMConfigGetBool(conn, conf, "localtime", &vmlocaltime, 0) < 0) if (xenXMConfigGetBool(conf, "localtime", &vmlocaltime, 0) < 0)
goto cleanup; goto cleanup;
def->clock.offset = vmlocaltime ? def->clock.offset = vmlocaltime ?
VIR_DOMAIN_CLOCK_OFFSET_LOCALTIME : VIR_DOMAIN_CLOCK_OFFSET_LOCALTIME :
VIR_DOMAIN_CLOCK_OFFSET_UTC; VIR_DOMAIN_CLOCK_OFFSET_UTC;
if (xenXMConfigCopyStringOpt(conn, conf, "device_model", &def->emulator) < 0) if (xenXMConfigCopyStringOpt(conf, "device_model", &def->emulator) < 0)
goto cleanup; goto cleanup;
list = virConfGetValue(conf, "disk"); list = virConfGetValue(conf, "disk");
@ -878,7 +871,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
goto no_memory; goto no_memory;
if (virStrncpy(disk->src, head, offset - head, if (virStrncpy(disk->src, head, offset - head,
(offset - head) + 1) == NULL) { (offset - head) + 1) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Source file %s too big for destination"), _("Source file %s too big for destination"),
head); head);
goto cleanup; goto cleanup;
@ -897,7 +890,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
goto no_memory; goto no_memory;
if (virStrncpy(disk->dst, head, offset - head, if (virStrncpy(disk->dst, head, offset - head,
(offset - head) + 1) == NULL) { (offset - head) + 1) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Dest file %s too big for destination"), head); _("Dest file %s too big for destination"), head);
goto cleanup; goto cleanup;
} }
@ -913,7 +906,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
if (virStrncpy(disk->driverName, disk->src, if (virStrncpy(disk->driverName, disk->src,
(tmp - disk->src), (tmp - disk->src),
(tmp - disk->src) + 1) == NULL) { (tmp - disk->src) + 1) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Driver name %s too big for destination"), _("Driver name %s too big for destination"),
disk->src); disk->src);
goto cleanup; goto cleanup;
@ -934,7 +927,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
if (virStrncpy(disk->driverType, disk->src, if (virStrncpy(disk->driverType, disk->src,
(tmp - disk->src), (tmp - disk->src),
(tmp - disk->src) + 1) == NULL) { (tmp - disk->src) + 1) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Driver type %s too big for destination"), _("Driver type %s too big for destination"),
disk->src); disk->src);
goto cleanup; goto cleanup;
@ -992,7 +985,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
} }
if (hvm && priv->xendConfigVersion == 1) { if (hvm && priv->xendConfigVersion == 1) {
if (xenXMConfigGetString(conn, conf, "cdrom", &str, NULL) < 0) if (xenXMConfigGetString(conf, "cdrom", &str, NULL) < 0)
goto cleanup; goto cleanup;
if (str) { if (str) {
if (VIR_ALLOC(disk) < 0) if (VIR_ALLOC(disk) < 0)
@ -1052,7 +1045,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
if (STRPREFIX(key, "mac=")) { if (STRPREFIX(key, "mac=")) {
int len = nextkey ? (nextkey - data) : sizeof(mac) - 1; int len = nextkey ? (nextkey - data) : sizeof(mac) - 1;
if (virStrncpy(mac, data, len, sizeof(mac)) == NULL) { if (virStrncpy(mac, data, len, sizeof(mac)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("MAC address %s too big for destination"), _("MAC address %s too big for destination"),
data); data);
goto skipnic; goto skipnic;
@ -1060,7 +1053,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
} else if (STRPREFIX(key, "bridge=")) { } else if (STRPREFIX(key, "bridge=")) {
int len = nextkey ? (nextkey - data) : sizeof(bridge) - 1; int len = nextkey ? (nextkey - data) : sizeof(bridge) - 1;
if (virStrncpy(bridge, data, len, sizeof(bridge)) == NULL) { if (virStrncpy(bridge, data, len, sizeof(bridge)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Bridge %s too big for destination"), _("Bridge %s too big for destination"),
data); data);
goto skipnic; goto skipnic;
@ -1068,7 +1061,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
} else if (STRPREFIX(key, "script=")) { } else if (STRPREFIX(key, "script=")) {
int len = nextkey ? (nextkey - data) : sizeof(script) - 1; int len = nextkey ? (nextkey - data) : sizeof(script) - 1;
if (virStrncpy(script, data, len, sizeof(script)) == NULL) { if (virStrncpy(script, data, len, sizeof(script)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Script %s too big for destination"), _("Script %s too big for destination"),
data); data);
goto skipnic; goto skipnic;
@ -1076,21 +1069,21 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
} else if (STRPREFIX(key, "model=")) { } else if (STRPREFIX(key, "model=")) {
int len = nextkey ? (nextkey - data) : sizeof(model) - 1; int len = nextkey ? (nextkey - data) : sizeof(model) - 1;
if (virStrncpy(model, data, len, sizeof(model)) == NULL) { if (virStrncpy(model, data, len, sizeof(model)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Model %s too big for destination"), data); _("Model %s too big for destination"), data);
goto skipnic; goto skipnic;
} }
} else if (STRPREFIX(key, "type=")) { } else if (STRPREFIX(key, "type=")) {
int len = nextkey ? (nextkey - data) : sizeof(type) - 1; int len = nextkey ? (nextkey - data) : sizeof(type) - 1;
if (virStrncpy(type, data, len, sizeof(type)) == NULL) { if (virStrncpy(type, data, len, sizeof(type)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Type %s too big for destination"), data); _("Type %s too big for destination"), data);
goto skipnic; goto skipnic;
} }
} else if (STRPREFIX(key, "vifname=")) { } else if (STRPREFIX(key, "vifname=")) {
int len = nextkey ? (nextkey - data) : sizeof(vifname) - 1; int len = nextkey ? (nextkey - data) : sizeof(vifname) - 1;
if (virStrncpy(vifname, data, len, sizeof(vifname)) == NULL) { if (virStrncpy(vifname, data, len, sizeof(vifname)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Vifname %s too big for destination"), _("Vifname %s too big for destination"),
data); data);
goto skipnic; goto skipnic;
@ -1098,7 +1091,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
} else if (STRPREFIX(key, "ip=")) { } else if (STRPREFIX(key, "ip=")) {
int len = nextkey ? (nextkey - data) : sizeof(ip) - 1; int len = nextkey ? (nextkey - data) : sizeof(ip) - 1;
if (virStrncpy(ip, data, len, sizeof(ip)) == NULL) { if (virStrncpy(ip, data, len, sizeof(ip)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("IP %s too big for destination"), data); _("IP %s too big for destination"), data);
goto skipnic; goto skipnic;
} }
@ -1116,7 +1109,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
if (mac[0]) { if (mac[0]) {
if (virParseMacAddr(mac, net->mac) < 0) { if (virParseMacAddr(mac, net->mac) < 0) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("malformed mac address '%s'"), mac); _("malformed mac address '%s'"), mac);
goto cleanup; goto cleanup;
} }
@ -1198,7 +1191,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
goto skippci; goto skippci;
if (virStrncpy(domain, key, (nextkey - key), sizeof(domain)) == NULL) { if (virStrncpy(domain, key, (nextkey - key), sizeof(domain)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Domain %s too big for destination"), key); _("Domain %s too big for destination"), key);
goto skippci; goto skippci;
} }
@ -1208,7 +1201,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
goto skippci; goto skippci;
if (virStrncpy(bus, key, (nextkey - key), sizeof(bus)) == NULL) { if (virStrncpy(bus, key, (nextkey - key), sizeof(bus)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Bus %s too big for destination"), key); _("Bus %s too big for destination"), key);
goto skippci; goto skippci;
} }
@ -1218,7 +1211,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
goto skippci; goto skippci;
if (virStrncpy(slot, key, (nextkey - key), sizeof(slot)) == NULL) { if (virStrncpy(slot, key, (nextkey - key), sizeof(slot)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Slot %s too big for destination"), key); _("Slot %s too big for destination"), key);
goto skippci; goto skippci;
} }
@ -1228,7 +1221,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
goto skippci; goto skippci;
if (virStrncpy(func, key, 1, sizeof(func)) == NULL) { if (virStrncpy(func, key, 1, sizeof(func)) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("Function %s too big for destination"), key); _("Function %s too big for destination"), key);
goto skippci; goto skippci;
} }
@ -1263,7 +1256,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
} }
if (hvm) { if (hvm) {
if (xenXMConfigGetString(conn, conf, "usbdevice", &str, NULL) < 0) if (xenXMConfigGetString(conf, "usbdevice", &str, NULL) < 0)
goto cleanup; goto cleanup;
if (str && if (str &&
(STREQ(str, "tablet") || (STREQ(str, "tablet") ||
@ -1286,28 +1279,28 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
/* HVM guests, or old PV guests use this config format */ /* HVM guests, or old PV guests use this config format */
if (hvm || priv->xendConfigVersion < 3) { if (hvm || priv->xendConfigVersion < 3) {
if (xenXMConfigGetBool(conn, conf, "vnc", &val, 0) < 0) if (xenXMConfigGetBool(conf, "vnc", &val, 0) < 0)
goto cleanup; goto cleanup;
if (val) { if (val) {
if (VIR_ALLOC(graphics) < 0) if (VIR_ALLOC(graphics) < 0)
goto no_memory; goto no_memory;
graphics->type = VIR_DOMAIN_GRAPHICS_TYPE_VNC; graphics->type = VIR_DOMAIN_GRAPHICS_TYPE_VNC;
if (xenXMConfigGetBool(conn, conf, "vncunused", &val, 1) < 0) if (xenXMConfigGetBool(conf, "vncunused", &val, 1) < 0)
goto cleanup; goto cleanup;
graphics->data.vnc.autoport = val ? 1 : 0; graphics->data.vnc.autoport = val ? 1 : 0;
if (!graphics->data.vnc.autoport) { if (!graphics->data.vnc.autoport) {
unsigned long vncdisplay; unsigned long vncdisplay;
if (xenXMConfigGetULong(conn, conf, "vncdisplay", &vncdisplay, 0) < 0) if (xenXMConfigGetULong(conf, "vncdisplay", &vncdisplay, 0) < 0)
goto cleanup; goto cleanup;
graphics->data.vnc.port = (int)vncdisplay + 5900; graphics->data.vnc.port = (int)vncdisplay + 5900;
} }
if (xenXMConfigCopyStringOpt(conn, conf, "vnclisten", &graphics->data.vnc.listenAddr) < 0) if (xenXMConfigCopyStringOpt(conf, "vnclisten", &graphics->data.vnc.listenAddr) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigCopyStringOpt(conn, conf, "vncpasswd", &graphics->data.vnc.passwd) < 0) if (xenXMConfigCopyStringOpt(conf, "vncpasswd", &graphics->data.vnc.passwd) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigCopyStringOpt(conn, conf, "keymap", &graphics->data.vnc.keymap) < 0) if (xenXMConfigCopyStringOpt(conf, "keymap", &graphics->data.vnc.keymap) < 0)
goto cleanup; goto cleanup;
if (VIR_ALLOC_N(def->graphics, 1) < 0) if (VIR_ALLOC_N(def->graphics, 1) < 0)
@ -1316,15 +1309,15 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
def->ngraphics = 1; def->ngraphics = 1;
graphics = NULL; graphics = NULL;
} else { } else {
if (xenXMConfigGetBool(conn, conf, "sdl", &val, 0) < 0) if (xenXMConfigGetBool(conf, "sdl", &val, 0) < 0)
goto cleanup; goto cleanup;
if (val) { if (val) {
if (VIR_ALLOC(graphics) < 0) if (VIR_ALLOC(graphics) < 0)
goto no_memory; goto no_memory;
graphics->type = VIR_DOMAIN_GRAPHICS_TYPE_SDL; graphics->type = VIR_DOMAIN_GRAPHICS_TYPE_SDL;
if (xenXMConfigCopyStringOpt(conn, conf, "display", &graphics->data.sdl.display) < 0) if (xenXMConfigCopyStringOpt(conf, "display", &graphics->data.sdl.display) < 0)
goto cleanup; goto cleanup;
if (xenXMConfigCopyStringOpt(conn, conf, "xauthority", &graphics->data.sdl.xauth) < 0) if (xenXMConfigCopyStringOpt(conf, "xauthority", &graphics->data.sdl.xauth) < 0)
goto cleanup; goto cleanup;
if (VIR_ALLOC_N(def->graphics, 1) < 0) if (VIR_ALLOC_N(def->graphics, 1) < 0)
goto no_memory; goto no_memory;
@ -1344,7 +1337,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
char *key = vfb; char *key = vfb;
if (virStrcpyStatic(vfb, list->list->str) == NULL) { if (virStrcpyStatic(vfb, list->list->str) == NULL) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("VFB %s too big for destination"), _("VFB %s too big for destination"),
list->list->str); list->list->str);
goto cleanup; goto cleanup;
@ -1412,7 +1405,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
if (hvm) { if (hvm) {
virDomainChrDefPtr chr = NULL; virDomainChrDefPtr chr = NULL;
if (xenXMConfigGetString(conn, conf, "parallel", &str, NULL) < 0) if (xenXMConfigGetString(conf, "parallel", &str, NULL) < 0)
goto cleanup; goto cleanup;
if (str && STRNEQ(str, "none") && if (str && STRNEQ(str, "none") &&
!(chr = xenDaemonParseSxprChar(str, NULL))) !(chr = xenDaemonParseSxprChar(str, NULL)))
@ -1429,7 +1422,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
chr = NULL; chr = NULL;
} }
if (xenXMConfigGetString(conn, conf, "serial", &str, NULL) < 0) if (xenXMConfigGetString(conf, "serial", &str, NULL) < 0)
goto cleanup; goto cleanup;
if (str && STRNEQ(str, "none") && if (str && STRNEQ(str, "none") &&
!(chr = xenDaemonParseSxprChar(str, NULL))) !(chr = xenDaemonParseSxprChar(str, NULL)))
@ -1451,7 +1444,7 @@ xenXMDomainConfigParse(virConnectPtr conn, virConfPtr conf) {
} }
if (hvm) { if (hvm) {
if (xenXMConfigGetString(conn, conf, "soundhw", &str, NULL) < 0) if (xenXMConfigGetString(conf, "soundhw", &str, NULL) < 0)
goto cleanup; goto cleanup;
if (str && if (str &&
@ -1484,8 +1477,7 @@ char *xenXMDomainDumpXML(virDomainPtr domain, int flags) {
char *ret = NULL; char *ret = NULL;
if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) { if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) {
xenXMError((domain ? domain->conn : NULL), VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return(NULL); return(NULL);
} }
if (domain->id != -1) if (domain->id != -1)
@ -1518,8 +1510,7 @@ int xenXMDomainSetMemory(virDomainPtr domain, unsigned long memory) {
int ret = -1; int ret = -1;
if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) { if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) {
xenXMError((domain ? domain->conn : NULL), VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return (-1); return (-1);
} }
if (domain->conn->flags & VIR_CONNECT_RO) if (domain->conn->flags & VIR_CONNECT_RO)
@ -1564,8 +1555,7 @@ int xenXMDomainSetMaxMemory(virDomainPtr domain, unsigned long memory) {
int ret = -1; int ret = -1;
if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) { if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) {
xenXMError((domain ? domain->conn : NULL), VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return (-1); return (-1);
} }
if (domain->conn->flags & VIR_CONNECT_RO) if (domain->conn->flags & VIR_CONNECT_RO)
@ -1608,8 +1598,7 @@ unsigned long xenXMDomainGetMaxMemory(virDomainPtr domain) {
unsigned long ret = 0; unsigned long ret = 0;
if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) { if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) {
xenXMError((domain ? domain->conn : NULL), VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return (0); return (0);
} }
if (domain->id != -1) if (domain->id != -1)
@ -1641,8 +1630,7 @@ int xenXMDomainSetVcpus(virDomainPtr domain, unsigned int vcpus) {
int ret = -1; int ret = -1;
if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) { if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) {
xenXMError((domain ? domain->conn : NULL), VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return (-1); return (-1);
} }
if (domain->conn->flags & VIR_CONNECT_RO) if (domain->conn->flags & VIR_CONNECT_RO)
@ -1700,17 +1688,16 @@ int xenXMDomainPinVcpu(virDomainPtr domain,
if (domain == NULL || domain->conn == NULL || domain->name == NULL if (domain == NULL || domain->conn == NULL || domain->name == NULL
|| cpumap == NULL || maplen < 1 || maplen > (int)sizeof(cpumap_t)) { || cpumap == NULL || maplen < 1 || maplen > (int)sizeof(cpumap_t)) {
xenXMError(domain ? domain->conn : NULL, VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return -1; return -1;
} }
if (domain->conn->flags & VIR_CONNECT_RO) { if (domain->conn->flags & VIR_CONNECT_RO) {
xenXMError (domain->conn, VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG,
"%s", _("read only connection")); "%s", _("read only connection"));
return -1; return -1;
} }
if (domain->id != -1) { if (domain->id != -1) {
xenXMError (domain->conn, VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG,
"%s", _("not inactive domain")); "%s", _("not inactive domain"));
return -1; return -1;
} }
@ -1719,11 +1706,11 @@ int xenXMDomainPinVcpu(virDomainPtr domain,
xenUnifiedLock(priv); xenUnifiedLock(priv);
if (!(filename = virHashLookup(priv->nameConfigMap, domain->name))) { if (!(filename = virHashLookup(priv->nameConfigMap, domain->name))) {
xenXMError (domain->conn, VIR_ERR_INTERNAL_ERROR, "%s", _("virHashLookup")); xenXMError(VIR_ERR_INTERNAL_ERROR, "%s", _("virHashLookup"));
goto cleanup; goto cleanup;
} }
if (!(entry = virHashLookup(priv->configCache, filename))) { if (!(entry = virHashLookup(priv->configCache, filename))) {
xenXMError (domain->conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("can't retrieve config file for domain")); "%s", _("can't retrieve config file for domain"));
goto cleanup; goto cleanup;
} }
@ -1785,11 +1772,11 @@ virDomainPtr xenXMDomainLookupByName(virConnectPtr conn, const char *domname) {
virDomainPtr ret = NULL; virDomainPtr ret = NULL;
if (!VIR_IS_CONNECT(conn)) { if (!VIR_IS_CONNECT(conn)) {
xenXMError(conn, VIR_ERR_INVALID_CONN, __FUNCTION__); xenXMError(VIR_ERR_INVALID_CONN, __FUNCTION__);
return (NULL); return (NULL);
} }
if (domname == NULL) { if (domname == NULL) {
xenXMError(conn, VIR_ERR_INVALID_ARG, __FUNCTION__); xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
return (NULL); return (NULL);
} }
@ -1841,11 +1828,11 @@ virDomainPtr xenXMDomainLookupByUUID(virConnectPtr conn,
virDomainPtr ret = NULL; virDomainPtr ret = NULL;
if (!VIR_IS_CONNECT(conn)) { if (!VIR_IS_CONNECT(conn)) {
xenXMError(conn, VIR_ERR_INVALID_CONN, __FUNCTION__); xenXMError(VIR_ERR_INVALID_CONN, __FUNCTION__);
return (NULL); return (NULL);
} }
if (uuid == NULL) { if (uuid == NULL) {
xenXMError(conn, VIR_ERR_INVALID_ARG, __FUNCTION__); xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
return (NULL); return (NULL);
} }
@ -1964,8 +1951,7 @@ int xenXMConfigSetString(virConfPtr conf, const char *setting, const char *str)
} }
static int xenXMDomainConfigFormatDisk(virConnectPtr conn, static int xenXMDomainConfigFormatDisk(virConfValuePtr list,
virConfValuePtr list,
virDomainDiskDefPtr disk, virDomainDiskDefPtr disk,
int hvm, int hvm,
int xendConfigVersion) int xendConfigVersion)
@ -1987,7 +1973,7 @@ static int xenXMDomainConfigFormatDisk(virConnectPtr conn,
virBufferAddLit(&buf, "phy:"); virBufferAddLit(&buf, "phy:");
break; break;
default: default:
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("unsupported disk type %s"), _("unsupported disk type %s"),
virDomainDiskTypeToString(disk->type)); virDomainDiskTypeToString(disk->type));
goto cleanup; goto cleanup;
@ -2071,14 +2057,14 @@ static int xenXMDomainConfigFormatNet(virConnectPtr conn,
virNetworkPtr network = virNetworkLookupByName(conn, net->data.network.name); virNetworkPtr network = virNetworkLookupByName(conn, net->data.network.name);
char *bridge; char *bridge;
if (!network) { if (!network) {
xenXMError(conn, VIR_ERR_NO_NETWORK, "%s", xenXMError(VIR_ERR_NO_NETWORK, "%s",
net->data.network.name); net->data.network.name);
return -1; return -1;
} }
bridge = virNetworkGetBridgeName(network); bridge = virNetworkGetBridgeName(network);
virNetworkFree(network); virNetworkFree(network);
if (!bridge) { if (!bridge) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("network %s is not active"), _("network %s is not active"),
net->data.network.name); net->data.network.name);
return -1; return -1;
@ -2090,7 +2076,7 @@ static int xenXMDomainConfigFormatNet(virConnectPtr conn,
break; break;
default: default:
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("unsupported network type %d"), _("unsupported network type %d"),
net->type); net->type);
goto cleanup; goto cleanup;
@ -2321,7 +2307,7 @@ virConfPtr xenXMDomainConfigFormat(virConnectPtr conn,
if (def->clock.offset == VIR_DOMAIN_CLOCK_OFFSET_LOCALTIME) { if (def->clock.offset == VIR_DOMAIN_CLOCK_OFFSET_LOCALTIME) {
if (def->clock.data.timezone) { if (def->clock.data.timezone) {
xenXMError(conn, VIR_ERR_CONFIG_UNSUPPORTED, xenXMError(VIR_ERR_CONFIG_UNSUPPORTED,
"%s", _("configurable timezones are not supported")); "%s", _("configurable timezones are not supported"));
goto cleanup; goto cleanup;
} }
@ -2333,7 +2319,7 @@ virConfPtr xenXMDomainConfigFormat(virConnectPtr conn,
goto no_memory; goto no_memory;
} else { } else {
/* XXX We could support Xen's rtc clock offset */ /* XXX We could support Xen's rtc clock offset */
xenXMError(conn, VIR_ERR_CONFIG_UNSUPPORTED, xenXMError(VIR_ERR_CONFIG_UNSUPPORTED,
_("unsupported clock offset '%s'"), _("unsupported clock offset '%s'"),
virDomainClockOffsetTypeToString(def->clock.offset)); virDomainClockOffsetTypeToString(def->clock.offset));
goto cleanup; goto cleanup;
@ -2374,7 +2360,7 @@ virConfPtr xenXMDomainConfigFormat(virConnectPtr conn,
} }
if (!(lifecycle = virDomainLifecycleTypeToString(def->onPoweroff))) { if (!(lifecycle = virDomainLifecycleTypeToString(def->onPoweroff))) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("unexpected lifecycle action %d"), def->onPoweroff); _("unexpected lifecycle action %d"), def->onPoweroff);
goto cleanup; goto cleanup;
} }
@ -2383,7 +2369,7 @@ virConfPtr xenXMDomainConfigFormat(virConnectPtr conn,
if (!(lifecycle = virDomainLifecycleTypeToString(def->onReboot))) { if (!(lifecycle = virDomainLifecycleTypeToString(def->onReboot))) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("unexpected lifecycle action %d"), def->onReboot); _("unexpected lifecycle action %d"), def->onReboot);
goto cleanup; goto cleanup;
} }
@ -2392,7 +2378,7 @@ virConfPtr xenXMDomainConfigFormat(virConnectPtr conn,
if (!(lifecycle = virDomainLifecycleTypeToString(def->onCrash))) { if (!(lifecycle = virDomainLifecycleTypeToString(def->onCrash))) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
_("unexpected lifecycle action %d"), def->onCrash); _("unexpected lifecycle action %d"), def->onCrash);
goto cleanup; goto cleanup;
} }
@ -2532,7 +2518,7 @@ virConfPtr xenXMDomainConfigFormat(virConnectPtr conn,
if (def->disks[i]->device == VIR_DOMAIN_DISK_DEVICE_FLOPPY) if (def->disks[i]->device == VIR_DOMAIN_DISK_DEVICE_FLOPPY)
continue; continue;
if (xenXMDomainConfigFormatDisk(conn, diskVal, def->disks[i], if (xenXMDomainConfigFormatDisk(diskVal, def->disks[i],
hvm, priv->xendConfigVersion) < 0) hvm, priv->xendConfigVersion) < 0)
goto cleanup; goto cleanup;
} }
@ -2644,11 +2630,11 @@ virDomainPtr xenXMDomainDefineXML(virConnectPtr conn, const char *xml) {
xenUnifiedPrivatePtr priv = (xenUnifiedPrivatePtr) conn->privateData; xenUnifiedPrivatePtr priv = (xenUnifiedPrivatePtr) conn->privateData;
if (!VIR_IS_CONNECT(conn)) { if (!VIR_IS_CONNECT(conn)) {
xenXMError(conn, VIR_ERR_INVALID_CONN, __FUNCTION__); xenXMError(VIR_ERR_INVALID_CONN, __FUNCTION__);
return (NULL); return (NULL);
} }
if (xml == NULL) { if (xml == NULL) {
xenXMError(conn, VIR_ERR_INVALID_ARG, __FUNCTION__); xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
return (NULL); return (NULL);
} }
if (conn->flags & VIR_CONNECT_RO) if (conn->flags & VIR_CONNECT_RO)
@ -2678,7 +2664,7 @@ virDomainPtr xenXMDomainDefineXML(virConnectPtr conn, const char *xml) {
char uuidstr[VIR_UUID_STRING_BUFLEN]; char uuidstr[VIR_UUID_STRING_BUFLEN];
virUUIDFormat(entry->def->uuid, uuidstr); virUUIDFormat(entry->def->uuid, uuidstr);
xenXMError(conn, VIR_ERR_OPERATION_FAILED, xenXMError(VIR_ERR_OPERATION_FAILED,
_("domain '%s' is already defined with uuid %s"), _("domain '%s' is already defined with uuid %s"),
entry->def->name, uuidstr); entry->def->name, uuidstr);
entry = NULL; entry = NULL;
@ -2691,13 +2677,13 @@ virDomainPtr xenXMDomainDefineXML(virConnectPtr conn, const char *xml) {
/* domain exists, we will overwrite it */ /* domain exists, we will overwrite it */
if (!(oldfilename = (char *)virHashLookup(priv->nameConfigMap, def->name))) { if (!(oldfilename = (char *)virHashLookup(priv->nameConfigMap, def->name))) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("can't retrieve config filename for domain to overwrite")); "%s", _("can't retrieve config filename for domain to overwrite"));
goto error; goto error;
} }
if (!(entry = virHashLookup(priv->configCache, oldfilename))) { if (!(entry = virHashLookup(priv->configCache, oldfilename))) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("can't retrieve config entry for domain to overwrite")); "%s", _("can't retrieve config entry for domain to overwrite"));
goto error; goto error;
} }
@ -2708,14 +2694,14 @@ virDomainPtr xenXMDomainDefineXML(virConnectPtr conn, const char *xml) {
/* Remove the name -> filename mapping */ /* Remove the name -> filename mapping */
if (virHashRemoveEntry(priv->nameConfigMap, def->name, NULL) < 0) { if (virHashRemoveEntry(priv->nameConfigMap, def->name, NULL) < 0) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("failed to remove old domain from config map")); "%s", _("failed to remove old domain from config map"));
goto error; goto error;
} }
/* Remove the config record itself */ /* Remove the config record itself */
if (virHashRemoveEntry(priv->configCache, oldfilename, xenXMConfigFree) < 0) { if (virHashRemoveEntry(priv->configCache, oldfilename, xenXMConfigFree) < 0) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("failed to remove old domain from config map")); "%s", _("failed to remove old domain from config map"));
goto error; goto error;
} }
@ -2724,7 +2710,7 @@ virDomainPtr xenXMDomainDefineXML(virConnectPtr conn, const char *xml) {
} }
if ((strlen(priv->configDir) + 1 + strlen(def->name) + 1) > PATH_MAX) { if ((strlen(priv->configDir) + 1 + strlen(def->name) + 1) > PATH_MAX) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("config file name is too long")); "%s", _("config file name is too long"));
goto error; goto error;
} }
@ -2742,7 +2728,7 @@ virDomainPtr xenXMDomainDefineXML(virConnectPtr conn, const char *xml) {
} }
if ((entry->refreshedAt = time(NULL)) == ((time_t)-1)) { if ((entry->refreshedAt = time(NULL)) == ((time_t)-1)) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("unable to get current time")); "%s", _("unable to get current time"));
goto error; goto error;
} }
@ -2751,14 +2737,14 @@ virDomainPtr xenXMDomainDefineXML(virConnectPtr conn, const char *xml) {
entry->def = def; entry->def = def;
if (virHashAddEntry(priv->configCache, filename, entry) < 0) { if (virHashAddEntry(priv->configCache, filename, entry) < 0) {
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("unable to store config file handle")); "%s", _("unable to store config file handle"));
goto error; goto error;
} }
if (virHashAddEntry(priv->nameConfigMap, def->name, entry->filename) < 0) { if (virHashAddEntry(priv->nameConfigMap, def->name, entry->filename) < 0) {
virHashRemoveEntry(priv->configCache, filename, NULL); virHashRemoveEntry(priv->configCache, filename, NULL);
xenXMError(conn, VIR_ERR_INTERNAL_ERROR, xenXMError(VIR_ERR_INTERNAL_ERROR,
"%s", _("unable to store config file handle")); "%s", _("unable to store config file handle"));
goto error; goto error;
} }
@ -2784,8 +2770,7 @@ int xenXMDomainUndefine(virDomainPtr domain) {
int ret = -1; int ret = -1;
if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) { if ((domain == NULL) || (domain->conn == NULL) || (domain->name == NULL)) {
xenXMError((domain ? domain->conn : NULL), VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return (-1); return (-1);
} }
@ -2861,7 +2846,7 @@ int xenXMListDefinedDomains(virConnectPtr conn, char **const names, int maxnames
int i, ret = -1; int i, ret = -1;
if (!VIR_IS_CONNECT(conn)) { if (!VIR_IS_CONNECT(conn)) {
xenXMError(conn, VIR_ERR_INVALID_CONN, __FUNCTION__); xenXMError(VIR_ERR_INVALID_CONN, __FUNCTION__);
return (-1); return (-1);
} }
@ -2906,7 +2891,7 @@ int xenXMNumOfDefinedDomains(virConnectPtr conn) {
int ret = -1; int ret = -1;
if (!VIR_IS_CONNECT(conn)) { if (!VIR_IS_CONNECT(conn)) {
xenXMError(conn, VIR_ERR_INVALID_CONN, __FUNCTION__); xenXMError(VIR_ERR_INVALID_CONN, __FUNCTION__);
return (-1); return (-1);
} }
@ -2948,8 +2933,7 @@ xenXMDomainAttachDeviceFlags(virDomainPtr domain, const char *xml,
xenUnifiedPrivatePtr priv; xenUnifiedPrivatePtr priv;
if ((!domain) || (!domain->conn) || (!domain->name) || (!xml)) { if ((!domain) || (!domain->conn) || (!domain->name) || (!xml)) {
xenXMError((domain ? domain->conn : NULL), VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return -1; return -1;
} }
@ -2995,7 +2979,7 @@ xenXMDomainAttachDeviceFlags(virDomainPtr domain, const char *xml,
} }
default: default:
xenXMError(domain->conn, VIR_ERR_XML_ERROR, xenXMError(VIR_ERR_XML_ERROR,
"%s", _("unknown device")); "%s", _("unknown device"));
goto cleanup; goto cleanup;
} }
@ -3039,8 +3023,7 @@ xenXMDomainDetachDeviceFlags(virDomainPtr domain, const char *xml,
xenUnifiedPrivatePtr priv; xenUnifiedPrivatePtr priv;
if ((!domain) || (!domain->conn) || (!domain->name) || (!xml)) { if ((!domain) || (!domain->conn) || (!domain->name) || (!xml)) {
xenXMError((domain ? domain->conn : NULL), VIR_ERR_INVALID_ARG, xenXMError(VIR_ERR_INVALID_ARG, __FUNCTION__);
__FUNCTION__);
return -1; return -1;
} }
@ -3101,7 +3084,7 @@ xenXMDomainDetachDeviceFlags(virDomainPtr domain, const char *xml,
break; break;
} }
default: default:
xenXMError(domain->conn, VIR_ERR_XML_ERROR, xenXMError(VIR_ERR_XML_ERROR,
"%s", _("unknown device")); "%s", _("unknown device"));
goto cleanup; goto cleanup;
} }
@ -3121,13 +3104,13 @@ xenXMDomainDetachDeviceFlags(virDomainPtr domain, const char *xml,
} }
int int
xenXMDomainBlockPeek (virDomainPtr dom, xenXMDomainBlockPeek (virDomainPtr dom ATTRIBUTE_UNUSED,
const char *path ATTRIBUTE_UNUSED, const char *path ATTRIBUTE_UNUSED,
unsigned long long offset ATTRIBUTE_UNUSED, unsigned long long offset ATTRIBUTE_UNUSED,
size_t size ATTRIBUTE_UNUSED, size_t size ATTRIBUTE_UNUSED,
void *buffer ATTRIBUTE_UNUSED) void *buffer ATTRIBUTE_UNUSED)
{ {
xenXMError (dom->conn, VIR_ERR_NO_SUPPORT, __FUNCTION__); xenXMError(VIR_ERR_NO_SUPPORT, __FUNCTION__);
return -1; return -1;
} }