Kieran Bingham b7854fd07d libcamera v0.7.0
This release brings 158 commits with substantial development on the SoftISP
components. This brings in GPU acceleration, allowing us to get higher
throughput for cameras using this pipeline. Further development to improve the
image quality is ongoing now that we can perform more processing in realtime.

The simple pipeline handler now supports exposing the Raw streams directly
allowing us to enable the SoftISP by default without removing access to the
camera formats.

Kernel headers have been updated to v6.18, supporting the new V4L2 ISP kernel
interface which allows us to continue improvements to hardware ISP pipelines as
we add new features.

Logging has been improved to better detect when to enable or disable color
output and can be controlled through the environment variable
LIBCAMERA_LOG_COLOR.

A new control is added for LensShadingCorrectionEnable to allow runtime control
over the LSC components where supported.

The gstreamer pipeline now has raw support added to the libcamerasrc
stream-role property allowing raw streams to be configured and accessed.

An exciting new AWB algorithm using Neural Networks, has been added to the
Raspberry Pi IPA following extensive development and training performed by the
Raspberry Pi Camera Team.

And finally, the Documentation now includes a support matrix which will help
identify the current support and enablement for platforms and sensors.

Contributors:

    36	Bryan O'Donoghue <bryan.odonoghue@linaro.org>
    26	Milan Zamazal <mzamazal@redhat.com>
    23	Barnabás Pőcze <barnabas.pocze@ideasonboard.com>
    20	Jacopo Mondi <jacopo.mondi@ideasonboard.com>
    15	Stefan Klug <stefan.klug@ideasonboard.com>
     8	Robert Mader <robert.mader@collabora.com>
     5	Hans de Goede <hdegoede@redhat.com>
     4	Daniel Scally <dan.scally@ideasonboard.com>
     4	Peter Bailey <peter.bailey@raspberrypi.com>
     3	Naushir Patuck <naush@raspberrypi.com>
     2	Andrei Gansari <andrei.gansari@nxp.com>
     2	Hans de Goede <johannes.goede@oss.qualcomm.com>
     2	Jai Luthra <jai.luthra@ideasonboard.com>
     2	Kieran Bingham <kieran.bingham@ideasonboard.com>
     1	Julien Vuillaumier <julien.vuillaumier@nxp.com>
     1	Khem Raj <raj.khem@gmail.com>
     1	Laurent Pinchart <laurent.pinchart@ideasonboard.com>
     1	Michael Olbrich <m.olbrich@pengutronix.de>
     1	Paul Elder <paul.elder@ideasonboard.com>
     1	Vasiliy Doylov <nekocwd@mainlining.org>

158 commits, 170 files changed, 7410 insertions(+), 2325 deletions(-)

Integration overview:

ABI:

The abi-compliance checker reports 100% compatibility in this release. But it's
a complete lie... so we're moving to v0.7.0 and increasing the SONAME for this
release.

  $ ./utils/abi-compat.sh

  Validating ABI compatibility between v0.6.0 and v0.7.0
  Preparing, please wait ...
  Comparing ABIs ...
  Comparing APIs ...
  Creating compatibility report ...
  Binary compatibility: 100%
  Source compatibility: 100%
  Total binary compatibility problems: 0, warnings: 3
  Total source compatibility problems: 0, warnings: 0
  Report: compat_reports/libcamera/v0.6.0_to_v0.7.0/compat_report.html

The warnings reported are diagnosed as low severity but relate to a change of
the structure size of the public API Request object, which will require a
recompile of any users.

