[systemd-devel] systemd prerelease 247-rc2

Michael Biebl mbiebl at gmail.com
Thu Nov 12 15:36:01 UTC 2020


Hi there

Am Do., 12. Nov. 2020 um 11:58 Uhr schrieb systemd tag bot
<donotreply-systemd-tag at refi64.com>:
>
> A new systemd ☠️ pre-release ☠️ has just been tagged. Please download the tarball here:
>
>         https://github.com/systemd/systemd/archive/v247-rc2.tar.gz

Congrats to the new release!

> Changes since the previous release:
>
>         * KERNEL API INCOMPATIBILITY: Linux 4.12 introduced two new uevents
>           "bind" and "unbind" to the Linux device model. When this kernel
>           change was made, systemd-udevd was only minimally updated to handle
>           and propagate these new event types. The introduction of these new
>           uevents (which are typically generated for USB devices and devices
>           needing a firmware upload before being functional) resulted in a
>           number of issues which we so far didn't address. We hoped the kernel
>           maintainers would themselves address these issues in some form, but
>           that did not happen. To handle them properly, many (if not most) udev
>           rules files shipped in various packages need updating, and so do many
>           programs that monitor or enumerate devices with libudev or sd-device,
>           or otherwise process uevents. Please note that this incompatibility
>           is not fault of systemd or udev, but caused by an incompatible kernel
>           change that happened back in Linux 4.12, but is becoming more and
>           more visible as the new uevents are generated by more kernel drivers.
>
>           To minimize issues resulting from this kernel change (but not avoid
>           them entirely) starting with systemd-udevd 247 the udev "tags"
>           concept (which is a concept for marking and filtering devices during
>           enumeration and monitoring) has been reworked: udev tags are now
>           "sticky", meaning that once a tag is assigned to a device it will not
>           be removed from the device again until the device itself is removed
>           (i.e. unplugged). This makes sure that any application monitoring
>           devices that match a specific tag is guaranteed to both see uevents
>           where the device starts being relevant, and those where it stops
>           being relevant (the latter now regularly happening due to the new
>           "unbind" uevent type). The udev tags concept is hence now a concept
>           tied to a *device* instead of a device *event* — unlike for example
>           udev properties whose lifecycle (as before) is generally tied to a
>           device event, meaning that the previously determined properties are
>           forgotten whenever a new uevent is processed.
>
>           With the newly redefined udev tags concept, sometimes it's necessary
>           to determine which tags are the ones applied by the most recent
>           uevent/database update, in order to discern them from those
>           originating from earlier uevents/database updates of the same
>           device. To accommodate for this a new automatic property CURRENT_TAGS
>           has been added that works similar to the existing TAGS property but
>           only lists tags set by the most recent uevent/database
>           update. Similarly, the libudev/sd-device API has been updated with
>           new functions to enumerate these 'current' tags, in addition to the
>           existing APIs that now enumerate the 'sticky' ones.
>
>           To properly handle "bind"/"unbind" on Linux 4.12 and newer it is
>           essential that all udev rules files and applications are updated to
>           handle the new events. Specifically:
>
>           • All rule files that currently use a header guard similar to
>             ACTION!="add|change",GOTO="xyz_end" should be updated to use
>             ACTION=="remove",GOTO="xyz_end" instead, so that the
>             properties/tags they add are also applied whenever "bind" (or
>             "unbind") is seen. (This is most important for all physical device
>             types — those for which "bind" and "unbind" are currently
>             generated, for all other device types this change is still
>             recommended but not as important — but certainly prepares for
>             future kernel uevent type additions).
>
>           • Similarly, all code monitoring devices that contains an 'if' branch
>             discerning the "add" + "change" uevent actions from all other
>             uevents actions (i.e. considering devices only relevant after "add"
>             or "change", and irrelevant on all other events) should be reworked
>             to instead negatively check for "remove" only (i.e. considering
>             devices relevant after all event types, except for "remove", which
>             invalidates the device). Note that this also means that devices
>             should be considered relevant on "unbind", even though conceptually
>             this — in some form — invalidates the device. Since the precise
>             effect of "unbind" is not generically defined, devices should be
>             considered relevant even after "unbind", however I/O errors
>             accessing the device should then be handled gracefully.
>
>           • Any code that uses device tags for deciding whether a device is
>             relevant or not most likely needs to be updated to use the new
>             udev_device_has_current_tag() API (or sd_device_has_current_tag()
>             in case sd-device is used), to check whether the tag is set at the
>             moment an uevent is seen (as opposed to the existing
>             udev_device_has_tag() API which checks if the tag ever existed on
>             the device, following the API concept redefinition explained
>             above).
>
>           We are very sorry for this breakage and the requirement to update
>           packages using these interfaces. We'd again like to underline that
>           this is not caused by systemd/udev changes, but result of a kernel
>           behaviour change.

I have to admit, it's unclear to me, what exactly this change means.
As far as udev_device_has_tag() is concerned, it seems the Debian
archive only ships one package (plymouth) which makes use of it.
https://codesearch.debian.net/search?q=udev_device_has_tag+package%3A%5CQplymouth%5CE&literal=1

But what about all those packages shipping udev rules files. Does this
new concept of sticky device tags affect them?
And if so, in what way?

I mean, Linux kernel 4.2 was already released a while ago (with the
new bind/unbind events). I assume most packages have been updated in
the meantime to handle those accordingly. What exactly changes with
those new sticky udev tags?
How can I find udev rules / packages which are potentially affected?
Has this new concept the potential to break (many) existing udev rules?
I'm now unsure whether it's safe to upload 247 to Debian unstable or not.


Regards,
Michael


More information about the systemd-devel mailing list