Flash LED handling under Linux¶
Some LED devices provide two modes - torch and flash. In the LED subsystem those modes are supported by LED class (see LED handling under Linux) and LED Flash class respectively. The torch mode related features are enabled by default and the flash ones only if a driver declares it by setting LED_DEV_CAP_FLASH flag.
In order to enable the support for flash LEDs CONFIG_LEDS_CLASS_FLASH symbol must be defined in the kernel config. A LED Flash class driver must be registered in the LED subsystem with led_classdev_flash_register function.
Following sysfs attributes are exposed for controlling flash LED devices: (see Documentation/ABI/testing/sysfs-class-led-flash)
flash_brightness
max_flash_brightness
flash_timeout
max_flash_timeout
flash_strobe
flash_fault
V4L2 flash wrapper for flash LEDs¶
A LED subsystem driver can be controlled also from the level of VideoForLinux2 subsystem. In order to enable this CONFIG_V4L2_FLASH_LED_CLASS symbol has to be defined in the kernel config.
The driver must call the v4l2_flash_init function to get registered in the V4L2 subsystem. The function takes six arguments:
- dev:
flash device, e.g. an I2C device
- of_node:
of_node of the LED, may be NULL if the same as device’s
- fled_cdev:
LED flash class device to wrap
- iled_cdev:
LED flash class device representing indicator LED associated with fled_cdev, may be NULL
- ops:
V4L2 specific ops
- external_strobe_set
defines the source of the flash LED strobe - V4L2_CID_FLASH_STROBE control or external source, typically a sensor, which makes it possible to synchronise the flash strobe start with exposure start,
- intensity_to_led_brightness and led_brightness_to_intensity
perform enum led_brightness <-> V4L2 intensity conversion in a device specific manner - they can be used for devices with non-linear LED current scale.
- config:
configuration for V4L2 Flash sub-device
- dev_name
the name of the media entity, unique in the system,
- flash_faults
bitmask of flash faults that the LED flash class device can report; corresponding LED_FAULT* bit definitions are available in <linux/led-class-flash.h>,
- torch_intensity
constraints for the LED in TORCH mode in microamperes,
- indicator_intensity
constraints for the indicator LED in microamperes,
- has_external_strobe
determines whether the flash strobe source can be switched to external,
On remove the v4l2_flash_release function has to be called, which takes one
argument - struct v4l2_flash
pointer returned previously by v4l2_flash_init.
This function can be safely called with NULL or error pointer argument.
Please refer to drivers/leds/leds-max77693.c for an exemplary usage of the v4l2 flash wrapper.
Once the V4L2 sub-device is registered by the driver which created the Media controller device, the sub-device node acts just as a node of a native V4L2 flash API device would. The calls are simply routed to the LED flash API.
Opening the V4L2 flash sub-device makes the LED subsystem sysfs interface unavailable. The interface is re-enabled after the V4L2 flash sub-device is closed.