Working on SoftISP
Find a file
Kieran Bingham 35ed4b9129 libcamera v0.4.0
The abi-compliance-checker reports that there is both ABI and API breakage in
this release.

  Binary compatibility: 91.2%
  Source compatibility: 98.9%
  Total binary compatibility problems: 69, warnings: 0
  Total source compatibility problems: 9, warnings: 0

This is not too surprising as this was the reason for the extra delay holding
up this release, and as such this release bumps the SONAME to 0.4 accordingly.

The majority of the ABI breakages are around the public API for Control
handling and definitions, which have caused underlying identifiers to be
changed, and the reuqired storage for controls has increased.

I hope that grouping the expected ABI and API breakages and delaying this
release will allow a longer stability on the 0.4 series but as we are
developing rapidly this can not be guaranteed, though we aim to minimise
disruption to distributions and applications whereever possible.

This release brings in 253 commits, with substantial development on image
control and tuning features for IPA and Pipeline handlers supporting libipa, as
well as integrating libipa support for IPA handling on the ARM Mali-C55 ISP.

A new 'Virtual Pipeline Handler' has been introduced to support more testing in
CI and virtual environments.

Gstreamer has had some interesting development to rework expressing the full
control set from libcamera using auto generation from the full control
descriptors.

A key and notable change in this release too is that the softISP is now moving
towards utilising the libipa implementaitons which will enable future tuning
and image control capabilities, and should also support future development on a
GPU-ISP implementation for GPU-accelerated handling. I do believe this work may
have introduced an oscillation regression in the AEGC which will need to be
investigated and fixed in the near future, but I don't want to hold up
progressing the ABI updates at this stage.

The i.MX8MP can now make full use of the DW100 Dewarp Engine for full rotation
and digital zoom capabilities.

Raspberry Pi systems now have improved support for the OV7251, IMX462, and
IMX327 Sensors, and libipa platforms can now make use of the GalaxyCore gc05a2
and gc08a3 Image sensors.

The following commits in this release relate to either a bug fix or an
improvement to an existing commit.

 - ipa: rpi: Use std::abs()
   - Reported-by: Maarten Lankhorst <dev@lankhorst.se>
 - libcamera: rkisp1: Clamp stream configuration to ISP limit on raw path
   - Fixes: 761545407c ("pipeline: rkisp1: Filter out sensor sizes not supported by the pipeline")
 - libcamera: rkisp1: Rectify SensorConfiguration check
   - Fixes: 047d647452 ("libcamera: rkisp1: Integrate SensorConfiguration support")
 - libcamera: controls: Add missing size to control_type<Point>
   - Fixes: 200d535ca8 ("libcamera: controls: Add ControlTypePoint")
 - pycamera: Add missing code for ControlTypePoint
   - Fixes: 200d535ca8 ("libcamera: controls: Add ControlTypePoint")
 - libcamera: software_isp: Clear IPA context on configure and stop
   - Fixes: 04d171e6b2 ("libcamera: software_isp: Call Algorithm::queueRequest")
 - utils: checkstyle.py: Centralize dependency handling for checkers
   - Fixes: 8ffaf376bb ("utils: checkstyle: Add a python formatter")
 - test: py: Fix log level restore in SimpleTestMethods()
   - Fixes: 06cb7130c4 ("py: Add unittests.py")
 - v4l2: v4l2_camera_proxy: Fix VIDIOC_[GS]_PARM support
   - Fixes: 5456e02d3f ("v4l2: Support setting frame rate in the V4L2 Adaptation layer")
 - gstreamer: Remove auto-focus-mode property from device provider
   - Fixes: 5a142438b0 ("gstreamer: Add enable_auto_focus option to the GStreamer plugin")
 - libcamera: software_isp: Clean up pending requests on stop
   - Bug: https://bugs.libcamera.org/show_bug.cgi?id=234
 - ipa: rpi: awb: Disable CT search bias for Grey World AWB
   - Fixes: ea8fd63d93 ("ipa: rpi: awb: Add a bias to the AWB search")
 - meson: Don't unnecessarily fallback to libyuv wrap
   - Fixes: eeaa7de21b ("libcamera: pipeline: Add test pattern for VirtualPipelineHandler")
 - libcamera: Don't copy `StreamConfiguration` when iterating
   - Fixes: 4217c9f1aa ("libcamera: camera: Zero streams before validate()")
 - libcamera: software_isp: Actually apply black level from tuning data
   - Fixes: 41e3d61c74 ("libcamera: software_isp: Clear IPA context on configure and stop")
 - gstreamer: keep same transfer with that in negotiated caps
   - Bug: https://bugs.libcamera.org/show_bug.cgi?id=150
 - pipeline: rkisp1: Fix scope of dewarper stop() exit action
   - Fixes: 12b553d691 ("libcamera: rkisp1: Plumb the dw100 dewarper as V4L2M2M converter")
 - pipeline: rkisp1: Limit sensor size to max resolution
   - Fixes: 761545407c ("pipeline: rkisp1: Filter out sensor sizes not supported by the pipeline")

