mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 23:37:42 +00:00
Only return two values in udevGetStringProperty
There is no need to differentiate between PROPERTY_FOUND and PROPERTY_MISSING - we can just look if the string is non-NULL.
This commit is contained in:
parent
3484c05ce0
commit
71402ef6f5
@ -89,9 +89,9 @@ static int udevGetStringProperty(struct udev_device *udev_device,
|
|||||||
{
|
{
|
||||||
if (VIR_STRDUP(*value,
|
if (VIR_STRDUP(*value,
|
||||||
udevGetDeviceProperty(udev_device, property_key)) < 0)
|
udevGetDeviceProperty(udev_device, property_key)) < 0)
|
||||||
return PROPERTY_ERROR;
|
return -1;
|
||||||
|
|
||||||
return *value == NULL ? PROPERTY_MISSING : PROPERTY_FOUND;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -473,7 +473,6 @@ static int udevProcessUSBDevice(struct udev_device *device,
|
|||||||
{
|
{
|
||||||
virNodeDevCapDataPtr data = &def->caps->data;
|
virNodeDevCapDataPtr data = &def->caps->data;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
int err;
|
|
||||||
|
|
||||||
if (udevGetUintProperty(device,
|
if (udevGetUintProperty(device,
|
||||||
"BUSNUM",
|
"BUSNUM",
|
||||||
@ -496,18 +495,16 @@ static int udevProcessUSBDevice(struct udev_device *device,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = udevGetStringProperty(device,
|
if (udevGetStringProperty(device,
|
||||||
"ID_VENDOR_FROM_DATABASE",
|
"ID_VENDOR_FROM_DATABASE",
|
||||||
&data->usb_dev.vendor_name);
|
&data->usb_dev.vendor_name) < 0)
|
||||||
if (err == PROPERTY_ERROR)
|
goto out;
|
||||||
|
|
||||||
|
if (!data->usb_dev.vendor_name &&
|
||||||
|
udevGetStringSysfsAttr(device,
|
||||||
|
"manufacturer",
|
||||||
|
&data->usb_dev.vendor_name) == PROPERTY_ERROR)
|
||||||
goto out;
|
goto out;
|
||||||
if (err == PROPERTY_MISSING) {
|
|
||||||
if (udevGetStringSysfsAttr(device,
|
|
||||||
"manufacturer",
|
|
||||||
&data->usb_dev.vendor_name) == PROPERTY_ERROR) {
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (udevGetUintProperty(device,
|
if (udevGetUintProperty(device,
|
||||||
"ID_MODEL_ID",
|
"ID_MODEL_ID",
|
||||||
@ -516,18 +513,16 @@ static int udevProcessUSBDevice(struct udev_device *device,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = udevGetStringProperty(device,
|
if (udevGetStringProperty(device,
|
||||||
"ID_MODEL_FROM_DATABASE",
|
"ID_MODEL_FROM_DATABASE",
|
||||||
&data->usb_dev.product_name);
|
&data->usb_dev.product_name) < 0)
|
||||||
if (err == PROPERTY_ERROR)
|
goto out;
|
||||||
|
|
||||||
|
if (!data->usb_dev.product_name &&
|
||||||
|
udevGetStringSysfsAttr(device,
|
||||||
|
"product",
|
||||||
|
&data->usb_dev.product_name) == PROPERTY_ERROR)
|
||||||
goto out;
|
goto out;
|
||||||
if (err == PROPERTY_MISSING) {
|
|
||||||
if (udevGetStringSysfsAttr(device,
|
|
||||||
"product",
|
|
||||||
&data->usb_dev.product_name) == PROPERTY_ERROR) {
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (udevGenerateDeviceName(device, def, NULL) != 0)
|
if (udevGenerateDeviceName(device, def, NULL) != 0)
|
||||||
goto out;
|
goto out;
|
||||||
@ -598,9 +593,8 @@ static int udevProcessNetworkInterface(struct udev_device *device,
|
|||||||
|
|
||||||
if (udevGetStringProperty(device,
|
if (udevGetStringProperty(device,
|
||||||
"INTERFACE",
|
"INTERFACE",
|
||||||
&data->net.ifname) == PROPERTY_ERROR) {
|
&data->net.ifname) < 0)
|
||||||
goto out;
|
goto out;
|
||||||
}
|
|
||||||
|
|
||||||
if (udevGetStringSysfsAttr(device,
|
if (udevGetStringSysfsAttr(device,
|
||||||
"address",
|
"address",
|
||||||
@ -833,9 +827,8 @@ static int udevProcessRemoveableMedia(struct udev_device *device,
|
|||||||
VIR_NODE_DEV_CAP_STORAGE_REMOVABLE_MEDIA_AVAILABLE;
|
VIR_NODE_DEV_CAP_STORAGE_REMOVABLE_MEDIA_AVAILABLE;
|
||||||
|
|
||||||
if (udevGetStringProperty(device, "ID_FS_LABEL",
|
if (udevGetStringProperty(device, "ID_FS_LABEL",
|
||||||
&data->storage.media_label) == PROPERTY_ERROR) {
|
&data->storage.media_label) < 0)
|
||||||
goto out;
|
goto out;
|
||||||
}
|
|
||||||
|
|
||||||
if (udevGetUint64SysfsAttr(device,
|
if (udevGetUint64SysfsAttr(device,
|
||||||
"size",
|
"size",
|
||||||
@ -988,16 +981,11 @@ static int udevProcessStorage(struct udev_device *device,
|
|||||||
if (VIR_STRDUP(data->storage.block, devnode) < 0)
|
if (VIR_STRDUP(data->storage.block, devnode) < 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (udevGetStringProperty(device,
|
if (udevGetStringProperty(device, "ID_BUS", &data->storage.bus) < 0)
|
||||||
"ID_BUS",
|
|
||||||
&data->storage.bus) == PROPERTY_ERROR) {
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
if (udevGetStringProperty(device, "ID_SERIAL", &data->storage.serial) < 0)
|
||||||
if (udevGetStringProperty(device,
|
|
||||||
"ID_SERIAL",
|
|
||||||
&data->storage.serial) == PROPERTY_ERROR) {
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
|
||||||
if (udevGetStringSysfsAttr(device,
|
if (udevGetStringSysfsAttr(device,
|
||||||
"device/vendor",
|
"device/vendor",
|
||||||
&data->storage.vendor) == PROPERTY_ERROR) {
|
&data->storage.vendor) == PROPERTY_ERROR) {
|
||||||
@ -1015,9 +1003,10 @@ static int udevProcessStorage(struct udev_device *device,
|
|||||||
* expected, so I don't see a problem with not having a property
|
* expected, so I don't see a problem with not having a property
|
||||||
* for it. */
|
* for it. */
|
||||||
|
|
||||||
if (udevGetStringProperty(device,
|
if (udevGetStringProperty(device, "ID_TYPE", &data->storage.drive_type) < 0)
|
||||||
"ID_TYPE",
|
goto out;
|
||||||
&data->storage.drive_type) != PROPERTY_FOUND ||
|
|
||||||
|
if (!data->storage.drive_type ||
|
||||||
STREQ(def->caps->data.storage.drive_type, "generic")) {
|
STREQ(def->caps->data.storage.drive_type, "generic")) {
|
||||||
int val = 0;
|
int val = 0;
|
||||||
const char *str = NULL;
|
const char *str = NULL;
|
||||||
@ -1079,9 +1068,8 @@ static int
|
|||||||
udevProcessSCSIGeneric(struct udev_device *dev,
|
udevProcessSCSIGeneric(struct udev_device *dev,
|
||||||
virNodeDeviceDefPtr def)
|
virNodeDeviceDefPtr def)
|
||||||
{
|
{
|
||||||
if (udevGetStringProperty(dev,
|
if (udevGetStringProperty(dev, "DEVNAME", &def->caps->data.sg.path) < 0 ||
|
||||||
"DEVNAME",
|
!def->caps->data.sg.path)
|
||||||
&def->caps->data.sg.path) != PROPERTY_FOUND)
|
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (udevGenerateDeviceName(dev, def, NULL) != 0)
|
if (udevGenerateDeviceName(dev, def, NULL) != 0)
|
||||||
@ -1129,9 +1117,10 @@ udevGetDeviceType(struct udev_device *device,
|
|||||||
*type = VIR_NODE_DEV_CAP_NET;
|
*type = VIR_NODE_DEV_CAP_NET;
|
||||||
|
|
||||||
/* SCSI generic device doesn't set DEVTYPE property */
|
/* SCSI generic device doesn't set DEVTYPE property */
|
||||||
if (udevGetStringProperty(device, "SUBSYSTEM", &subsystem) ==
|
if (udevGetStringProperty(device, "SUBSYSTEM", &subsystem) < 0)
|
||||||
PROPERTY_FOUND &&
|
return -1;
|
||||||
STREQ(subsystem, "scsi_generic"))
|
|
||||||
|
if (STREQ_NULLABLE(subsystem, "scsi_generic"))
|
||||||
*type = VIR_NODE_DEV_CAP_SCSI_GENERIC;
|
*type = VIR_NODE_DEV_CAP_SCSI_GENERIC;
|
||||||
VIR_FREE(subsystem);
|
VIR_FREE(subsystem);
|
||||||
}
|
}
|
||||||
@ -1276,11 +1265,8 @@ static int udevAddOneDevice(struct udev_device *device)
|
|||||||
if (VIR_STRDUP(def->sysfs_path, udev_device_get_syspath(device)) < 0)
|
if (VIR_STRDUP(def->sysfs_path, udev_device_get_syspath(device)) < 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (udevGetStringProperty(device,
|
if (udevGetStringProperty(device, "DRIVER", &def->driver) < 0)
|
||||||
"DRIVER",
|
|
||||||
&def->driver) == PROPERTY_ERROR) {
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
|
||||||
|
|
||||||
if (VIR_ALLOC(def->caps) != 0)
|
if (VIR_ALLOC(def->caps) != 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user