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[32];
  struct led_flash_setting torch_intensity;
  struct led_flash_setting indicator_intensity;
  u32 flash_faults;
  unsigned int has_external_strobe:1;
};

Members

dev_name[32]
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.