And the following updates have been made in this release, grouped by category:

core:
 - utils: abi-compat: Disable python build
 - utils: abi-compat: sort meson options
 - libcamera: controls: Add enum names and values map to ControlId
 - libcamera: controls: Add array information to ControlId
 - libcamera: v4l2_videodevice: Add getSelection() function
 - libcamera: controls: Handle enum values without a cast
 - libcamera: Replace usage of lroundf() with std::lround()
 - libcamera: Replace last users of math.h
 - libcamera: geometry: Clarify Rectangle's top-left corner
 - libcamera: geometry: Add two-point Rectangle constructor
 - libcamera: controls: Add ControlTypePoint
 - libcamera: control_ids_draft: Add face detection controls
 - libcamera: android: Add face detection control support
 - libcamera: yaml_parser: Take string keys in `std::string_view`
 - libcamera: camera: Fix CameraConfiguration spelling error
 - libcamera: MappedFrameBuffer: Fix typo in comment formatting
 - libcamera: controls: Add missing size to control_type<Point>
 - libcamera: tracepoints: Fix copyright year for reproducible builds
 - libcamera: controls: Add vendor information to ControlId
 - libcamera: converter: Add interface for feature flags
 - libcamera: converter: Add interface to support cropping capability
 - libcamera: formats: Change bytesPerGroup of RGB565 and RGB565_BE from 3 to 2
 - utils: checkstyle.py: Factor out common code to new CheckerBase class
 - utils: checkstyle.py: Turn check() into a class method for all checkers
 - utils: checkstyle.py: Print issues using __str__
 - utils: checkstyle.py: Centralize dependency handling for checkers
 - libcamera: camera_sensor: Introduce CameraSensorFactory
 - libcamera: camera_sensor: Create abstract base class
 - libcamera: camera_sensor: Sort factories by priority
 - libcamera: pipeline_handler: Provide cancelRequest
 - libcamera: simple: Track requests in conversionQueue_
 - libcamera: Rationalize IPA and handlers names
 - libcamera: Add debug control space
 - libcamera: Add a DebugMetadata helper
 - utils: Add script to generate control_ids_debug.yaml
 - libcamera: yaml_parser: Use std::from_chars()
 - libcamera: add DmaBufAllocator::exportBuffers()
 - libcamera: Remove PipelineHandler Fatal check of non-empty MediaDevices
 - libcamera: virtual: Add VirtualPipelineHandler
 - libcamera: virtual: Add ImageFrameGenerator
 - libcamera: virtual: Read config and register cameras based on the config
 - meson: Don't unnecessarily fallback to libyuv wrap
 - libcamera: Rename "shutter speed" to "exposure time"
 - libcamera: camera_sensor_properties: Add sensor control delays
 - libcamera: pipelines: Draw control delays from CameraSensor properties
 - libcamera: Don't copy `StreamConfiguration` when iterating
 - treewide: Avoid some copies in range-based for loops
 - libcamera: v4l2_videodevice: Clarify V4L2M2MDevice
 - libcamera: Extend u32 control type
 - libcamera: Extend u16 control type
 - libcamera: add method to set thread affinity
 - libcamera: Copy Matrix class from libipa to libcamera
 - libcamera: internal: Move Matrix class into libcamera namespace
 - libcamera: internal: matrix: Replace vector with array in constructor
 - libcamera: internal: Add Matrix class to build
 - libcamera: mali-c55: Limit max size to sensor resolution
 - libcamera: mali-c55: Limit ISP input size
 - libcamera: mali-c55: Init camera properties
 - libcamera: mali-c55: Simplify bufferReady()
 - libcamera: mali-c55: Remove MaliC55CameraData::mbusCodes()
 - libcamera: mali-c55: Add stride and size to rawConfig
 - libcamera: v4l2-subdevice: Add Mali C55 media bus formats
 - libcamera: bayer_format: Add 20-bit bayer formats
 - libcamera: mali-c55: Propagate CSI-2 format to ISP
 - libcamera: mali-c55: Correct input/output format representation
 - libcamera: mali-c55: Enable links between resizer and video node
 - libcamera: mali-c55: Enable usage of scaler
 - libcamera: mali-c55: implement support for ScalerCrop
 - libcamera: yaml_parser: Output more details when parsing fails
 - libcamera: yaml_parser: Include stdlib.h instead of cstdlib
 - libcamera: utils: StringSplitter: Inline some trivial methods
 - libcamera: utils: StringSplitter: Add `operator==`
 - libcamera: stream: Add operator<<(StreamConfiguration)
 - libcamera: yaml_parser: Improve efficiency of string empty check
 - libcamera: geometry: Add Rectangle::transformedBetween()
 - libcamera: converter_v4l2_m2m: Add missing override specifier
 - libcamera: converter_v4l2_m2m: Refactor get crop bounds code
 - libcamera: converter: Add function to query crop bounds
 - libcamera: converter: Add function to check if a stream was configured
 - libcamera: converter: Add functions to adjust config
 - libcamera: camera: Add a const version of the pipe() function
 - libcamera: camera_sensor: Add parameter to limit returned sensor size
 - libcamera: camera_sensor_properties: Add ov7251 and ov9281
 - libcamera: rpi: Draw sensor delays from CameraSensorProperties
 - include: linux: Add mali-c55-config.h
 - include: linux: Add Mali-C55 Stats and Params V4L2 format
 - libcamera: mali-c55: Acquire and plumb in 3a params and stats
 - libcamera: controls: Populate direction field in control definitions
 - utils: codegen: controls.py: Parse direction information
 - libcamera: controls: Add support for querying direction information
 - libcamera: controls: Update the ColourTemperature control to be writable
 - utils: gen-debug-controls: Output direction flag
 - hooks: pre-push: Verify that co-authors have a SoB line
 - gitignore: Add venv directory to gitignore
 - CameraManager: Ensure we cleanup on failure
 - Add .editorconfig file
 - DmaBufAllocator: Add Dma Buffer synchronization function & helper class

