File: runtime_configuration.rst

package info (click to toggle)
libcamera 0.6.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 15,336 kB
  • sloc: cpp: 83,873; python: 18,076; ansic: 12,651; sh: 1,267; makefile: 60
file content (281 lines) | stat: -rw-r--r-- 9,093 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
.. SPDX-License-Identifier: CC-BY-SA-4.0

Runtime configuration
=====================

The libcamera behaviour can be tuned through a configuration file or
environment variables. This document lists all the configuration options
and describes their usage.

General rules
-------------

The configuration file is looked up in the following locations, in this
order:

- $XDG_CONFIG_HOME/libcamera/configuration.yaml
- LIBCAMERA_SYSCONF_DIR/configuration.yaml
- LIBCAMERA_DATA_DIR/libcamera/configuration.yaml

The first configuration file found wins, configuration files in other
locations are ignored.

Settings in environment variables take precedence over settings in
configuration files. This allows overriding behaviour temporarily
without the need to modify configuration files.

Configuration options
---------------------

Here is an overview of the available configuration options, in the YAML
file structure:

::

  configuration:
    ipa:
      force_isolation: # true/false
      config_paths:
        - ... # full path to a directory
      module_paths:
        - ... # full path to a directory
    pipelines_match_list:
      - ... # pipeline name
    pipelines:
      simple:
        supported_devices:
          - driver: # driver name, e.g. `mxc-isi`
            software_isp: # true/false
    software_isp:
      copy_input_buffer: # true/false
      measure:
        skip: # non-negative integer, frames to skip initially
        number: # non-negative integer, frames to measure

Configuration file example
--------------------------

::

   ---
   version: 1
   configuration:
     ipa:
       config_paths:
         - /home/user/.libcamera/share/ipa
         - /opt/libcamera/vendor/share/ipa
       module_paths:
         - /home/user/.libcamera/lib
         - /opt/libcamera/vendor/lib
       proxy_paths:
         - /home/user/.libcamera/proxy/worker
         - /opt/libcamera/vendor/proxy/worker
       force_isolation: true
     pipelines_match_list:
       - rkisp1
       - simple
     pipelines:
       simple:
         supported_devices:
           - driver: mxc-isi
             software_isp: true
     software_isp:
       copy_input_buffer: false
       measure:
         skip: 50
         number: 30

List of variables and configuration options
-------------------------------------------

LIBCAMERA_LOG_FILE
   The custom destination for log output.

   Example value: ``/home/{user}/camera_log.log``

LIBCAMERA_LOG_LEVELS
   Configure the verbosity of log messages for different categories (`more <Log levels_>`__).

   Example value: ``*:DEBUG``

LIBCAMERA_LOG_NO_COLOR
   Disable coloring of log messages (`more <Notes about debugging_>`__).

LIBCAMERA_IPA_CONFIG_PATH, ipa.config_paths
   Define custom search locations for IPA configurations (`more <IPA configuration_>`__).

   Example value: ``${HOME}/.libcamera/share/ipa:/opt/libcamera/vendor/share/ipa``

LIBCAMERA_IPA_FORCE_ISOLATION, ipa.force_isolation
   When set to a non-empty string, force process isolation of all IPA modules.

   Example value: ``1``

LIBCAMERA_IPA_MODULE_PATH, ipa.module_paths
   Define custom search locations for IPA modules (`more <IPA module_>`__).

   Example value: ``${HOME}/.libcamera/lib:/opt/libcamera/vendor/lib``

LIBCAMERA_IPA_PROXY_PATH, ipa.proxy_paths
   Define custom full path for a proxy worker for a given executable name.

   Example value: ``${HOME}/.libcamera/proxy/worker:/opt/libcamera/vendor/proxy/worker``

LIBCAMERA_PIPELINES_MATCH_LIST, pipelines_match_list
   Define an ordered list of pipeline names to be used to match the media
   devices in the system. The pipeline handler names used to populate the
   variable are the ones passed to the REGISTER_PIPELINE_HANDLER() macro in the
   source code.

   Example value: ``rkisp1,simple``

LIBCAMERA_RPI_CONFIG_FILE
   Define a custom configuration file to use in the Raspberry Pi pipeline handler.

   Example value: ``/usr/local/share/libcamera/pipeline/rpi/vc4/minimal_mem.yaml``

LIBCAMERA_<NAME>_TUNING_FILE
   Define a custom IPA tuning file to use with the pipeline handler `NAME`.

   Example value: ``/usr/local/share/libcamera/ipa/rpi/vc4/custom_sensor.json``

pipelines.simple.supported_devices.driver, pipelines.simple.supported_devices.software_isp
   Override whether software ISP is enabled for the given driver.

   Example `driver` value: ``mxc-isi``

   Example `software_isp` value: ``true``

