2019-06-28 20:20:20 +08:00
|
|
|
==============
|
2016-09-17 03:16:48 +08:00
|
|
|
Userspace LEDs
|
|
|
|
==============
|
|
|
|
|
|
|
|
The uleds driver supports userspace LEDs. This can be useful for testing
|
|
|
|
triggers and can also be used to implement virtual LEDs.
|
|
|
|
|
|
|
|
|
|
|
|
Usage
|
|
|
|
=====
|
|
|
|
|
|
|
|
When the driver is loaded, a character device is created at /dev/uleds. To
|
|
|
|
create a new LED class device, open /dev/uleds and write a uleds_user_dev
|
2019-06-28 20:20:20 +08:00
|
|
|
structure to it (found in kernel public header file linux/uleds.h)::
|
2016-09-17 03:16:48 +08:00
|
|
|
|
|
|
|
#define LED_MAX_NAME_SIZE 64
|
|
|
|
|
|
|
|
struct uleds_user_dev {
|
2019-06-28 20:20:20 +08:00
|
|
|
char name[LED_MAX_NAME_SIZE];
|
2016-09-17 03:16:48 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
A new LED class device will be created with the name given. The name can be
|
|
|
|
any valid sysfs device node name, but consider using the LED class naming
|
|
|
|
convention of "devicename:color:function".
|
|
|
|
|
|
|
|
The current brightness is found by reading a single byte from the character
|
|
|
|
device. Values are unsigned: 0 to 255. Reading will block until the brightness
|
|
|
|
changes. The device node can also be polled to notify when the brightness value
|
|
|
|
changes.
|
|
|
|
|
|
|
|
The LED class device will be removed when the open file handle to /dev/uleds
|
|
|
|
is closed.
|
|
|
|
|
|
|
|
Multiple LED class devices are created by opening additional file handles to
|
|
|
|
/dev/uleds.
|
|
|
|
|
|
|
|
See tools/leds/uledmon.c for an example userspace program.
|