sd_device_enumerator_get_device_first, sd_device_enumerator_get_device_next, sd_device_enumerator_get_subsystem_first, sd_device_enumerator_get_subsystem_next — Enumerates devices and get the first or next device.
#include <systemd/sd-device.h>
| sd_device *sd_device_enumerator_get_device_first( | sd_device_enumerator *enumerator ); | 
| sd_device *sd_device_enumerator_get_device_next( | sd_device_enumerator *enumerator ); | 
| sd_device *sd_device_enumerator_get_subsystem_first( | sd_device_enumerator *enumerator ); | 
| sd_device *sd_device_enumerator_get_subsystem_next( | sd_device_enumerator *enumerator ); | 
The sd_device_enumerator_get_device_first() function enumerates all
    matching devices under /sys/bus/
    and SUBSYSTEM/devices//sys/class/,
    and returns a pointer to the first sd_device object. If no devices are found,
    SUBSYSTEM/devices/NULL is returned.
The sd_device_enumerator_get_device_next() function returns the pointer
    to the next sd_device from the enumerator. It should
    be called after sd_device_enumerator_get_device_first() or after a previous
    call to this function. If no more devices are available, NULL is returned.
The sd_device_enumerator_get_subsystem_first() function enumerates all
    matching subsystem devices in /sys/module/, /sys/bus/,
    and /sys/bus/
    (such as SUBSYSTEM/drivers//sys/bus/pci/drivers/). It returns a pointer to the first
    sd_device object. If no devices are found NULL is returned.
    Note that this does not enumerate devices provided by
    sd_device_enumerator_get_device_first/next(). Hence, e.g.
    /sys/bus/pci/, /sys/bus/pci/drivers/ahci/ and so on are
    enumerated, but /sys/bus/pci/devices/0000:00:00.0/ and so on are not.
The sd_device_enumerator_get_subsystem_next() function returns the next
    subsystem device from the enumerator. It should be called after
    sd_device_enumerator_get_subsystem_first() or after a previous call to this
    function. If no more subsystem devices are available, NULL is returned.
On success, these functions return a pointer to an sd_device object.
    On failure or when no more devices are available, NULL is returned. The
    returned pointers are owned by the enumerator and should not be freed by the caller.
sd_device_enumerator_get_device_first(),
    sd_device_enumerator_get_device_next(),
    sd_device_enumerator_get_subsystem_first(), and
    sd_device_enumerator_get_subsystem_next() were introduced in systemd version
    240.