bugs:
 - libcamera: simple: Move colour space logging after adjustment
   - Fixes: 5a33bc10e9 ("libcamera: software_isp: Assign colour spaces in configurations")
 - utils: gen-shader-headers: Fix subproject build
   - Fixes: 19371dee41 ("utils: gen-shader-headers: Add a utility to generate headers from shaders")
 - ipa: simple: awb: Fix ColourGains reported
   - Fixes: a0b97475b1 ("ipa: simple: Report the ColourGains in metadata")
 - apps: cam: Do not override Request::controls()
   - Fixes: 568865a6c1 ("cam: Use script parser to set controls")
 - gstreamer: Be prepared when queueing request
   - Fixes: 06bd05bece ("gstreamer: Use dedicated lock for request queues")
 - v4l2: v4l2_camera_proxy: Fix for getting default FrameDurationLimits
   - Fixes: 4e9be7d11b ("ipa: ipu3, mali-c55, rkisp1, rpi: Fix reporting non-scalar controls")
 - ipa: mali-c55: Retain Camera::controls() after ipa->configure()
   - Fixes: fe989ee514 ("ipa: mali-c55: Add Mali-C55 ISP IPA module")
 - ipa: ipu3: Retain Camera::controls() after ipa->configure()
   - Fixes: 87353f2bba ("ipa: ipu3: Derive ipu3::algorithms::Agc from AgcMeanLuminance")
 - libcamera: v4l2_subdevice: Remove unnecessary variable
   - Fixes: 5d2aad02e8 ("libcamera: add model() for retrieving model name in V4L2Subdevice")
 - libcamera: simple: Fix black level offsets in AWB
   - Fixes: 4e13c6f55b ("Honor black level in AWB")
 - apps: qcam: Disable -Wsfinae-incomplete
   - Link: https://qt-project.atlassian.net/browse/QTBUG-143470
 - libcamera: base: utils: Fix namespace of `operator<<` for `Duration`
   - Fixes: 5055ca747c ("libcamera: utils: Add helper class for std::chrono::duration")

core:
 - libcamera: media_pipeline: Add accessor for MediaPipeline list of entities
 - libcamera: controls: Small style fixes
 - libcamera: base: Wrap <regex.h>
 - libcamera: device_enumerator: Support regex to match entity names
 - libcamera: media_device: Get entity by regexp
 - libcamera: V4L2Subdevice: Get device by regexp
 - utils: gen-shader-headers: Add a utility to generate headers from shaders
 - meson: Automatically generate glsl_shaders.h from specified shader programs
 - include: linux: drm_fourcc.h: Update to v6.18
 - include: linux: intel-ipu3.h: Update to v6.18
 - include: linux: media-bus-format.h: Update to v6.18
 - include: linux: v4l2-controls.h: Update to v6.18
 - include: linux: videodev2.h: Update to v6.18
 - include: linux: README: Update to Linux v6.18
 - utils: gen-shader-headers: Fix subproject build
 - libcamera: device_enumerator_udev: Disable copy/move
 - libcamera: device_enumerator_udev: Handle duplicate devices
 - include: linux: Add stddef.h
 - include: linux: Add v4l2-isp.h
 - libcamera: request: Create control list with Camera info map
 - libcamera: request: Move metadata_ to Private
 - libcamera: request: Make metadata_ a class instance
 - libcamera: request: Make controls_ a class instance
 - libcamera: camera: Ensure a request's controls are valid
 - libcamera: camera_manager: CameraManager::version(): Add `threadsafe` ref
 - libcamera: controls: Simplify SFINAE template parameter
 - libcamera: base: log: Add `LIBCAMERA_LOG_COLOR` env var
 - libcamera: control_serializer: Remove unnecessary allocation
 - libcamera: base: event_dispatcher_poll: Dispatch `POLLPRI` first
 - meson: Do not force libc++ when using clang
 - treewide: Remove `libcamera::LOG(...)` occurrences
 - libcamera: base: log: Do not instantiate disabled `LogMessage`s
 - libcamera: base: log: Do not check severity before printing
 - libcamera: base: log: Remove `LogInvalid` check
 - libcamera: base: log: Inline `LOG()` into `ASSERT()`
 - libcamera: base: utils: join(): Don't use `const_iterator` directly
 - libcamera: v4l2_subdevice: Remove unnecessary variable
 - libcamera: v4l2_subdevice: Avoid reconstructing the `std::regex` object
 - libcamera: v4l2_subdevice: Avoid unnecessary copy
 - libcamera: control_ids: Introduce LensShadingCorrectionEnable
 - libcamera: yaml_parser: Fix uninitialized variable warning
 - libcamera: base: utils: Simplify `operator<<` for `Duration`
 - libcamera: base: utils: Fix namespace of `operator<<` for `Duration`