apps:
 - apps: cam: Print control enum values more nicely
 - py: Add bindings for ControlId enum name
 - apps: cam: Print control array sizes
 - apps: Replace HAVE_DNG with HAVE_TIFF
 - apps: cam: Print an error when outputting DNG and DNG support is missing
 - pycamera: Add missing code for ControlTypePoint
 - apps: cam: Print control vendor information when listing controls
 - py: Add bindings for ControlId vendor information
 - qcam: Automatically select the camera if only one is available
 - gstreamer: Implement caps negotiation for video/x-bayer
 - v4l2: v4l2_camera_proxy: Fix VIDIOC_[GS]_PARM support
 - gstreamer: Remove auto-focus-mode property from device provider
 - gstreamer: Remove auto-focus-mode property from libcamerasrc
 - gstreamer: Generate controls from control_ids_*.yaml files
 - py: Add bindings for ControlId array information
 - qcam: Use pointer when choosing camera
 - gstreamer: keep same transfer with that in negotiated caps
 - apps: cam: Print control direction information

pipeline:
 - libcamera: software_isp: Remove superfluous includes
 - libcamera: software_isp: Move BlackLevel to libcamera::ipa::soft
 - libcamera: software_isp: Define skeletons for IPA refactoring
 - libcamera: software_isp: Let IPASoftSimple inherit Module
 - libcamera: software_isp: Make stats frame and buffer aware
 - libcamera: software_isp: Remove final dots in debayer.cpp docstrings
 - libcamera: software_isp: Track and pass frame ids
 - libcamera: software_isp: Create algorithms
 - libcamera: software_isp: Call Algorithm::configure
 - libcamera: software_isp: Call Algorithm::queueRequest
 - libcamera: software_isp: Call Algorithm::prepare
 - libcamera: software_isp: Call Algorithm::process
 - libcamera: software_isp: Move black level to an algorithm module
 - libcamera: software_isp: Move color handling to an algorithm module
 - libcamera: software_isp: Use floating point for color parameters
 - libcamera: software_isp: Use DelayedControls
 - libcamera: software_isp: Move exposure+gain to an algorithm module
 - libcamera: software_isp: Update black level only on exposure changes
 - pipeline: simple: Increase buffer count to four
 - libcamera: rkisp1: Eliminate hard-coded resizer limits
 - pipeline: rkisp1: Filter out sensor sizes not supported by the pipeline
 - libcamera: software_isp: Improve wording in a comment
 - libcamera: rkisp1: Integrate SensorConfiguration support
 - libcamera: rkisp1: Clamp stream configuration to ISP limit on raw path
 - libcamera: rkisp1: Use const reference for sensor configuration
 - libcamera: rkisp1: Rectify SensorConfiguration check
 - libcamera: rkisp1: Maintain alphabetical order of forward declarations
 - libcamera: software_isp: Clear IPA context on configure and stop
 - libcamera: software_isp: Get black level from the camera helper
 - libcamera: software_isp: Black level from tuning file
 - libcamera: pipeline: rkisp1: Fix typo in todo task
 - libcamera: rkisp1: Prepare for additional camera controls
 - libcamera: rkisp1: Plumb the dw100 dewarper as V4L2M2M converter
 - pipeline: rpi: Remove CameraData::scalerCrop_
 - pipeline: rpi: Pass crop rectangle as a parameter to platformSetIspCrop()
 - pipeline: rpi: Introduce CameraData::CropParams
 - pipeline: rpi: Track which ISP output is configured for a stream
 - pipeline: rpi: Pass ISP output index into platformSetIspCrop()
 - pipeline: rpi: Handler controls::rpi::ScalerCrops
 - libcamera: rkisp1: Create main buffer pool out of if(!isRaw)
 - libcamera: software_isp: Clean up pending requests on stop
 - libcamera: pipeline: Add test pattern for VirtualPipelineHandler
 - libcamera: software_isp: Refactor SoftwareIsp to use DmaBufAllocator::exportBuffers
 - libcamera: software_isp: Initialize exposure+gain before agc calculations
 - libcamera: software_isp: Remove unused IPAActiveState fields
 - libcamera: software_isp: Actually apply black level from tuning data
 - rkisp1: Use Matrix class from libcamera
 - libcamera: software_isp: Add support for contrast control
 - libcamera: software_isp: Add contrast control
 - pipeline: rkisp1: Fix scope of dewarper stop() exit action
 - pipeline: rkisp1: Keep aspect ratio on imx8mp
 - pipeline: rkisp1: Split inputCrop and outputCrop
 - pipeline: rkisp1: Reorder sensorInfo collection code
 - pipeline: rkisp1: Query dewarper crop bounds if no stream configured
 - pipeline: rkisp1: Fix ScalerCrop to be in sensor coordinates
 - pipeline: rkisp1: Add ScalerMaximumCrop property
 - pipeline: rkisp1: Refactor path validation
 - pipeline: rkisp1: Enable the dewarper unconditionally
 - pipeline: rkisp1: make RkISP1CameraConfiguration a friend of the pipeline handler
 - pipeline: rkisp1: Fix config validation when dewarper is used
 - pipeline: rkisp1: Limit sensor size to max resolution
 - debayer_cpu: Replace syncing DMABUFs with DmaSyncer
 - include: media-bus-formats: Add Mali-C55 mbus codes
 - mali-c55: Plumb the IPA module in

