mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-10 23:07:44 +00:00
qemuDomainAttachDeviceMknod: Don't loop endlessly
When working with symlinks it is fairly easy to get into a loop. Don't. Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
3f5fcacf89
commit
7f0b382522
@ -7735,16 +7735,24 @@ qemuDomainAttachDeviceMknodHelper(pid_t pid ATTRIBUTE_UNUSED,
|
||||
|
||||
|
||||
static int
|
||||
qemuDomainAttachDeviceMknod(virQEMUDriverPtr driver,
|
||||
qemuDomainAttachDeviceMknodRecursive(virQEMUDriverPtr driver,
|
||||
virDomainObjPtr vm,
|
||||
virDomainDeviceDefPtr devDef,
|
||||
const char *file)
|
||||
const char *file,
|
||||
unsigned int ttl)
|
||||
{
|
||||
struct qemuDomainAttachDeviceMknodData data;
|
||||
int ret = -1;
|
||||
char *target = NULL;
|
||||
bool isLink;
|
||||
|
||||
if (!ttl) {
|
||||
virReportSystemError(ELOOP,
|
||||
_("Too many levels of symbolic links: %s"),
|
||||
file);
|
||||
return ret;
|
||||
}
|
||||
|
||||
memset(&data, 0, sizeof(data));
|
||||
|
||||
data.driver = driver;
|
||||
@ -7822,7 +7830,8 @@ qemuDomainAttachDeviceMknod(virQEMUDriverPtr driver,
|
||||
}
|
||||
|
||||
if (isLink &&
|
||||
qemuDomainAttachDeviceMknod(driver, vm, devDef, target) < 0)
|
||||
qemuDomainAttachDeviceMknodRecursive(driver, vm, devDef,
|
||||
target, ttl -1) < 0)
|
||||
goto cleanup;
|
||||
|
||||
ret = 0;
|
||||
@ -7836,6 +7845,19 @@ qemuDomainAttachDeviceMknod(virQEMUDriverPtr driver,
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
qemuDomainAttachDeviceMknod(virQEMUDriverPtr driver,
|
||||
virDomainObjPtr vm,
|
||||
virDomainDeviceDefPtr devDef,
|
||||
const char *file)
|
||||
{
|
||||
long symloop_max = sysconf(_SC_SYMLOOP_MAX);
|
||||
|
||||
return qemuDomainAttachDeviceMknodRecursive(driver, vm, devDef,
|
||||
file, symloop_max);
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
qemuDomainDetachDeviceUnlinkHelper(pid_t pid ATTRIBUTE_UNUSED,
|
||||
void *opaque)
|
||||
|
Loading…
Reference in New Issue
Block a user