static struct openvz_vm_def *openvzParseXML(virConnectPtr conn, xmlDocPtr xml);
static int openvzGetVPSUUID(int vpsid, char *uuidstr);
static int openvzSetUUID(int vpsid);
-static struct openvz_vm *openvzLoadConfig(struct openvz_driver *driver,
- const char *path,
- const char *xmlStr);
/* For errors internal to this library. */
static void
}
int
-strtoI(char *str)
+strtoI(const char *str)
{
int base = 10;
char *endptr;
}
/* rejecting VPS ID <= OPENVZ_RSRV_VM_LIMIT for they are reserved */
- if (strtoI(BAD_CAST obj->stringval) <= OPENVZ_RSRV_VM_LIMIT) {
+ if (strtoI((const char *) obj->stringval) <= OPENVZ_RSRV_VM_LIMIT) {
error(conn, VIR_ERR_INTERNAL_ERROR,
"VPS ID Error (must be an integer greater than 100");
goto bail_out;
*pnext = calloc(1, sizeof(struct openvz_vm));
if(!*pnext) {
error(conn, VIR_ERR_INTERNAL_ERROR, "calloc failed");
- return NULL;
+ goto error;
}
if(!vm)
vm = *pnext;
- fscanf(fp, "%d %s\n", &veid, status);
+ if (fscanf(fp, "%d %s\n", &veid, status) != 2) {
+ error(conn, VIR_ERR_INTERNAL_ERROR,
+ "Failed to parse vzlist output");
+ free(*pnext);
+ goto error;
+ }
if(strcmp(status, "stopped")) {
(*pnext)->status = VIR_DOMAIN_RUNNING;
driver->num_active ++;
else {
(*pnext)->status = VIR_DOMAIN_SHUTOFF;
driver->num_inactive ++;
- (*pnext)->vpsid = -1; /* inactive domains don't have their ID set in libvirt,
- thought this doesn't make sense for OpenVZ */
+ /*
+ * inactive domains don't have their ID set in libvirt,
+ * thought this doesn't make sense for OpenVZ
+ */
+ (*pnext)->vpsid = -1;
}
vmdef = calloc(1, sizeof(struct openvz_vm_def));
if(!vmdef) {
error(conn, VIR_ERR_INTERNAL_ERROR, "calloc failed");
- return NULL;
+ free(*pnext);
+ goto error;
}
snprintf(vmdef->name, OPENVZ_NAME_MAX, "%i", veid);
ret = virUUIDParse(uuidstr, vmdef->uuid);
if(ret == -1) {
- error(conn, VIR_ERR_INTERNAL_ERROR, "UUID in config file malformed");
- return NULL;
+ error(conn, VIR_ERR_INTERNAL_ERROR,
+ "UUID in config file malformed");
+ free(*pnext);
+ free(vmdef);
+ goto error;
}
(*pnext)->vmdef = vmdef;
pnext = &(*pnext)->next;
}
return vm;
+error:
+ while (vm != NULL) {
+ struct openvz_vm *next;
+
+ next = vm->next;
+ free(vm->vmdef);
+ free(vm);
+ vm = next;
+ }
+ return NULL;
}
static char
while(conf_dir_list[i]) {
if(!access(conf_dir_list[i], F_OK))
- return strdup(conf_dir_list[i]);
+ return strdup(conf_dir_list[i]);
i ++;
}
char uuidstr[VIR_UUID_STRING_BUFLEN];
unsigned char uuid[VIR_UUID_BUFLEN];
char *conf_dir;
- int fd, ret, i;
+ int fd, ret;
conf_dir = openvzLocateConfDir();
sprintf(conf_file, "%s/%d.conf", conf_dir, vpsid);
return dom;
}
-static char *openvzGetOSType(virDomainPtr dom)
+static char *openvzGetOSType(virDomainPtr dom ATTRIBUTE_UNUSED)
{
/* OpenVZ runs on Linux and runs only Linux */
return strdup("linux");
return ret;
}
-static int openvzDomainReboot(virDomainPtr dom, unsigned int flags) {
+static int openvzDomainReboot(virDomainPtr dom,
+ unsigned int flags ATTRIBUTE_UNUSED) {
char cmdbuf[CMDBUF_LEN];
int ret;
char *cmdExec[OPENVZ_MAX_ARG];
return got;
}
-static int openvzNumDomains(virConnectPtr conn) {
+static int openvzNumDomains(virConnectPtr conn ATTRIBUTE_UNUSED) {
return ovz_driver.num_active;
}
return got;
}
-static int openvzNumDefinedDomains(virConnectPtr conn) {
+static int openvzNumDefinedDomains(virConnectPtr conn ATTRIBUTE_UNUSED) {
return ovz_driver.num_inactive;
}
return 1;
}
-static int openvzCloseNetwork(virConnectPtr conn) {
+static int openvzCloseNetwork(virConnectPtr conn ATTRIBUTE_UNUSED) {
return 0;
}
-static virDrvOpenStatus openvzOpenNetwork(virConnectPtr conn,
+static virDrvOpenStatus openvzOpenNetwork(virConnectPtr conn ATTRIBUTE_UNUSED,
const char *name ATTRIBUTE_UNUSED,
int flags ATTRIBUTE_UNUSED) {
return VIR_DRV_OPEN_SUCCESS;
NULL, /* domainGetSchedulerType */
NULL, /* domainGetSchedulerParameters */
NULL, /* domainSetSchedulerParameters */
+ NULL, /* domainMigratePrepare */
+ NULL, /* domainMigratePerform */
+ NULL, /* domainMigrateFinish */
+ NULL, /* domainBlockStats */
+ NULL, /* domainInterfaceStats */
};
static virNetworkDriver openvzNetworkDriver = {