mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-27 14:03:43 +03:00
sd-device-enumerator: introduce device_enumerator_scan_devices_and_subsystems()
This commit is contained in:
parent
37cf83d9bf
commit
3c5cc23a93
@ -5,6 +5,7 @@
|
|||||||
|
|
||||||
int device_enumerator_scan_devices(sd_device_enumerator *enumeartor);
|
int device_enumerator_scan_devices(sd_device_enumerator *enumeartor);
|
||||||
int device_enumerator_scan_subsystems(sd_device_enumerator *enumeartor);
|
int device_enumerator_scan_subsystems(sd_device_enumerator *enumeartor);
|
||||||
|
int device_enumerator_scan_devices_and_subsystems(sd_device_enumerator *enumerator);
|
||||||
int device_enumerator_add_device(sd_device_enumerator *enumerator, sd_device *device);
|
int device_enumerator_add_device(sd_device_enumerator *enumerator, sd_device *device);
|
||||||
int device_enumerator_add_match_is_initialized(sd_device_enumerator *enumerator);
|
int device_enumerator_add_match_is_initialized(sd_device_enumerator *enumerator);
|
||||||
int device_enumerator_add_match_parent_incremental(sd_device_enumerator *enumerator, sd_device *parent);
|
int device_enumerator_add_match_parent_incremental(sd_device_enumerator *enumerator, sd_device *parent);
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
typedef enum DeviceEnumerationType {
|
typedef enum DeviceEnumerationType {
|
||||||
DEVICE_ENUMERATION_TYPE_DEVICES,
|
DEVICE_ENUMERATION_TYPE_DEVICES,
|
||||||
DEVICE_ENUMERATION_TYPE_SUBSYSTEMS,
|
DEVICE_ENUMERATION_TYPE_SUBSYSTEMS,
|
||||||
|
DEVICE_ENUMERATION_TYPE_ALL,
|
||||||
_DEVICE_ENUMERATION_TYPE_MAX,
|
_DEVICE_ENUMERATION_TYPE_MAX,
|
||||||
_DEVICE_ENUMERATION_TYPE_INVALID = -EINVAL,
|
_DEVICE_ENUMERATION_TYPE_INVALID = -EINVAL,
|
||||||
} DeviceEnumerationType;
|
} DeviceEnumerationType;
|
||||||
@ -980,6 +981,58 @@ _public_ sd_device *sd_device_enumerator_get_subsystem_next(sd_device_enumerator
|
|||||||
return enumerator->devices[++enumerator->current_device_index];
|
return enumerator->devices[++enumerator->current_device_index];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int device_enumerator_scan_devices_and_subsystems(sd_device_enumerator *enumerator) {
|
||||||
|
int r = 0, k;
|
||||||
|
|
||||||
|
assert(enumerator);
|
||||||
|
|
||||||
|
if (enumerator->scan_uptodate &&
|
||||||
|
enumerator->type == DEVICE_ENUMERATION_TYPE_ALL)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
device_enumerator_unref_devices(enumerator);
|
||||||
|
|
||||||
|
if (!set_isempty(enumerator->match_tag)) {
|
||||||
|
k = enumerator_scan_devices_tags(enumerator);
|
||||||
|
if (k < 0)
|
||||||
|
r = k;
|
||||||
|
} else if (enumerator->match_parent) {
|
||||||
|
k = enumerator_scan_devices_children(enumerator);
|
||||||
|
if (k < 0)
|
||||||
|
r = k;
|
||||||
|
} else {
|
||||||
|
k = enumerator_scan_dir(enumerator, "class", NULL, NULL);
|
||||||
|
if (k < 0)
|
||||||
|
r = log_debug_errno(k, "sd-device-enumerator: Failed to scan /sys/class: %m");
|
||||||
|
|
||||||
|
k = enumerator_scan_dir(enumerator, "bus", "devices", NULL);
|
||||||
|
if (k < 0)
|
||||||
|
r = log_debug_errno(k, "sd-device-enumerator: Failed to scan /sys/bus: %m");
|
||||||
|
|
||||||
|
if (match_subsystem(enumerator, "module")) {
|
||||||
|
k = enumerator_scan_dir_and_add_devices(enumerator, "module", NULL, NULL);
|
||||||
|
if (k < 0)
|
||||||
|
r = log_debug_errno(k, "sd-device-enumerator: Failed to scan modules: %m");
|
||||||
|
}
|
||||||
|
if (match_subsystem(enumerator, "subsystem")) {
|
||||||
|
k = enumerator_scan_dir_and_add_devices(enumerator, "bus", NULL, NULL);
|
||||||
|
if (k < 0)
|
||||||
|
r = log_debug_errno(k, "sd-device-enumerator: Failed to scan subsystems: %m");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (match_subsystem(enumerator, "drivers")) {
|
||||||
|
k = enumerator_scan_dir(enumerator, "bus", "drivers", "drivers");
|
||||||
|
if (k < 0)
|
||||||
|
r = log_debug_errno(k, "sd-device-enumerator: Failed to scan drivers: %m");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
enumerator->scan_uptodate = true;
|
||||||
|
enumerator->type = DEVICE_ENUMERATION_TYPE_ALL;
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
sd_device *device_enumerator_get_first(sd_device_enumerator *enumerator) {
|
sd_device *device_enumerator_get_first(sd_device_enumerator *enumerator) {
|
||||||
assert_return(enumerator, NULL);
|
assert_return(enumerator, NULL);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user