ipa:
 - ipa: rpi: Use std::abs()
 - ipa: rpi: Replace last users of math.h
 - ipa: rpi: awb: Add a const for the default colour temperature
 - ipa: rpi: awb: Add a bias to the AWB search
 - ipa: rkisp1: algorithms: agc: Check for correct stats type
 - ipa: rkisp1: algorithms: awb: Check for correct stats type
 - ipa: rpi: Add tuning files for OV7251
 - ipa: libipa: Fix ExposureModeHelper function name in documentation
 - ipa: rkisp1: Add constructor to the ipa context
 - ipa: rkisp1: Add debug metadata support to the rkisp1
 - ipa: libipa: Add data accessor to Histogram
 - ipa: libipa: Add colour helpers
 - ipa: ipu3: Use centralised libipa helpers
 - ipa: rkisp1: Use centralised libipa helpers
 - ipa: rpi: Use centralised libipa helpers
 - ipa: rpi: awb: Disable CT search bias for Grey World AWB
 - libipa: FCQueue: Make sure FrameContext#0 is initialized
 - libcamera: libipa: camera_sensor: Provide helper and properties for Sony IMX462
 - ipa: rpi: cam_helper: Add Sony IMX327
 - ipa: raspberrypi: Add tuning file for IMX462 sensor
 - ipa: raspberrypi: Add tuning file for IMX327 sensor
 - libcamera: libipa: camera_sensor_helper: add IMX290 black level
 - ipa: libipa: vector: Add mutable x(), y() and z() accessors
 - ipa: libipa: vector: Add r(), g() and b() accessors
 - ipa: libipa: vector: Add scalar constructor
 - ipa: libipa: vector: Rename the dot product operator*() to dot()
 - ipa: libipa: vector: Generalize arithmetic operators
 - ipa: libipa: vector: Add missing binary arithemtic operators
 - ipa: libipa: vector: Add compound assignment operators
 - ipa: libipa: vector: Add element-wise min() and max() functions
 - ipa: libipa: vector: Add sum() function
 - ipa: ipu3: awb: Replace Awb::RGB class with ipa::RGB
 - ipa: libipa: colour: Use the RGB class to model RGB values
 - ipa: libipa: colour: Use Vector and Matrix for linear algebra
 - ipa: rkisp1: awb: Use RGB class to store colour gains
 - ipa: rkisp1: awb: Use Vector and Matrix for linear algebra
 - ipa: rkisp1: awb: Expand comment
 - libcamera: libipa: camera_sensor: Add GalaxyCore gc05a2 sensor properties
 - libcamera: libipa: camera_sensor: Add GalaxyCore gc08a3 sensor properties
 - ipa: rpi: Rename Matrix to Matrix3x3
 - ipa: rpi: ccm: Replace local matrix implementation with the libcamera one
 - libipa: Use Matrix class from libcamera
 - libipa: Drop Matrix class
 - libipa: agc_mean_luminance: Rename yaml key from exposure-time to exposureTime
 - ipa: software_isp: Add constructor to the IPA context
 - ipa: ipu3: Add constructor to the IPA context
 - libcamera: libipa: camera_sensor_helper: Use `variant` instead of `union`
 - ipa: rpi: Fix wrong frame integration difference value for OV9281
 - ipa: rpi: cam_helper: imx708: Correct the frame integration diff value
 - libipa: Centralise Fixed / Floating point convertors
 - ipa: mali-c55: Add Mali-C55 ISP IPA module
 - ipa: mali-c55: Add Agc algorithm
 - ipa: mali-c55: Add BLC Algorithm
 - ipa: mali-c55: Add AWB Algorithm
 - ipa: mali-c55: Add Lens Shading Correction algorithm
 - ipa: mali-c55: Add IMX415 tuning data file
 - ipa: rkisp1: awb: Load white balance gains from tuning file
 - ipa: rkisp1: awb: Implement ColourTemperature control
 - ipa: rpi: awb: Make it possible to set the colour temperature directly
 - ipa: libipa: Add Lux helper
 - ipa: rkisp1: Add Lux algorithm module
 - controls: rpi: Add a vendor rpi::ScalerCrops control

