mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-25 14:05:18 +00:00
Re-arrange code setting up ifs/disk loop devices for LXC
The current code for setting up loop devices to LXC disks first does a switch() based on the disk format, then looks at the disk driver name. Reverse this so it first looks at the driver name, and then the disk format. This is more useful since the list of supported disk formats depends on what driver is used. The code for setting loop devices for LXC fs entries also needs to have the same logic added, now the XML schema supports this. Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
This commit is contained in:
parent
ada14b86cc
commit
c8fa7e8c55
@ -401,17 +401,31 @@ static int virLXCControllerSetupLoopDevices(virLXCControllerPtr ctrl)
|
|||||||
if (fs->type != VIR_DOMAIN_FS_TYPE_FILE)
|
if (fs->type != VIR_DOMAIN_FS_TYPE_FILE)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
fd = virLXCControllerSetupLoopDeviceFS(fs);
|
if (fs->fsdriver == VIR_DOMAIN_FS_DRIVER_TYPE_LOOP) {
|
||||||
if (fd < 0)
|
if (fs->format != VIR_STORAGE_FILE_RAW &&
|
||||||
goto cleanup;
|
fs->format != VIR_STORAGE_FILE_NONE) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
_("fs format %s is not supported"),
|
||||||
|
virStorageFileFormatTypeToString(fs->format));
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
VIR_DEBUG("Saving loop fd %d", fd);
|
fd = virLXCControllerSetupLoopDeviceFS(fs);
|
||||||
if (VIR_EXPAND_N(ctrl->loopDevFds, ctrl->nloopDevs, 1) < 0) {
|
if (fd < 0)
|
||||||
VIR_FORCE_CLOSE(fd);
|
goto cleanup;
|
||||||
virReportOOMError();
|
|
||||||
goto cleanup;
|
VIR_DEBUG("Saving loop fd %d", fd);
|
||||||
|
if (VIR_EXPAND_N(ctrl->loopDevFds, ctrl->nloopDevs, 1) < 0) {
|
||||||
|
VIR_FORCE_CLOSE(fd);
|
||||||
|
virReportOOMError();
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
ctrl->loopDevFds[ctrl->nloopDevs - 1] = fd;
|
||||||
|
} else {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
_("fs driver %s is not supported"),
|
||||||
|
virDomainFSDriverTypeTypeToString(fs->fsdriver));
|
||||||
}
|
}
|
||||||
ctrl->loopDevFds[ctrl->nloopDevs - 1] = fd;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0 ; i < ctrl->def->ndisks ; i++) {
|
for (i = 0 ; i < ctrl->def->ndisks ; i++) {
|
||||||
@ -421,40 +435,36 @@ static int virLXCControllerSetupLoopDevices(virLXCControllerPtr ctrl)
|
|||||||
if (disk->type != VIR_DOMAIN_DISK_TYPE_FILE)
|
if (disk->type != VIR_DOMAIN_DISK_TYPE_FILE)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
switch (disk->format) {
|
if (!disk->driverName ||
|
||||||
|
STREQ(disk->driverName, "loop")) {
|
||||||
|
if (disk->format != VIR_STORAGE_FILE_RAW &&
|
||||||
|
disk->format != VIR_STORAGE_FILE_NONE) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
_("disk format %s is not supported"),
|
||||||
|
virStorageFileFormatTypeToString(disk->format));
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
/* We treat 'none' as meaning 'raw' since we
|
/* We treat 'none' as meaning 'raw' since we
|
||||||
* don't want to go into the auto-probing
|
* don't want to go into the auto-probing
|
||||||
* business for security reasons
|
* business for security reasons
|
||||||
*/
|
*/
|
||||||
case VIR_STORAGE_FILE_RAW:
|
|
||||||
case VIR_STORAGE_FILE_NONE:
|
|
||||||
if (disk->driverName &&
|
|
||||||
STRNEQ(disk->driverName, "loop")) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
|
||||||
_("disk driver %s is not supported"),
|
|
||||||
disk->driverName);
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
|
|
||||||
fd = virLXCControllerSetupLoopDeviceDisk(disk);
|
fd = virLXCControllerSetupLoopDeviceDisk(disk);
|
||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
VIR_DEBUG("Saving loop fd %d", fd);
|
||||||
|
if (VIR_EXPAND_N(ctrl->loopDevFds, ctrl->nloopDevs, 1) < 0) {
|
||||||
|
VIR_FORCE_CLOSE(fd);
|
||||||
|
virReportOOMError();
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
ctrl->loopDevFds[ctrl->nloopDevs - 1] = fd;
|
||||||
|
} else {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
_("disk format %s is not supported"),
|
_("disk driver %s is not supported"),
|
||||||
virStorageFileFormatTypeToString(disk->format));
|
disk->driverName);
|
||||||
goto cleanup;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
VIR_DEBUG("Saving loop fd %d", fd);
|
|
||||||
if (VIR_EXPAND_N(ctrl->loopDevFds, ctrl->nloopDevs, 1) < 0) {
|
|
||||||
VIR_FORCE_CLOSE(fd);
|
|
||||||
virReportOOMError();
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
ctrl->loopDevFds[ctrl->nloopDevs - 1] = fd;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
VIR_DEBUG("Setup all loop devices");
|
VIR_DEBUG("Setup all loop devices");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user