{"id":3377,"url":"https://patchwork.libcamera.org/api/1.1/covers/3377/?format=json","web_url":"https://patchwork.libcamera.org/cover/3377/","project":{"id":1,"url":"https://patchwork.libcamera.org/api/1.1/projects/1/?format=json","name":"libcamera","link_name":"libcamera","list_id":"libcamera_core","list_email":"libcamera-devel@lists.libcamera.org","web_url":"","scm_url":"","webscm_url":""},"msgid":"<20200404004438.17992-1-laurent.pinchart@ideasonboard.com>","date":"2020-04-04T00:44:27","name":"[libcamera-devel,v4,00/11] Simple pipeline handler","submitter":{"id":2,"url":"https://patchwork.libcamera.org/api/1.1/people/2/?format=json","name":"Laurent Pinchart","email":"laurent.pinchart@ideasonboard.com"},"mbox":"https://patchwork.libcamera.org/cover/3377/mbox/","series":[{"id":796,"url":"https://patchwork.libcamera.org/api/1.1/series/796/?format=json","web_url":"https://patchwork.libcamera.org/project/libcamera/list/?series=796","date":"2020-04-04T00:44:27","name":"Simple pipeline handler","version":4,"mbox":"https://patchwork.libcamera.org/series/796/mbox/"}],"comments":"https://patchwork.libcamera.org/api/covers/3377/comments/","headers":{"Return-Path":"<laurent.pinchart@ideasonboard.com>","Received":["from perceval.ideasonboard.com (perceval.ideasonboard.com\n\t[213.167.242.64])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id B499E605D1\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tSat,  4 Apr 2020 02:44:51 +0200 (CEST)","from pendragon.bb.dnainternet.fi (81-175-216-236.bb.dnainternet.fi\n\t[81.175.216.236])\n\tby perceval.ideasonboard.com (Postfix) with ESMTPSA id EDEFC321;\n\tSat,  4 Apr 2020 02:44:50 +0200 (CEST)"],"Authentication-Results":"lancelot.ideasonboard.com; dkim=pass (1024-bit key; \n\tunprotected) header.d=ideasonboard.com\n\theader.i=@ideasonboard.com\n\theader.b=\"DXirUb9w\"; dkim-atps=neutral","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com;\n\ts=mail; t=1585961091;\n\tbh=Y+nRbu7R6wgKaOzxNPmWZm9LuppCL0avS0XrtjJ88Xc=;\n\th=From:To:Cc:Subject:Date:From;\n\tb=DXirUb9wn18DOnP5DVirApd4vNyUIzc1xuUk1Sha5ci8k56SDh8EHju55XonobHpI\n\tpcwG2eNB9n2uHF+Do2B7R4ZcUFQXtVW34QCoWeArY7Im7YQtWOrygkzwK1zHt5sEpc\n\tglwM6/kiEs9v1VJAHu5NaKlHRfEYV8euut1xkTQM=","From":"Laurent Pinchart <laurent.pinchart@ideasonboard.com>","To":"libcamera-devel@lists.libcamera.org","Cc":"Martijn Braam <martijn@brixit.nl>,\n\tBenjamin GAIGNARD <benjamin.gaignard@st.com>,\n\tAndrey Konovalov <andrey.konovalov@linaro.org>","Date":"Sat,  4 Apr 2020 03:44:27 +0300","Message-Id":"<20200404004438.17992-1-laurent.pinchart@ideasonboard.com>","X-Mailer":"git-send-email 2.24.1","MIME-Version":"1.0","Content-Type":"text/plain; charset=UTF-8","Content-Transfer-Encoding":"8bit","Subject":"[libcamera-devel] [PATCH v4 00/11] Simple pipeline handler","X-BeenThere":"libcamera-devel@lists.libcamera.org","X-Mailman-Version":"2.1.29","Precedence":"list","List-Id":"<libcamera-devel.lists.libcamera.org>","List-Unsubscribe":"<https://lists.libcamera.org/options/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=unsubscribe>","List-Archive":"<https://lists.libcamera.org/pipermail/libcamera-devel/>","List-Post":"<mailto:libcamera-devel@lists.libcamera.org>","List-Help":"<mailto:libcamera-devel-request@lists.libcamera.org?subject=help>","List-Subscribe":"<https://lists.libcamera.org/listinfo/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=subscribe>","X-List-Received-Date":"Sat, 04 Apr 2020 00:44:52 -0000"},"content":"Hello,\n\nThis patch series builds on Martijn's work to implement a pipeline\nhandler for simpler pipelines. Additional information about the pipeline\nhandler itself can be found in patch 09/11.\n\nCompared to v3, this version only incorporates the review comments and\nhas been rebased on top of master, without major changes.\n\nPatch 01/11 adds a V4L2 API extension required for pipeline\nauto-configuration, and patches 02/11 to 08/11 add a new utility\nfunction and miscellaneous small extensions.\n\nPatch 09/11 adds the new simple pipeline handler, patch 10/11 the\nsimpler converter, and patch 11/11 integrates converter support into the\nsimple pipeline handler. The converter API hasn't changed and should\nstill be improved, it's currently a proof of concept. Other options also\nexist, such as making the simple pipeline handler a base class from\nwhich more specialized pipeline handlers could derive from, and\nimplement support for converters in device-specific code.\n\nThe code has been tested on an i.MX7 platform with a greyscale sensor\nand the i.MX PXP as format converter to produce RGB. I've kept sun6i-csi\nfrom Martijn's work in the list of supported drivers, but supporting\nthat platform will require extending the corresponding driver to support\nthe VIDIOC_ENUM_FMT extension. Once done, if all goes well, the platform\nshould work out of the box.\n\nAs before, this is meant to be compatible with the stm32 and qcom-camss\nthat pipeline handlers have previously been submitted for, although for\nqcom-camss the pipeline configuration is a bit more complex, and the\nbest strategy to move forward remains to be decided. The respective\ndrivers need be added to the drivers array in\nSimplePipelineHandler::match(), and, as for sun6i-csi, support for the\nVIDIOC_ENUM_FMT extension needs to be implemented in the drivers, which\nshould be fairly easy.\n\nLaurent Pinchart (10):\n  [DNI] include: linux: Extend VIDIOC_ENUM_FMT to support MC-centric\n    devices\n  libcamera: utils: Add string join function\n  libcamera: v4l2_subdevice: Extend [gs]etFormat() to specify format\n    type\n  libcamera: v4l2_subdevice: Don't use doxygen \\ref needlessly\n  libcamera: v4l2_videodevice: Support filtering formats by media bus\n    code\n  libcamera: v4l2_videodevice: Expose the device capabilities\n  libcamera: v4l2_videodevice: Downgrade 4CC conversion errors to\n    warnings\n  libcamera: v4l2_videodevice: Map V4L2_PIX_FMT_GREY to DRM FourCC\n  libcamera: pipeline: simple: Add simple format converter\n  libcamera: pipeline: simple: Integrate converter support\n\nMartijn Braam (1):\n  libcamera: pipeline: Add a simple pipeline handler\n\n include/linux/videodev2.h                   |   5 +-\n meson_options.txt                           |   2 +-\n src/libcamera/include/utils.h               |  44 +\n src/libcamera/include/v4l2_subdevice.h      |  11 +-\n src/libcamera/include/v4l2_videodevice.h    |   6 +-\n src/libcamera/pipeline/simple/converter.cpp | 213 +++++\n src/libcamera/pipeline/simple/converter.h   |  60 ++\n src/libcamera/pipeline/simple/meson.build   |   4 +\n src/libcamera/pipeline/simple/simple.cpp    | 877 ++++++++++++++++++++\n src/libcamera/utils.cpp                     |  16 +\n src/libcamera/v4l2_subdevice.cpp            |  28 +-\n src/libcamera/v4l2_videodevice.cpp          |  36 +-\n test/utils.cpp                              |  20 +-\n 13 files changed, 1303 insertions(+), 19 deletions(-)\n create mode 100644 src/libcamera/pipeline/simple/converter.cpp\n create mode 100644 src/libcamera/pipeline/simple/converter.h\n create mode 100644 src/libcamera/pipeline/simple/meson.build\n create mode 100644 src/libcamera/pipeline/simple/simple.cpp"}