documentation:
 - Documentation: guides: Fix FileSink source link

test:
 - test: py: Fix log level restore in SimpleTestMethods()
 - test: py: Replace environment array with environment object
 - test: py: LD_PRELOAD the C++ standard library when using ASan
 - test: libipa: Add Vector class test
 - test: span: Use intended variable

tuning:
 - utils: tuning: libtuning: Fix tuning for non RGGB RAWs
 - libtuning: Use logging framework in ctt_awb.awb()
 - libtuning: Remove the Cam object from ctt_awb.awb()
 - libtuning: Fix access to color member in ctt_awb.awb()
 - libtuning: Add initial AWB module
 - utils: tuning: rkisp1: Replace static AWB with new AWB module

Acked-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
Signed-off-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
2024-12-23 20:18:23 +00:00
.reuse Documentation: Introduce Camera Sensor Model 2023-09-27 14:35:33 +03:00
Documentation ipa: mali-c55: Add Mali-C55 ISP IPA module 2024-12-17 22:35:58 +00:00
include libcamera: controls: Add support for querying direction information 2024-12-18 17:27:01 +09:00
LICENSES Documentation: theme: Specify license of search.png 2022-09-30 21:51:14 +03:00
package/gentoo/media-libs/libcamera libcamera: Standardize URLs to git repositories 2021-09-24 13:25:33 +03:00
src ipa: rkisp1: Add Lux algorithm module 2024-12-23 17:38:40 +09:00
subprojects subprojects: Drop leftovers of pybind11 2023-06-04 11:48:00 +03:00
test libipa: Centralise Fixed / Floating point convertors 2024-12-17 22:35:58 +00:00
utils utils: gen-debug-controls: Output direction flag 2024-12-23 11:16:08 +00:00
.clang-format libcamera: Remove spaces at end of lines 2024-08-05 18:25:53 +03:00
.clang-tidy libcamera: Add missing SPDX headers for miscellaneous CC0-1.0 contents 2022-09-30 21:51:23 +03:00
.editorconfig Add .editorconfig file 2024-11-19 23:57:09 +00:00
.gitignore gitignore: Add venv directory to gitignore 2024-10-09 14:36:47 +02:00
COPYING.rst libcamera: Summarize licensing terms in COPYING.rst 2020-06-26 15:18:25 +03:00
meson.build libcamera v0.4.0 2024-12-23 20:18:23 +00:00
meson_options.txt ipa: mali-c55: Add Mali-C55 ISP IPA module 2024-12-17 22:35:58 +00:00
README.rst Documentation: Rework index.rst 2024-08-21 01:35:49 +03:00

