[libcamera-devel] [PATCH v2 00/20] libcamera: ipu3: Rework configuration

Jacopo Mondi jacopo at jmondi.org
Thu Jul 9 10:41:08 CEST 2020


Hello,
   this second version combines what was sent in v1 to just rework the
stream validation process with the computation of the ImgU configuration
parameters.

The series steers things in the opposite direction compared to v1 when it
comes to stream assignment. V1 moved stream assignment to configure(), we
here retain it in validateion AND remove it from configure(), by using
StreamConfiguration::setStream() to remove the custom array of Streams that
was used to keep the association in place.

In order to be able to use setStream() at validate() time, the Camera class has
been changed to not zero the streams array between calls to the pipeline handler
validate() and configure() functions. The intent of that sequence was to make
sure streams where populated after configure(), the restriction that that has
to happen at configure and not validate is now lifted, and what we only care
about is that -after- validate+configure we have streams correctly populated.

When reworking validation all the assumptions about how streams have to be
assigned have been reworked, allowing multiple YUV outputs and not restricting
the usage of the main output to streams which are full-size only.

The ImgU outputs are now always (at least) 32 pixels in size smaller than
the input frame. This is not a requirement stated anywhere in the documentation,
but inspecting the xml configuration file for ChromeOS and the results from
the pipe configuration tool[1] it seems best results are obtained by giving the
IF and BDS components at least 32 pixels to scale/crop.

Speaking of pipe configuration, IF, and BDS, this series introduces in the
IPU3 pipeline handler dynamic calculation of the pipeline intermediate
components sizes, by importing the procedures implemented in the pipeline
configuration script provided by Intel:

[1] https://github.com/intel/intel-ipu3-pipecfg

The tool has been first ported as a standalone C++ application, its computation
verified against the python script results, and then integrated in the IPU3
pipeline handler.

The computed results match the python script ones for all the cases I have
tested (all the stream combination modes, and configurations with explicit
sizes).

Unfortunately, the parameters computed by the python tool differs from the ones
reported in the ChromeOS .xml configuration files. A github issue has been
opened asking for directions, but as of now, we can only assume the script
is correct.

As now we calculate the proper pipeline configuration, restrictions on the
maximum available sizes have been removed as well.

Jacopo Mondi (20):
  libcamera: ipu3: Rename mbusCodesToInfo
  libcamera: ipu3: Remove streams from generateConfiguration
  libcamera: ipu3: Make sure the config is valid
  libcamera: ipu3: cio2: Report format and sizes
  libcamera: ipu3: Do not overwrite StreamConfiguration
  libcamera: ipu3: Report StreamFormats
  libcamera: ipu3: Remove initialization of Size
  libcamera: ipu3: Validate the stream combination
  libcamera: camera: Zero streams before validate()
  libcamera: ipu3: Adjust and assign streams in validate()
  libcamera: ipu3: Adjust full frame picture to 32 pixels
  libcamera: ipu3: Always use the maximum frame size
  libcamera: ipu3: Store CameraData as mutable in CameraConfiguration
  libcamera: ipu3: Remove streams from IPU3CameraConfiguration
  libcamera: ipu3: Remove camera_ from IPU3CameraConfiguration
  libcamera: geometry: Add isNull() function to Rectangle class
  libcamera: ipu3: imgu: Calculate ImgU pipe configuration
  libcamera: ipu3: Calculate ImgU pipe configuration
  lbcamera: ipu3: Configure ImgU with the computed parameters
  libcamera: ipu3: imgu: Rename configureInput()

 include/libcamera/geometry.h         |   1 +
 src/libcamera/camera.cpp             |   4 +-
 src/libcamera/geometry.cpp           |   6 +
 src/libcamera/pipeline/ipu3/cio2.cpp |  58 +++-
 src/libcamera/pipeline/ipu3/cio2.h   |   5 +
 src/libcamera/pipeline/ipu3/imgu.    |   0
 src/libcamera/pipeline/ipu3/imgu.cpp | 401 +++++++++++++++++++++++++--
 src/libcamera/pipeline/ipu3/imgu.h   |  22 +-
 src/libcamera/pipeline/ipu3/ipu3.cpp | 389 ++++++++++++--------------
 9 files changed, 648 insertions(+), 238 deletions(-)
 create mode 100644 src/libcamera/pipeline/ipu3/imgu.

--
2.27.0



More information about the libcamera-devel mailing list