X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fdevice.h;h=ee50cfafc65ed8606f026962990a1f78a1465377;hp=a5c5f745b81f712dfea4e582e7205269c0a54b8c;hb=8e4d105ddfd53fa146e03cee9d6fcc2e932975ac;hpb=e99e38bbdcca3fe5956823bdb3d38544ccf93221 diff --git a/src/device.h b/src/device.h index a5c5f745b..ee50cfafc 100644 --- a/src/device.h +++ b/src/device.h @@ -1,4 +1,4 @@ -/*-*- Mode: C; c-basic-offset: 8 -*-*/ +/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ #ifndef foodevicehfoo #define foodevicehfoo @@ -30,7 +30,7 @@ typedef struct Device Device; * simplifies the state engine greatly */ typedef enum DeviceState { DEVICE_DEAD, - DEVICE_AVAILABLE, + DEVICE_PLUGGED, _DEVICE_STATE_MAX, _DEVICE_STATE_INVALID = -1 } DeviceState; @@ -38,9 +38,15 @@ typedef enum DeviceState { struct Device { Meta meta; - DeviceState state; - char *sysfs; + + /* In order to be able to distuingish dependencies on + different device nodes we might end up creating multiple + devices for the same sysfs path. We chain them up here. */ + + LIST_FIELDS(struct Device, same_sysfs); + + DeviceState state; }; extern const UnitVTable device_vtable;