.. SPDX-License-Identifier: CC-BY-SA-4.0

===========
 libcamera
===========

**A complex camera support library for Linux, Android, and ChromeOS**

Cameras are complex devices that need heavy hardware image processing
operations. Control of the processing is based on advanced algorithms that must
run on a programmable processor. This has traditionally been implemented in a
dedicated MCU in the camera, but in embedded devices algorithms have been moved
to the main CPU to save cost. Blurring the boundary between camera devices and
Linux often left the user with no other option than a vendor-specific
closed-source solution.

To address this problem the Linux media community has very recently started
collaboration with the industry to develop a camera stack that will be
open-source-friendly while still protecting vendor core IP. libcamera was born
out of that collaboration and will offer modern camera support to Linux-based
systems, including traditional Linux distributions, ChromeOS and Android.

.. section-begin-getting-started

Getting Started
---------------

To fetch the sources, build and install:

.. code::

  git clone https://git.libcamera.org/libcamera/libcamera.git
  cd libcamera
  meson setup build
  ninja -C build install

Dependencies
~~~~~~~~~~~~

The following Debian/Ubuntu packages are required for building libcamera.
Other distributions may have differing package names:

A C++ toolchain: [required]
        Either {g++, clang}

Meson Build system: [required]
        meson (>= 0.60) ninja-build pkg-config

for the libcamera core: [required]
        libyaml-dev python3-yaml python3-ply python3-jinja2

for IPA module signing: [recommended]
        Either libgnutls28-dev or libssl-dev, openssl

        Without IPA module signing, all IPA modules will be isolated in a
        separate process. This adds an unnecessary extra overhead at runtime.

for improved debugging: [optional]
        libdw-dev libunwind-dev

        libdw and libunwind provide backtraces to help debugging assertion
        failures. Their functions overlap, libdw provides the most detailed
        information, and libunwind is not needed if both libdw and the glibc
        backtrace() function are available.

for device hotplug enumeration: [optional]
        libudev-dev

for documentation: [optional]
        python3-sphinx doxygen graphviz texlive-latex-extra

for gstreamer: [optional]
        libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev

for Python bindings: [optional]
        libpython3-dev pybind11-dev

for cam: [optional]
        libevent-dev is required to support cam, however the following
        optional dependencies bring more functionality to the cam test
        tool:

        - libdrm-dev: Enables the KMS sink
        - libjpeg-dev: Enables MJPEG on the SDL sink
        - libsdl2-dev: Enables the SDL sink

