mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-24 05:25:18 +00:00
node_device_udev: Split udevRemoveOneDevice() into two
Move internals of udevRemoveOneDevice() into a separate function which accepts sysfs path as an argument and actually removes the device from the internal list. It will be reused later. Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
This commit is contained in:
parent
4c1033a151
commit
bfa8cf4b29
@ -1222,17 +1222,15 @@ udevGetDeviceDetails(struct udev_device *device,
|
||||
|
||||
|
||||
static int
|
||||
udevRemoveOneDevice(struct udev_device *device)
|
||||
udevRemoveOneDeviceSysPath(const char *path)
|
||||
{
|
||||
virNodeDeviceObjPtr obj = NULL;
|
||||
virNodeDeviceDefPtr def;
|
||||
virObjectEventPtr event = NULL;
|
||||
const char *name = NULL;
|
||||
|
||||
name = udev_device_get_syspath(device);
|
||||
if (!(obj = virNodeDeviceObjListFindBySysfsPath(driver->devs, name))) {
|
||||
VIR_DEBUG("Failed to find device to remove that has udev name '%s'",
|
||||
name);
|
||||
if (!(obj = virNodeDeviceObjListFindBySysfsPath(driver->devs, path))) {
|
||||
VIR_DEBUG("Failed to find device to remove that has udev path '%s'",
|
||||
path);
|
||||
return -1;
|
||||
}
|
||||
def = virNodeDeviceObjGetDef(obj);
|
||||
@ -1242,7 +1240,7 @@ udevRemoveOneDevice(struct udev_device *device)
|
||||
0);
|
||||
|
||||
VIR_DEBUG("Removing device '%s' with sysfs path '%s'",
|
||||
def->name, name);
|
||||
def->name, path);
|
||||
virNodeDeviceObjListRemove(driver->devs, obj);
|
||||
virNodeDeviceObjEndAPI(&obj);
|
||||
|
||||
@ -1251,6 +1249,15 @@ udevRemoveOneDevice(struct udev_device *device)
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
udevRemoveOneDevice(struct udev_device *device)
|
||||
{
|
||||
const char *path = udev_device_get_syspath(device);
|
||||
|
||||
return udevRemoveOneDeviceSysPath(path);
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
udevSetParent(struct udev_device *device,
|
||||
virNodeDeviceDefPtr def)
|
||||
|
Loading…
x
Reference in New Issue
Block a user