mirror of
https://github.com/systemd/systemd.git
synced 2024-12-25 01:34:28 +03:00
device: skip deserialization of device units when udevd is not running
Do not try to party initialize a device during deserialization if it's not known by udev (anymore) and therefore hasn't been seen during device enumeration. The device unit in this case has not been initialized properly and setting it in the "plugged" state can be confusing. Actually this happens during every boots when PID switches to the new rootfs: PID is reexecuted and enumerates devices but since udev is not running, the list of enumerated devices is empty.
This commit is contained in:
parent
918e6f1c01
commit
036d2eefae
@ -173,6 +173,18 @@ static int device_deserialize_item(Unit *u, const char *key, const char *value,
|
|||||||
assert(value);
|
assert(value);
|
||||||
assert(fds);
|
assert(fds);
|
||||||
|
|
||||||
|
/* The device was known at the time units were serialized but it's not
|
||||||
|
* anymore at the time units are deserialized. This happens when PID1 is
|
||||||
|
* re-executed after having switched to the new rootfs: devices were
|
||||||
|
* enumerated but udevd wasn't running yet thus the list of devices
|
||||||
|
* (handled by systemd) to initialize was empty. In such case we wait
|
||||||
|
* for the device events to be re-triggered by udev so device units are
|
||||||
|
* properly re-initialized. */
|
||||||
|
if (d->found == DEVICE_NOT_FOUND) {
|
||||||
|
assert(d->sysfs == NULL);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (streq(key, "state")) {
|
if (streq(key, "state")) {
|
||||||
DeviceState state;
|
DeviceState state;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user