for qcam: [optional]
        libtiff-dev qt6-base-dev qt6-tools-dev-tools

for tracing with lttng: [optional]
        liblttng-ust-dev python3-jinja2 lttng-tools

for android: [optional]
        libexif-dev libjpeg-dev

for Python bindings: [optional]
        pybind11-dev

for lc-compliance: [optional]
        libevent-dev libgtest-dev

for abi-compat.sh: [optional]
        abi-compliance-checker

Basic testing with cam utility
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The ``cam`` utility can be used for basic testing. You can list the cameras
detected on the system with ``cam -l``, and capture ten frames from the first
camera and save them to disk with ``cam -c 1 --capture=10 --file``. See
``cam -h`` for more information about the ``cam`` tool.

In case of problems, a detailed debug log can be obtained from libcamera by
setting the ``LIBCAMERA_LOG_LEVELS`` environment variable:

.. code::

    :~$ LIBCAMERA_LOG_LEVELS=*:DEBUG cam -l

Using GStreamer plugin
~~~~~~~~~~~~~~~~~~~~~~

To use the GStreamer plugin from the source tree, use the meson ``devenv``
command.  This will create a new shell instance with the ``GST_PLUGIN_PATH``
environment set accordingly.

.. code::

  meson devenv -C build

The debugging tool ``gst-launch-1.0`` can be used to construct a pipeline and
test it. The following pipeline will stream from the camera named "Camera 1"
onto the OpenGL accelerated display element on your system.

.. code::

  gst-launch-1.0 libcamerasrc camera-name="Camera 1" ! queue ! glimagesink

To show the first camera found you can omit the camera-name property, or you
can list the cameras and their capabilities using:

.. code::

  gst-device-monitor-1.0 Video

This will also show the supported stream sizes which can be manually selected
if desired with a pipeline such as:

.. code::

  gst-launch-1.0 libcamerasrc ! 'video/x-raw,width=1280,height=720' ! \
       queue ! glimagesink

The libcamerasrc element has two log categories, named libcamera-provider (for
the video device provider) and libcamerasrc (for the operation of the camera).
All corresponding debug messages can be enabled by setting the ``GST_DEBUG``
environment variable to ``libcamera*:7``.

Presently, to prevent element negotiation failures it is required to specify
the colorimetry and framerate as part of your pipeline construction. For
instance, to capture and encode as a JPEG stream and receive on another device
the following example could be used as a starting point:

.. code::

   gst-launch-1.0 libcamerasrc ! \
        video/x-raw,colorimetry=bt709,format=NV12,width=1280,height=720,framerate=30/1 ! \
        queue ! jpegenc ! multipartmux ! \
        tcpserversink host=0.0.0.0 port=5000

Which can be received on another device over the network with:

.. code::

   gst-launch-1.0 tcpclientsrc host=$DEVICE_IP port=5000 ! \
        multipartdemux ! jpegdec ! autovideosink

The GStreamer element also supports multiple streams. This is achieved by
requesting additional source pads. Downstream caps filters can be used
to choose specific parameters like resolution and pixel format. The pad
property ``stream-role`` can be used to select a role.

The following example displays a 640x480 view finder while streaming JPEG
encoded 800x600 video. You can use the receiver pipeline above to view the
remote stream from another device.

.. code::

   gst-launch-1.0 libcamerasrc name=cs src::stream-role=view-finder src_0::stream-role=video-recording \
       cs.src ! queue ! video/x-raw,width=640,height=480 ! videoconvert ! autovideosink \
       cs.src_0 ! queue ! video/x-raw,width=800,height=600 ! videoconvert ! \
       jpegenc ! multipartmux ! tcpserversink host=0.0.0.0 port=5000

.. section-end-getting-started

Troubleshooting
~~~~~~~~~~~~~~~

Several users have reported issues with meson installation, crux of the issue
is a potential version mismatch between the version that root uses, and the
version that the normal user uses. On calling `ninja -C build`, it can't find
the build.ninja module. This is a snippet of the error message.

::

  ninja: Entering directory `build'
  ninja: error: loading 'build.ninja': No such file or directory

This can be solved in two ways:

1. Don't install meson again if it is already installed system-wide.

2. If a version of meson which is different from the system-wide version is
   already installed, uninstall that meson using pip3, and install again without
   the --user argument.