1.17. V4L2 flash functions and data structures¶
-
struct
v4l2_flash_ctrl_data¶ flash control initialization data, filled basing on the features declared by the LED flash class driver in the v4l2_flash_config
Definition
struct v4l2_flash_ctrl_data {
struct v4l2_ctrl_config config;
u32 cid;
};
Members
config- initialization data for a control
cid- contains v4l2 flash control id if the config field was initialized, 0 otherwise
-
struct
v4l2_flash_ops¶ V4L2 flash operations
Definition
struct v4l2_flash_ops {
int (* external_strobe_set) (struct v4l2_flash *v4l2_flash,bool enable);
enum led_brightness (* intensity_to_led_brightness) (struct v4l2_flash *v4l2_flash, s32 intensity);
s32 (* led_brightness_to_intensity) (struct v4l2_flash *v4l2_flash, enum led_brightness);
};
Members
external_strobe_set- Setup strobing the flash by hardware pin state assertion.
intensity_to_led_brightness- Convert intensity to brightness in a device specific manner
led_brightness_to_intensity- convert brightness to intensity in a device specific manner.
-
struct
v4l2_flash_config¶ V4L2 Flash sub-device initialization data
Definition
struct v4l2_flash_config {
char dev_name;
struct led_flash_setting torch_intensity;
struct led_flash_setting indicator_intensity;
u32 flash_faults;
unsigned int has_external_strobe:1;
};
Members
dev_name- the name of the media entity, unique in the system
torch_intensity- constraints for the LED in torch mode
indicator_intensity- constraints for the indicator LED
flash_faults- bitmask of flash faults that the LED flash class device can report; corresponding LED_FAULT* bit definitions are available in the header file <linux/led-class-flash.h>
has_external_strobe- external strobe capability
-
struct
v4l2_flash¶ Flash sub-device context
Definition
struct v4l2_flash {
struct led_classdev_flash * fled_cdev;
struct led_classdev_flash * iled_cdev;
const struct v4l2_flash_ops * ops;
struct v4l2_subdev sd;
struct v4l2_ctrl_handler hdl;
struct v4l2_ctrl ** ctrls;
};
Members
fled_cdev- LED flash class device controlled by this sub-device
iled_cdev- LED class device representing indicator LED associated with the LED flash class device
ops- V4L2 specific flash ops
sd- V4L2 sub-device
hdl- flash controls handler
ctrls- array of pointers to controls, whose values define the sub-device state
-
struct v4l2_flash *
v4l2_flash_init(struct device * dev, struct device_node * of_node, struct led_classdev_flash * fled_cdev, struct led_classdev_flash * iled_cdev, const struct v4l2_flash_ops * ops, struct v4l2_flash_config * config)¶ initialize V4L2 flash led sub-device
Parameters
struct device * dev- flash device, e.g. an I2C device
struct device_node * of_node- of_node of the LED, may be NULL if the same as device’s
struct led_classdev_flash * fled_cdev- LED flash class device to wrap
struct led_classdev_flash * iled_cdev- LED flash class device representing indicator LED associated with fled_cdev, may be NULL
const struct v4l2_flash_ops * ops- V4L2 Flash device ops
struct v4l2_flash_config * config- initialization data for V4L2 Flash sub-device
Description
Create V4L2 Flash sub-device wrapping given LED subsystem device.
Return
A valid pointer, or, when an error occurs, the return
value is encoded using ERR_PTR(). Use IS_ERR() to check and
PTR_ERR() to obtain the numeric return value.
-
void
v4l2_flash_release(struct v4l2_flash * v4l2_flash)¶ release V4L2 Flash sub-device
Parameters
struct v4l2_flash * v4l2_flash- the V4L2 Flash sub-device to release
Description
Release V4L2 Flash sub-device.