Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

What:           /sys/.../uevent
Date:           May 2017
KernelVersion:  4.13
Contact:        Linux kernel mailing list <linux-kernel@vger.kernel.org>
Description:
                Enable passing additional variables for synthetic uevents that
                are generated by writing /sys/.../uevent file.

                Recognized extended format is ACTION [UUID [KEY=VALUE ...].

                The ACTION is compulsory - it is the name of the uevent action
                ("add", "change", "remove"). There is no change compared to
                previous functionality here. The rest of the extended format
                is optional.

                You need to pass UUID first before any KEY=VALUE pairs.
                The UUID must be in "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
                format where 'x' is a hex digit. The UUID is considered to be
                a transaction identifier so it's possible to use the same UUID
                value for one or more synthetic uevents in which case we
                logically group these uevents together for any userspace
                listeners. The UUID value appears in uevent as
                "SYNTH_UUID=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" environment
                variable.

                If UUID is not passed in, the generated synthetic uevent gains
                "SYNTH_UUID=0" environment variable automatically.

                The KEY=VALUE pairs can contain alphanumeric characters only.
                It's possible to define zero or more pairs - each pair is then
                delimited by a space character ' '. Each pair appears in
                synthetic uevent as "SYNTH_ARG_KEY=VALUE". That means the KEY
                name gains "SYNTH_ARG_" prefix to avoid possible collisions
                with existing variables.

                Example of valid sequence written to the uevent file:

                    add fe4d7c9d-b8c6-4a70-9ef1-3d8a58d18eed A=1 B=abc

                This generates synthetic uevent including these variables:

                    ACTION=add
                    SYNTH_ARG_A=1
                    SYNTH_ARG_B=abc
                    SYNTH_UUID=fe4d7c9d-b8c6-4a70-9ef1-3d8a58d18eed
Users:
                udev, userspace tools generating synthetic uevents