From patchwork Fri May 31 08:06:59 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jacopo Mondi X-Patchwork-Id: 800771 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 89503745F4 for ; Fri, 31 May 2024 08:07:33 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=213.167.242.64 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1717142855; cv=none; b=OG48wHY+Kf9TNVpd4KXmb8HqzqCV0q7eDrDnyikcwfiTiOOkjr/0/iqfatUkMKX7MzWZzPwyVR91Wftepcqb5nzCqS4J7t0RmL9f3zzmtIxtC+DRBTyOAgWoJT8/FAFzlWbB7N/9Z32GFcAMNROilQTuveojC1WS8j2oLlBXOI4= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1717142855; c=relaxed/simple; bh=hUaQgmAWlR/6odRzsIvRD4jwwoSmwwnzttofpewJ9tA=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=O/12HzsecWq9m9YWXjuCIAaKJjdk+E+QBpYIFdP/lxwSGJO1S2Jr5KZNiVEBetcGLv6WEES3/8J8tFi8DJzPynihxVCY39TDu56tHMSRbOEVyyjdLcQu5UUmpP6c/go0u8dYhHRf8iHNLMVQCdgyvPE5OjBcmz39rAGtWtb51lM= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ideasonboard.com; spf=pass smtp.mailfrom=ideasonboard.com; dkim=pass (1024-bit key) header.d=ideasonboard.com header.i=@ideasonboard.com header.b=e6HX3Seo; arc=none smtp.client-ip=213.167.242.64 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ideasonboard.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ideasonboard.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=ideasonboard.com header.i=@ideasonboard.com header.b="e6HX3Seo" Received: from localhost.localdomain (93-61-96-190.ip145.fastwebnet.it [93.61.96.190]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 80852A06; Fri, 31 May 2024 10:07:25 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1717142846; bh=hUaQgmAWlR/6odRzsIvRD4jwwoSmwwnzttofpewJ9tA=; h=From:To:Cc:Subject:Date:From; b=e6HX3Seo/pn8i6W3F5wLawZhbiTz4TN7Dyb/Bk3w+34dLCjJBkkFOPOF8JFEUaTT6 MnLsKb547A+H85wQO7pvSGHPRLCBGz67XVcKrEVfRvxN0MEhiW6L5+/7udDLNAgHW5 2o/+ytOvk10ULxz8Dh2/uwm+lOyQgDP5AVrZx18M= From: Jacopo Mondi To: Linux Media Mailing List Cc: Jacopo Mondi , David Plowman , Naushir Patuck , Nick Hollinghurst , Dave Stevenson , Tomi Valkeinen , Laurent Pinchart , Kieran Bingham , Sakari Ailus , Hans Verkuil , Mauro Carvalho Chehab Subject: [PATCH v9 0/8] media: raspberrypi: Add support for PiSP Back End Date: Fri, 31 May 2024 10:06:59 +0200 Message-ID: <20240531080707.34568-1-jacopo.mondi@ideasonboard.com> X-Mailer: git-send-email 2.45.1 Precedence: bulk X-Mailing-List: linux-media@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 v8->v9: - Remove reference to multiple contexts from the admin guide as suggested by Nick - Fix the compressed RAW format description as suggested by Nick v7->v8: - Remove multiple-contexts and remove `struct pispbe_node_group` - Address Sakari's style comments - Remove CONFIG_PM dependency v6->v7: - Introduce uAPI headers earlier in the series to document them - kernel-doc uAPI types in pisp_be_config.h - Link pisp_be_config.h kernel documentation in metafmt documentation v5->v6: - minor updates If no further comments, I think the series is ready to be collected (for v6.11) v5->v6: - Rebase on recent media_stage master branch - Remove Y12 and Y14 formats as they have upstreamed already - Squash in patch from Naush from https://github.com/raspberrypi/linux/pull/6140 v4->v5: - Address Sakari's style comments on the driver - Add Naush's tags v3->v4: - Rename the compressed RAW formats and change the page title - Minor fixes to the RGB48 documentation - Remove the clock name from bindings and driver v2->v3: - Expand documentation of RGB48 formats - Add back to the bindings the 'aclk' clock-names property - Explicitly get the clock by name in the driver - minor fixes v1->v2: - Add Y12P and Y14P formats to yuv-luma.rst instead of documenting them separately - Fix typos in formats and documentation - Adjust bindings as suggested during review - Fix admin-guide with an up-to-media media graph (remove the HOG node) - Add a patch to the driver to safely clean-up the video devices buffer queues in case of errors https://github.com/raspberrypi/linux/commit/9fcfb8ee070ecc2ca9b4fcf4629c4545f9cf178e Add support for the Raspberry Pi PiSP Back End memory-2-memory ISP. Documentation available at: https://datasheets.raspberrypi.com/camera/raspberry-pi-image-signal-processor-specification.pdf The PiSP Back End is the memory-2-memory ISP found on Raspberry Pi 5. In conjunction with the PiSP Front End, for which a driver is expected to hit mainline in the next weeks, it implements the Raspberry Pi 5 camera system. The ISP is fully supported in the Raspberry Pi libcamera version and once patches for the PiSP Front End will hit mainline the support will land in mainline libcamera as well. Patch based on media-stage master branch. A branch is available at git://git.kernel.org/pub/scm/linux/kernel/git/jmondi/linux.git #pispbe/media-staging/be-upstream-v8 -------------------- Hans' build scripts build summary ------------------------ date: Tue May 28 16:25:12 CEST 2024 media-tree git repo: git://git.kernel.org/pub/scm/linux/kernel/git/jmondi/linux.git media-tree git branch: jmondi/pispbe/media-staging/be-upstream-v8 media-tree git hash: 009fac2170dd037c036a95787175562bf5186e13 v4l-utils git hash: 4a6a3725dd192759c2998311b00440b84c60df57 edid-decode git hash: 5f723267e04deb3aa9610483514a02bcee10d9c2 gcc version: i686-linux-gcc (GCC) 13.1.0 ccache version: ccache version 4.7.5 smatch/sparse repo: git://repo.or.cz/smatch.git smatch version: v0.5.0-8639-gff1cc4d4 sparse version: v0.5.0-8639-gff1cc4d4 build-scripts repo: https://git.linuxtv.org/hverkuil/build-scripts.git build-scripts git hash: 745fc7cf5ba1a1a841374c61e8470852232584c1 host hardware: x86_64 host os: 6.1.0-18-amd64 linux-git-arm: OK linux-git-powerpc64: OK linux-git-arm64: OK linux-git-i686: OK linux-git-x86_64: OK no-acpi.config: OK no-of.config: OK no-pm.config: OK no-pm-sleep.config: OK no-debug-fs.config: OK sparse: OK smatch: WARNINGS: drivers/media/pci/ivtv/ivtv-driver.c:1296 ivtv_probe() warn: 'itv->dec_mem' from ioremap() not released on lines: 1296. drivers/media/pci/ivtv/ivtv-driver.c:1296 ivtv_probe() warn: 'itv->enc_mem' from ioremap() not released on lines: 1296. COMPILE_TEST: WARNINGS: VIDEO_INTEL_IPU6 strcpy/strncpy/strlcpy: OK abi-compliance: ABI OK pahole: ABI OK spec-git: OK kerneldoc: OK date: Tue May 28 17:31:58 CEST 2024 ------------------------------------------------------------------------------- --------------------------- V4L2 compliance ----------------------------------- v4l2-compliance 1.27.0-5208, 64 bits, 64-bit time_t v4l2-compliance SHA: b13cb2cdedb2 2024-05-28 08:52:30 Compliance test for pispbe device /dev/video0: Total for pispbe device /dev/video4: 48, Succeeded: 48, Failed: 0, Warnings: 0 Compliance test for pispbe device /dev/video1: Total for pispbe device /dev/video4: 48, Succeeded: 48, Failed: 0, Warnings: 0 Compliance test for pispbe device /dev/video2: Total for pispbe device /dev/video4: 48, Succeeded: 48, Failed: 0, Warnings: 0 Compliance test for pispbe device /dev/video3: Total for pispbe device /dev/video4: 48, Succeeded: 48, Failed: 0, Warnings: 0 Compliance test for pispbe device /dev/video4: Total for pispbe device /dev/video4: 48, Succeeded: 48, Failed: 0, Warnings: 0 Compliance test for pispbe device /dev/video5: Total for pispbe device /dev/video0: 48, Succeeded: 48, Failed: 0, Warnings: 0 Compliance test for pispbe device /dev/video6: Total for pispbe device /dev/video0: 48, Succeeded: 48, Failed: 0, Warnings: 0 Compliance test for pispbe device /dev/video7: Total for pispbe device /dev/video0: 48, Succeeded: 48, Failed: 0, Warnings: 0 ------------------------------------------------------------------------------- Jacopo Mondi (7): media: uapi: pixfmt-luma: Document MIPI CSI-2 packing media: uapi: Add a pixel format for BGR48 and RGB48 media: uapi: Add Raspberry Pi PiSP Back End uAPI media: uapi: Add meta pixel format for PiSP BE config media: uapi: Add PiSP Compressed RAW Bayer formats media: dt-bindings: Add bindings for Raspberry Pi PiSP Back End media: admin-guide: Document the Raspberry Pi PiSP BE Naushir Patuck (1): media: raspberrypi: Add support for PiSP BE .../admin-guide/media/raspberrypi-pisp-be.dot | 20 + .../admin-guide/media/raspberrypi-pisp-be.rst | 109 + .../admin-guide/media/v4l-drivers.rst | 1 + .../bindings/media/raspberrypi,pispbe.yaml | 63 + .../userspace-api/media/v4l/meta-formats.rst | 1 + .../media/v4l/metafmt-pisp-be.rst | 56 + .../userspace-api/media/v4l/pixfmt-bayer.rst | 1 + .../userspace-api/media/v4l/pixfmt-rgb.rst | 54 + .../media/v4l/pixfmt-srggb8-pisp-comp.rst | 74 + .../media/v4l/pixfmt-yuv-luma.rst | 4 + MAINTAINERS | 9 + drivers/media/platform/Kconfig | 1 + drivers/media/platform/Makefile | 1 + drivers/media/platform/raspberrypi/Kconfig | 5 + drivers/media/platform/raspberrypi/Makefile | 3 + .../platform/raspberrypi/pisp_be/Kconfig | 12 + .../platform/raspberrypi/pisp_be/Makefile | 6 + .../platform/raspberrypi/pisp_be/pisp_be.c | 1809 +++++++++++++++++ .../raspberrypi/pisp_be/pisp_be_formats.h | 519 +++++ drivers/media/v4l2-core/v4l2-common.c | 2 + drivers/media/v4l2-core/v4l2-ioctl.c | 13 + .../linux/media/raspberrypi/pisp_be_config.h | 927 +++++++++ .../linux/media/raspberrypi/pisp_common.h | 199 ++ include/uapi/linux/videodev2.h | 17 + 24 files changed, 3906 insertions(+) create mode 100644 Documentation/admin-guide/media/raspberrypi-pisp-be.dot create mode 100644 Documentation/admin-guide/media/raspberrypi-pisp-be.rst create mode 100644 Documentation/devicetree/bindings/media/raspberrypi,pispbe.yaml create mode 100644 Documentation/userspace-api/media/v4l/metafmt-pisp-be.rst create mode 100644 Documentation/userspace-api/media/v4l/pixfmt-srggb8-pisp-comp.rst create mode 100644 drivers/media/platform/raspberrypi/Kconfig create mode 100644 drivers/media/platform/raspberrypi/Makefile create mode 100644 drivers/media/platform/raspberrypi/pisp_be/Kconfig create mode 100644 drivers/media/platform/raspberrypi/pisp_be/Makefile create mode 100644 drivers/media/platform/raspberrypi/pisp_be/pisp_be.c create mode 100644 drivers/media/platform/raspberrypi/pisp_be/pisp_be_formats.h create mode 100644 include/uapi/linux/media/raspberrypi/pisp_be_config.h create mode 100644 include/uapi/linux/media/raspberrypi/pisp_common.h --- 2.45.1