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:
Ján Tomko 2016-06-03 15:54:19 +02:00
parent 3484c05ce0
commit 71402ef6f5

View File

@ -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;