software_isp.copy_input_buffer
   Define whether input buffers should be copied into standard (cached)
   memory in software ISP. This is done by default to prevent very slow
   processing on platforms with non-cached buffers. It can be set to
   false on platforms with cached buffers to avoid an unnecessary
   overhead.

   Example value: ``false``

software_isp.measure.skip, software_isp.measure.number
   Define per-frame time measurement parameters in software ISP. `skip`
   defines how many initial frames are skipped before starting the
   measurement; `number` defines how many frames then participate in the
   measurement.

   Set `software_isp.measure.number` to 0 to disable the measurement.

   Example `skip` value: ``50``

   Example `number` value: ``30``

Further details
---------------

Notes about debugging
~~~~~~~~~~~~~~~~~~~~~

The environment variables ``LIBCAMERA_LOG_FILE``, ``LIBCAMERA_LOG_LEVELS`` and
``LIBCAMERA_LOG_NO_COLOR`` are used to modify the default configuration of the
libcamera logger.

By default, libcamera logs all messages to the standard error (std::cerr).
Messages are colored by default depending on the log level. Coloring can be
disabled by setting the ``LIBCAMERA_LOG_NO_COLOR`` environment variable.

The default log destination can also be directed to a file by setting the
``LIBCAMERA_LOG_FILE`` environment variable to the log file name. This also
disables coloring.

Log levels are controlled through the ``LIBCAMERA_LOG_LEVELS`` variable, which
accepts a comma-separated list of 'category:level' pairs.

The `level <Log levels_>`__ part is mandatory and can either be specified by
name or by numerical index associated with each level.

The optional `category <Log categories_>`__ is a string matching the categories
defined by each file in the source base using the logging infrastructure. It
can include a wildcard ('*') character at the end to match multiple categories.

For more information refer to the :doxy-int:`API documentation <log.h>`.

Examples:

Enable full debug output to a separate file, for every `category <Log categories_>`__
within a local environment:

.. code:: bash

   :~$ LIBCAMERA_LOG_FILE='/tmp/example_log.log' \
       LIBCAMERA_LOG_LEVELS=0 \
       cam --list

Enable full debug output for the categories ``Camera`` and ``V4L2`` within a
global environment:

.. code:: bash

   :~$ export LIBCAMERA_LOG_LEVELS='Camera:DEBUG,V4L2:DEBUG'
   :~$ cam --list

Log levels
~~~~~~~~~~

This is the list of available log levels, notice that all levels below
the chosen one are printed, while those above are discarded.

-  DEBUG (0)
-  INFO (1)
-  WARN (2)
-  ERROR (3)
-  FATAL (4)

Example:
If you choose WARN (2), you will be able to see WARN (2), ERROR (3) and FATAL (4)
but not DEBUG (0) and INFO (1).

Log categories
~~~~~~~~~~~~~~

Every category represents a specific area of the libcamera codebase,
the names can be located within the source code, for example:
`src/libcamera/camera_manager.cpp <https://git.libcamera.org/libcamera/libcamera.git/tree/src/libcamera/camera_manager.cpp#n35>`__

.. code:: cpp

   LOG_DEFINE_CATEGORY(Camera)

There are two available macros used to assign a category name to a part of the
libcamera codebase:

LOG_DEFINE_CATEGORY
   This macro is required, in order to use the ``LOGC`` macro for a particular
   category. It can only be used once for each category. If you want to create
   log messages within multiple compilation units for the same category utilize
   the ``LOG_DECLARE_CATEGORY`` macro, in every file except the definition file.
LOG_DECLARE_CATEGORY
   Used for sharing an already defined category between multiple separate
   compilation units.

Both macros have to be used within the libcamera namespace of the C++ source
code.

IPA configuration
~~~~~~~~~~~~~~~~~

IPA modules use their own configuration files to store parameters. The format
and contents of the configuration files is specific to the IPA module. They
usually contain tuning parameters for the algorithms, in JSON format.

The ``LIBCAMERA_IPA_CONFIG_PATH`` variable can be used to specify custom
storage locations to search for those configuration files.

`Examples <https://git.libcamera.org/libcamera/libcamera.git/tree/src/ipa/rpi/vc4/data>`__

IPA module
~~~~~~~~~~

In order to locate the correct IPA module for your hardware, libcamera gathers
existing IPA modules from multiple locations. The default locations for this
operation are the installed system path (for example on Debian:
``/usr/local/x86_64-pc-linux-gnu/libcamera``) and the build directory.
With the ``LIBCAMERA_IPA_MODULE_PATH``, you can specify a non-default location
to search for IPA modules.