pipeline:
 - pipeline: imx8-isi: Integrating MediaPipeline class
 - libcamera: simple: Move colour space logging after adjustment
 - libcamera: simple: Exclude raw configurations from output conversions
 - libcamera: simple: Handle processed and raw formats separately
 - libcamera: simple: Validate raw stream configurations
 - libcamera: simple: Don't enforce conversion with an added raw stream
 - libcamera: simple: Set the number of software ISP streams to 2
 - libcamera: simple: Require metadata only when software ISP is used
 - libcamera: simple: Make raw streams working
 - pipeline: rpi: Rename Stream::prepareBuffers to Stream::allocateBuffers
 - pipeline: rpi: Rework internal buffer allocations
 - libcamera: simple: Enable SoftISP for imx7-csi
 - libcamera: pipeline: virtual: Don't use span iterator as pointer
 - libcamera: simple: Fix black level offsets in AWB

softisp:
 - libcamera: shaders: Move GL shader programs to src/libcamera/assets/shader
 - libcamera: swstats_cpu: Update statsProcessFn() / processLine0() documentation
 - libcamera: swstats_cpu: Drop patternSize_ documentation
 - libcamera: swstats_cpu: Move header to libcamera/internal/software_isp
 - libcamera: software_isp: Move benchmark code to its own class
 - libcamera: swstats_cpu: Add processFrame() method
 - libcamera: software_isp: Move useful items from DebayerCpu to Debayer base class
 - libcamera: software_isp: Move Bayer params init from DebayerCpu to Debayer
 - libcamera: software_isp: Move param select code to Debayer base class
 - libcamera: software_isp: Move DMA Sync code to Debayer base class
 - libcamera: software_isp: Make output DMA sync contingent
 - libcamera: software_isp: Move isStandardBayerOrder to base class
 - libcamera: software_isp: debayer: Introduce a start() / stop() methods to the debayer object
 - libcamera: software_isp: debayer: Make the debayer_ object of type class Debayer not DebayerCpu
 - libcamera: software_isp: lut: Make CCM available in debayer params
 - libcamera: software_isp: blacklevel: Make black level available in debayer params
 - libcamera: software_isp: lut: Make gamma from lut.cpp available in debayer params
 - libcamera: software_isp: lut: Make contrast available in debayer params
 - libcamera: software_isp: debayer: Latch contrastExp not contrast to debayer parameters
 - libcamera: software_isp: gbm: Add a GBM helper class for GPU surface access
 - libcamera: software_isp: egl: Add a eGL base helper class
 - libcamera: shaders: Rename bayer_8 to bayer_unpacked
 - libcamera: shaders: Use highp not mediump for float precision
 - libcamera: shaders: Extend debayer shaders to apply CCM gains
 - libcamera: shaders: Extend bayer shaders to support swapping R and B on output
 - libcamera: shaders: Add support for black level compensation
 - libcamera: shaders: Add support for Gamma
 - libcamera: shaders: Add support for contrast
 - libcamera: shaders: Fix input sampling when width != stride
 - libcamera: software_isp: Add member variables to track selected input/output pixelFormat
 - libcamera: software_isp: Add a Size_ member variable to pass to eGL later
 - libcamera: software_isp: debayer_egl: Add an eGL Debayer class
 - libcamera: software_isp: debayer_cpu: Make getInputConfig and getOutputConfig static
 - libcamera: software_isp: GPU support for unpacked 10/12-bit formats
 - libcamera: software_isp: debayer_egl: Make DebayerEGL an environment option
 - libcamera: software_isp: lut: Skip calculation lookup tables if gpuIspEnabled is true
 - libcamera: software_isp: lut: Change default Gamma to 1.0/2.2
 - libcamera: software_isp: Switch on default CCM at 65k
 - libcamera: software_isp: debayer_egl: Make gpuisp default softisp mode
 - libcamera: software_isp: Add a gpuisp todo list
 - Revert "libcamera: software_isp: gbm: Add a GBM helper class for GPU surface access"
 - egl: Remove unused functions
 - egl: Remove bpp variable
 - egl: Remove duplicated logging of EGL version
 - egl: Print GLES version
 - egl: Use the Mesa surfaceless platform instead of GBM
 - egl: Add workaround for Mesa <= 22.2

