[PATCH v2 00/18] libcamera: introduce Software ISP and Software IPA
Hans de Goede
hdegoede at redhat.com
Thu Feb 8 17:26:47 CET 2024
Hi All,
Just a quick headsup. Unfortunately I have not been able to make
much time to work on preparing v3 of this series today, so I won't
be able to post a v3 today.
I plan to continue working on preparing v3 on Monday and I'll
hopefully post a v3 series upstream on Tuesday.
Regards,
Hans
On 1/13/24 15:22, Hans de Goede wrote:
> Hi All,
>
> Here is v2 of the patch-set to add Software ISP support
> to libcamera / to the simple pipeline-handler.
>
> Changes in v2 vs v1:
> - Integrated Dennis, Martti and Toon's auto-exposure algorithm
> based on the paper which they found which gives us a nice
> relatively simple AEC + AGC algorithm
> TODO: Add link to paper to source + commit-message
> - Integrated Dennis' doxygen comments for all new classes, no more warnings!
> - Move AWB gain calculations to the IPA (Andrey)
> - Added 8 bpp and 10 bpp unpacked raw bayer input support (Hans)
> - Use dma-buf for the output FrameBuffer-s (Andrey)
> - Memcpy data from input FrameBuffers to a heap buffer on a line by line
> basis to speedup debayering from uncached mem (Hans)
> - This addresses all "open issues" from the v1 posting
>
> Changes in v1 vs RFC-v2:
> - Add and use SwStats[Cpu] and Debayer[Cpu] classes
> - Rename linaro soft-IPA and soft-ISP implementations to simple following
> the simple pipeline hander
> - Integrate Pavel's swstats and debayer improvements
>
> This has been tested on:
> - Qualcomm RB5 board with a mezzanine board equipped with RPi camera v2 (Andrey)
> - Lenovo x13s, sc8280xp (Bryan)
> - Pinephone (Pavel)
> - Debix Model A (Milan)
> - Lenovo Thinkpad Yoga X1 yoga gen7/8, Alder Lake/Raptor Lake IPU6EP +
> ov2740 10bpp packed + unpacked (Dennis / Hans)
> - Dell Latitude 9420, Tiger Lake IPU6 + ov01a1s (RGBI) sensor
> (Martti, requires IGIG_GBGR_IGIG_GRGB patches on top)
>
> git branch for this v2 patch set:
> https://gitlab.freedesktop.org/camera/libcamera-softisp/-/commits/SoftwareISP-v05
>
> git branch for v1 of the patch set:
> https://gitlab.freedesktop.org/camera/libcamera-softisp/-/commits/SoftwareISP-v04
>
> Old RFC-v2 cover-letter with small updates:
>
> Here is an implementation of Software ISP and Software IPA
> which provide debayering and implementation of image processing
> algorithms for systems without a hardware ISP, or in cases when
> there are no public drivers for the hardware ISP present in the
> system.
>
> The implementation of the Software ISP is a reference one.
> A naive AWB alorithm is implemented as part of a function which
> does debayering and statistics calculations - the algorithm part
> is to be moved to the IPA in the next version of the patch set.
> And for debayering itself there is already a more efficient
> implementation by Hans de Goede. This patch set is currently using
> the earlier debayering implementation as it is less lines of code
> and is OK for the initial discussion.
> Only RAW10P format from the sensor is currently supported, but
> other debayering functions can be easily added (which of them to
> call is decided based on the input format).
>
> The Software IPA has only auto exposure and AGC. For the AGC
> the analogue gain control of the camera sensor is used (if
> available). The algorithm is very much simplified, and is
> mostly included as a reference code.
>
> The 6th patch renames some variables in the simple pipeline
> handler for the Software ISP to use the same buffer handling
> code as the Converter currently does. This lets one to
> avoid adding extra code to the pipeline handler, but also
> makes the Software ISP and the Converter mutually exclusive.
>
> The Software ISP / IPA are intended to be used with the simple
> pipeline handler. The pipeline handler doesn't interact with
> the Software IPA directly - the Software IPA is hidden behind
> the Software ISP interface. To use the Software ISP the build
> must be configured with
> -Dpipelines=simple/simple -Dipas=simple/simple
> and the Converter must not be used (the latter is hardcoded
> in the simple pipeline handler).
> If the build is configured with just
> -Dpipelines=simple
> the Software ISP / IPA are not used, and the simple pipeline
> handler works in the same way as without this patchset.
>
> "simple" in the
> -Dpipelines=simple/simple -Dipas=simple/simple
> is the name of the Software ISP / IPA implementation.
> -Dpipelines=simple/<something else> -Dipas=simple/<something else>
> should work too if another implementation were added. What
> implementation to use is the build time choice, only one
> implementation is included into the build.
>
> This patch set uses SharedMemObject class used by the RPi pipeline
> handler - the second patch in the series moves the header file
> to a common directory.
>
> This patch set has been tested on Qualcomm RB5 board with
> a mezzanine board equipped with RPi camera v2 (not the
> standard RB5 camera mezzanine).
>
> git branch for the RFC-v2 patch set:
> https://gitlab.freedesktop.org/camera/libcamera-softisp/-/commits/SoftwareISP-v03
>
> RFC-v1 of the patch set:
> https://patchwork.libcamera.org/cover/19262/
>
> Changes in RFC v2 vs RFC v1:
> - patches are restructured and reordered
> - the Software IPA is hidden behind the Software ISP interface. The
> pipeline handler doesn't interact with the Software IPA directly
> - instantiation of the Software ISP / IPA is configurable (at build
> time)
> - comment explaining the implementation limitations is added to
> SwIspLinaro::IspWorker::debayerRaw10P()
>
> Regards,
>
> Hans
>
>
>
> Andrey Konovalov (10):
> libcamera: pipeline: simple: fix size adjustment in validate()
> libcamera: internal: Move dma_heaps.[h,cpp] to common directories
> libcamera: dma_heaps: extend DmaHeap class to support system heap
> libcamera: internal: Move SharedMemObject class to a common directory
> libcamera: introduce SoftwareIsp class
> libcamera: ipa: add Soft IPA common files
> libcamera: ipa: Soft IPA: add a Simple Soft IPA implementation
> libcamera: software_isp: add Simple SoftwareIsp implementation
> libcamera: pipeline: simple: rename converterBuffers_ and related vars
> libcamera: pipeline: simple: enable use of Soft ISP and Soft IPA
>
> Dennis Bonke (1):
> libcamera: internal: Document the SharedMemObject class
>
> Hans de Goede (7):
> libcamera: software_isp: Add SwStats base class
> libcamera: software_isp: Add SwStatsCpu class
> libcamera: software_isp: Add Debayer base class
> libcamera: software_isp: Add DebayerCpu class
> libcamera: swstats_cpu: Add support for 8 and 10 bpp unpacked bayer
> input
> libcamera: debayer_cpu: Add support for 8 and 10 bpp unpacked bayer
> input
> libcamera: debayer_cpu: Add BGR888 output support
>
> Documentation/Doxyfile.in | 1 +
> .../libcamera/internal}/dma_heaps.h | 14 +-
> include/libcamera/internal/meson.build | 4 +
> .../libcamera/internal}/shared_mem_object.h | 57 +-
> include/libcamera/internal/software_isp.h | 231 ++++++
> .../libcamera/internal/software_isp/debayer.h | 132 ++++
> .../internal/software_isp/debayer_cpu.h | 141 ++++
> .../internal/software_isp/debayer_params.h | 43 ++
> .../internal/software_isp/meson.build | 11 +
> .../internal/software_isp/swisp_simple.h | 163 +++++
> .../internal/software_isp/swisp_stats.h | 34 +
> .../libcamera/internal/software_isp/swstats.h | 215 ++++++
> .../internal/software_isp/swstats_cpu.h | 51 ++
> include/libcamera/ipa/meson.build | 1 +
> include/libcamera/ipa/soft.mojom | 29 +
> meson_options.txt | 3 +-
> src/ipa/simple/common/meson.build | 17 +
> src/ipa/simple/common/soft_base.cpp | 73 ++
> src/ipa/simple/common/soft_base.h | 50 ++
> src/ipa/simple/meson.build | 12 +
> src/ipa/simple/simple/data/meson.build | 9 +
> src/ipa/simple/simple/data/soft.conf | 3 +
> src/ipa/simple/simple/meson.build | 26 +
> src/ipa/simple/simple/soft_simple.cpp | 273 ++++++++
> .../{pipeline/rpi/vc4 => }/dma_heaps.cpp | 55 +-
> src/libcamera/meson.build | 3 +
> src/libcamera/pipeline/rpi/vc4/meson.build | 1 -
> src/libcamera/pipeline/rpi/vc4/vc4.cpp | 5 +-
> src/libcamera/pipeline/simple/simple.cpp | 177 +++--
> src/libcamera/software_isp.cpp | 62 ++
> src/libcamera/software_isp/debayer.cpp | 22 +
> src/libcamera/software_isp/debayer_cpu.cpp | 661 ++++++++++++++++++
> src/libcamera/software_isp/meson.build | 27 +
> src/libcamera/software_isp/swisp_simple.cpp | 238 +++++++
> src/libcamera/software_isp/swstats.cpp | 22 +
> src/libcamera/software_isp/swstats_cpu.cpp | 261 +++++++
> 36 files changed, 3035 insertions(+), 92 deletions(-)
> rename {src/libcamera/pipeline/rpi/vc4 => include/libcamera/internal}/dma_heaps.h (65%)
> rename {src/libcamera/pipeline/rpi/common => include/libcamera/internal}/shared_mem_object.h (62%)
> create mode 100644 include/libcamera/internal/software_isp.h
> create mode 100644 include/libcamera/internal/software_isp/debayer.h
> create mode 100644 include/libcamera/internal/software_isp/debayer_cpu.h
> create mode 100644 include/libcamera/internal/software_isp/debayer_params.h
> create mode 100644 include/libcamera/internal/software_isp/meson.build
> create mode 100644 include/libcamera/internal/software_isp/swisp_simple.h
> create mode 100644 include/libcamera/internal/software_isp/swisp_stats.h
> create mode 100644 include/libcamera/internal/software_isp/swstats.h
> create mode 100644 include/libcamera/internal/software_isp/swstats_cpu.h
> create mode 100644 include/libcamera/ipa/soft.mojom
> create mode 100644 src/ipa/simple/common/meson.build
> create mode 100644 src/ipa/simple/common/soft_base.cpp
> create mode 100644 src/ipa/simple/common/soft_base.h
> create mode 100644 src/ipa/simple/meson.build
> create mode 100644 src/ipa/simple/simple/data/meson.build
> create mode 100644 src/ipa/simple/simple/data/soft.conf
> create mode 100644 src/ipa/simple/simple/meson.build
> create mode 100644 src/ipa/simple/simple/soft_simple.cpp
> rename src/libcamera/{pipeline/rpi/vc4 => }/dma_heaps.cpp (54%)
> create mode 100644 src/libcamera/software_isp.cpp
> create mode 100644 src/libcamera/software_isp/debayer.cpp
> create mode 100644 src/libcamera/software_isp/debayer_cpu.cpp
> create mode 100644 src/libcamera/software_isp/meson.build
> create mode 100644 src/libcamera/software_isp/swisp_simple.cpp
> create mode 100644 src/libcamera/software_isp/swstats.cpp
> create mode 100644 src/libcamera/software_isp/swstats_cpu.cpp
>
More information about the libcamera-devel
mailing list