libcamera  v0.4.0+65-9834402f
Supporting cameras in Linux since 2019
v4l2_device.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: LGPL-2.1-or-later */
2 /*
3  * Copyright (C) 2019, Google Inc.
4  *
5  * Common base for V4L2 video devices and subdevices
6  */
7 
8 #pragma once
9 
10 #include <map>
11 #include <memory>
12 #include <optional>
13 #include <stdint.h>
14 #include <vector>
15 
16 #include <linux/videodev2.h>
17 
18 #include <libcamera/base/log.h>
19 #include <libcamera/base/signal.h>
20 #include <libcamera/base/span.h>
22 
23 #include <libcamera/color_space.h>
24 #include <libcamera/controls.h>
25 
27 
28 namespace libcamera {
29 
30 class EventNotifier;
31 
32 class V4L2Device : protected Loggable
33 {
34 public:
35  void close();
36  bool isOpen() const { return fd_.isValid(); }
37 
38  const ControlInfoMap &controls() const { return controls_; }
39 
40  ControlList getControls(const std::vector<uint32_t> &ids);
41  int setControls(ControlList *ctrls);
42 
43  const struct v4l2_query_ext_ctrl *controlInfo(uint32_t id) const;
44 
45  const std::string &deviceNode() const { return deviceNode_; }
46  std::string devicePath() const;
47 
48  int setFrameStartEnabled(bool enable);
50 
51  void updateControlInfo();
52 
53 protected:
54  V4L2Device(const std::string &deviceNode);
55  ~V4L2Device();
56 
57  int open(unsigned int flags);
58  int setFd(UniqueFD fd);
59 
60  int ioctl(unsigned long request, void *argp);
61 
62  int fd() const { return fd_.get(); }
63 
64  template<typename T>
65  static std::optional<ColorSpace> toColorSpace(const T &v4l2Format,
66  PixelFormatInfo::ColourEncoding colourEncoding);
67 
68  template<typename T>
69  static int fromColorSpace(const std::optional<ColorSpace> &colorSpace, T &v4l2Format);
70 
71 private:
72  static ControlType v4l2CtrlType(uint32_t ctrlType);
73  static std::unique_ptr<ControlId> v4l2ControlId(const v4l2_query_ext_ctrl &ctrl);
74  std::optional<ControlInfo> v4l2ControlInfo(const v4l2_query_ext_ctrl &ctrl);
75  std::optional<ControlInfo> v4l2MenuControlInfo(const v4l2_query_ext_ctrl &ctrl);
76 
77  void listControls();
78  void updateControls(ControlList *ctrls,
79  Span<const v4l2_ext_control> v4l2Ctrls);
80 
81  void eventAvailable();
82 
83  std::map<unsigned int, struct v4l2_query_ext_ctrl> controlInfo_;
84  std::vector<std::unique_ptr<ControlId>> controlIds_;
85  ControlIdMap controlIdMap_;
86  ControlInfoMap controls_;
87  std::string deviceNode_;
88  UniqueFD fd_;
89 
90  EventNotifier *fdEventNotifier_;
91  bool frameStartEnabled_;
92 };
93 
94 } /* namespace libcamera */
int fd() const
Retrieve the V4L2 device file descriptor.
Definition: v4l2_device.h:62
int open(unsigned int flags)
Open a V4L2 device node.
Definition: v4l2_device.cpp:81
Base class for V4L2VideoDevice and V4L2Subdevice.
Definition: v4l2_device.h:32
static int fromColorSpace(const std::optional< ColorSpace > &colorSpace, T &v4l2Format)
Fill in the color space fields of a V4L2 format from a ColorSpace.
Definition: v4l2_device.cpp:990
Class and enums to represent color spaces.
File descriptor wrapper that owns a file descriptor.
int get() const
Retrieve the managed file descriptor.
Definition: unique_fd.h:59
Base class to support log message extensions.
Definition: log.h:90
Top-level libcamera namespace.
Definition: backtrace.h:17
void close()
Close the device node.
Definition: v4l2_device.cpp:140
std::string devicePath() const
Retrieve the device path in sysfs.
Definition: v4l2_device.cpp:435
bool isOpen() const
Check if the V4L2 device node is open.
Definition: v4l2_device.h:36
static std::optional< ColorSpace > toColorSpace(const T &v4l2Format, PixelFormatInfo::ColourEncoding colourEncoding)
Convert the color space fields in a V4L2 format to a ColorSpace.
Definition: v4l2_device.cpp:911
Signal< uint32_t > frameStart
A Signal emitted when capture of a frame has started.
Definition: v4l2_device.h:49
const std::string & deviceNode() const
Retrieve the device node path.
Definition: v4l2_device.h:45
A map of ControlId to ControlInfo.
Definition: controls.h:366
ColourEncoding
The colour encoding type.
Definition: formats.h:23
~V4L2Device()
Destroy a V4L2Device.
Definition: v4l2_device.cpp:68
Signal & slot implementation.
ControlType
Define the data type of a Control.
Definition: controls.h:29
unique_ptr-like wrapper for a file descriptor
Definition: unique_fd.h:16
void updateControlInfo()
Update the information for all device controls.
Definition: v4l2_device.cpp:737
const struct v4l2_query_ext_ctrl * controlInfo(uint32_t id) const
Retrieve the v4l2_query_ext_ctrl information for the given control.
Definition: v4l2_device.cpp:415
int setControls(ControlList *ctrls)
Write controls to the device.
Definition: v4l2_device.cpp:295
int setFd(UniqueFD fd)
Set the file descriptor of a V4L2 device.
Definition: v4l2_device.cpp:119
Notify of activity on a file descriptor.
Definition: event_notifier.h:19
int ioctl(unsigned long request, void *argp)
Perform an IOCTL system call on the device node.
Definition: v4l2_device.cpp:492
const ControlInfoMap & controls() const
Retrieve the supported V4L2 controls and their information.
Definition: v4l2_device.h:38
V4L2Device(const std::string &deviceNode)
Construct a V4L2Device.
Definition: v4l2_device.cpp:59
ControlList getControls(const std::vector< uint32_t > &ids)
Read controls from the device.
Definition: v4l2_device.cpp:177
Associate a list of ControlId with their values for an object.
Definition: controls.h:410
Framework to manage controls related to an object.
bool isValid() const
Check if the UniqueFD owns a valid file descriptor.
Definition: unique_fd.h:60
Types and helper functions to handle libcamera image formats.
Logging infrastructure.
std::unordered_map< unsigned int, const ControlId * > ControlIdMap
A map of numerical control ID to ControlId.
Definition: controls.h:364
int setFrameStartEnabled(bool enable)
Enable or disable frame start event notification.
Definition: v4l2_device.cpp:461