apps:
 - gstreamer: Add raw support to libcamerasrc stream-role property
 - apps: cam: Do not override Request::controls()
 - apps: lc-compliance: Commit camera configuration last
 - qcam: viewfinder_gl: Set no-op Bayer shader values
 - gstreamer: Be prepared when queueing request
 - v4l2: v4l2_camera_proxy: Fix for getting default FrameDurationLimits
 - apps: qcam: Disable -Wsfinae-incomplete

ipa:
 - ipa: simple: awb: Fix ColourGains reported
 - ipa: rpi: remove executable bits from data files
 - ipa: mali-c55: Update header file and adjust IPA
 - ipa: libipa: Introduce V4L2Params
 - ipa: mali-c55: Introduce MaliC55Params
 - ipa: simple: fix minimal analog gain init
 - ipa: simple: agc: Make sure activeState.agc expo/again are always initialized
 - ipa: simple: Add a flag to indicate gpuIspEnabled
 - ipa: mali-c55: Retain Camera::controls() after ipa->configure()
 - ipa: ipu3: Retain Camera::controls() after ipa->configure()
 - ipa: rpi: controller: awb: Separate Bayesian AWB into AwbBayes
 - ipa: rpi: controller: awb: Add Neural Network AWB
 - ipa: rpi: controller: Ignore algorithms that are not enabled
 - ipa: rpi: pisp: vc4: Update tuning files for new AWB
 - libcamera: ipa: simple: Remove an unused include from awb.cpp
 - libcamera: ipa: simple: Unwrap IPAFrameContext::ccm
 - libcamera: ipa: simple: Generalize tracking matrix changes
 - libcamera: ipa: simple: Rename "ccm" identifiers not specific to CCM
 - libcamera: ipa: simple: Introduce a general correction matrix
 - libcamera: ipa: simple: Initialise the general correction matrix
 - libcamera: ipa: simple: Separate saturation from CCM
 - libcamera: ipa: simple: Move contrast settings to adjust.cpp
 - libcamera: ipa: simple: Make gamma adjustable
 - libcamera: ipa: simple: Apply gain matrix in awb
 - libcamera: ipa: simple: Use float type for adjustment controls
 - libcamera: ipa: simple: Use symbolic constants for adjust defaults
 - libcamera: ipa: simple: Set contrast metadata unconditionally
 - libcamera: ipa: simple: Remove Lut algorithm
 - libcamera: ipa: simple: Disable Ccm algorithm by default again
 - ipa: rkisp1: lsc: Drop unused member variable
 - ipa: rkisp1: lsc: Drop unused function declaration
 - ipa: rkisp1: lsc: Replace assert with ASSERT
 - ipa: rkisp1: lsc: Rename res to positions
 - ipa: rkisp1: lsc: Rename res to ret
 - ipa: rkisp1: lsc: Rename res to samples
 - ipa: rksip1: lsc: Move function definitions out of class
 - ipa: rkisp1: lsc: Move local types into anonymous namespace
 - ipa: rkisp1: lsc: Handle quantization locally
 - ipa: libipa: interpolator: Drop key quantization
 - ipa: rkisp1: lsc: Pass sampling positions into samplePolynomial
 - ipa: rkisp1: lsc: Pass crop rectangle as parameter
 - ipa: rkisp1: lsc: Resample polynomial lens shading tables at configure time
 - ipa: rkisp1: Implement LensShadingCorrectionEnable control
 - ipa: rpi: Fix printing of `utils::Duration`

documentation:
 - Documentation: Add ISP feature support matrix
 - Documentation: Add camera sensor support table
 - Documentation: guides: pipeline-handler: Refresh

Acked-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
Signed-off-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
2026-01-29 12:17:26 +00:00
2025-12-16 15:02:52 +01:00
2025-07-21 11:50:44 +01:00
2024-11-19 23:57:09 +00:00
2026-01-29 12:17:26 +00: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 (>= 1.0.1) 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]
        doxygen graphviz python3-sphinx python3-sphinx-book-theme
        python3-sphinxcontrib.doxylink (>= 1.6.1) 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
        - libtiff-dev: Enables writing DNG

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

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

for android: [optional]
        libexif-dev libjpeg-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.
Description
No description provided
Readme 12 MiB
Languages
C++ 69.3%
C 17.8%
Python 10.4%
Meson 1.5%
Shell 0.7%
Other 0.3%