Received: by 2002:a05:7412:b101:b0:e2:908c:2ebd with SMTP id az1csp3196830rdb; Thu, 16 Nov 2023 03:05:38 -0800 (PST) X-Google-Smtp-Source: AGHT+IEcvegXfyeMvWnWdFZtqlbHFutJ6R90orQ8rmKJADaUwAeK6fBT3Fz0Obmn6HPkq6QW6Evd X-Received: by 2002:a17:90b:3b52:b0:280:c576:31bc with SMTP id ot18-20020a17090b3b5200b00280c57631bcmr14184048pjb.32.1700132738230; Thu, 16 Nov 2023 03:05:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700132738; cv=none; d=google.com; s=arc-20160816; b=0AmQSqZgXouhnSu9++vCO0FW41R1fjmLCsrYk43lH5V3Vh/+8a6F8Itdeh0Wo85Ju0 EktqoEKwC4NP3Jrhi5mrFu0cukMLPWTjXFs5XZ7+MYA471uX/j+C+IARRVIkV0GsvmdH harVJLsfNbbPZ8RXdMn76KOeuq5mhmjkQ3C1qmFd128EF5bHqIR/JrvhPgCk6U9BkpKa tsqkdhLB4xDid/PS5+X3XdD2eEFLu1pUSdWQBd+r27CzyW3rK6r1MMpwdDP6yv7Lm85i YOk4AwgA2PEPTQrCx3ud9SchNPyWVC7hz9XxTq+DkGv+NNAdfVp670ZU7iV9Pkaa/bDJ ySZQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=wRYDFN7LQPSgDuJub9iN8vSh9Owhba100B3Esv1HkRY=; fh=/sUFM3LIRLscnjlLfpf1Icbv7aS2VHkc5345TYI64Ck=; b=oA4dQVLUXE1vELbJyqS4RJfaavuSU7SF5dCUaPswwUXdNNBbwvmRPJdD5Cl7MpaiqS clnMibfkUvHOqT5OIiTyBfOsTE1wPbvZJ0nCaKPwPxGMxkebhH/biCAsmL5AqYWcjJBW D7piZV/zX2ImmDnLbKrhJfdmKoLI26zy06WoyP96u+5pJB8IuIF39J1PY2Ot4Dig6P6Y VwpKAkbe+FClWAQjbnhDhRYUCx3jr2rSK6pC716iJTWeUSZDqiM3Isuk/YldZUI44jWe /56mRp8jkRnB/Q4WoF9kf6ef+QHSP3mYBrBvREEwuyBG6SZbV8JXGsHsfiP506ayxlAA ARCg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b="WP+Dwy7/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Return-Path: Received: from fry.vger.email (fry.vger.email. [23.128.96.38]) by mx.google.com with ESMTPS id w6-20020a17090aad4600b0027d0b9c0b90si1753511pjv.153.2023.11.16.03.05.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 16 Nov 2023 03:05:38 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) client-ip=23.128.96.38; Authentication-Results: mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b="WP+Dwy7/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id 5352781C09B5; Thu, 16 Nov 2023 03:05:14 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344985AbjKPLEx (ORCPT + 99 others); Thu, 16 Nov 2023 06:04:53 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60802 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230193AbjKPLEv (ORCPT ); Thu, 16 Nov 2023 06:04:51 -0500 Received: from relay1-d.mail.gandi.net (relay1-d.mail.gandi.net [IPv6:2001:4b98:dc4:8::221]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8137185; Thu, 16 Nov 2023 03:04:45 -0800 (PST) Received: by mail.gandi.net (Postfix) with ESMTPSA id 41DAE240003; Thu, 16 Nov 2023 11:04:43 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bootlin.com; s=gm1; t=1700132684; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding; bh=wRYDFN7LQPSgDuJub9iN8vSh9Owhba100B3Esv1HkRY=; b=WP+Dwy7/01e6/1st6HlcpzS2jlUpo2z+Q1ikCC5iFBv2ISVtPt7I1Ia6w1N0xIWpeNaacg u9nFmy3cQ6qee/EsJ5snVnRPA0Bys6absVyYJEM0TSQR/NPfkpoPE0YdYsfvxT6lbnJ91y H+X/LMjQTwgvYs9ko6CVqwxFPMW04HRQP32kFDYz3P/8BwqMatGj4zbQ/p3d80mYqBUeNK x8YPhGA7r9dhqVrBrYf3VDniAU5uqklTFP4nQR3LgX3wUQv1F3eAhlxDExMuy/V0BUN7Gu XuRIsXMKVReBM++Mq13CxkBn0D1Or4qNg2c7GilsXBp1ka/vkmorX0juFBCGvQ== From: Mehdi Djait To: mchehab@kernel.org, heiko@sntech.de, hverkuil-cisco@xs4all.nl, krzysztof.kozlowski+dt@linaro.org, robh+dt@kernel.org, conor+dt@kernel.org Cc: linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, thomas.petazzoni@bootlin.com, alexandre.belloni@bootlin.com, maxime.chevallier@bootlin.com, paul.kocialkowski@bootlin.com, michael.riesch@wolfvision.net, Mehdi Djait Subject: [PATCH v11 0/3] media: rockchip: Add a driver for Rockchip's camera interface Date: Thu, 16 Nov 2023 12:04:37 +0100 Message-ID: X-Mailer: git-send-email 2.41.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-GND-Sasl: mehdi.djait@bootlin.com X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Thu, 16 Nov 2023 03:05:14 -0800 (PST) Hello everyone, V11 for basic support of the Camera Interface found on the Rockchip PX30 SoC Most of this driver was written following the BSP driver from rockchip, removing the parts that either didn't fit correctly the guidelines, or that couldn't be tested. In the BSP, this driver is known as the "cif" driver, but this controller was renamed to "vip" in the datasheet. This version of the driver supports ONLY the parallel interface BT656 and was tested/implemented using an SDTV video decoder. media_tree, base-commit: 3e238417254bfdcc23fe207780b59cbb08656762 V10 => V11: cif/capture.c cif/dev.c cif/common.h cif/capture.h: - removed the csi_fmt_val and all the CSI reg defines - removed the setting of buffer numbers in the queue_setup vb2_ops callback - changed the v4l2_fwnode_endpoint declaration to V4L2_MBUS_UNKNOWN: letting the device tree decide which bus is being used - split dev.h into common.h and capture.h rockchip,px30-vip.yaml: - renamed rockchip,rk3066-cif.yaml back to rockchip,px30-vip.yaml as suggested by Conor - added the description of the port's endpoint bus-type property - extended the example to include the definition of the corresponding video-decoder V9 => V10: cif/capture.c cif/dev.c cif/dev.h: as suggested by Paul: - ensured that the lock is still being held when accessing stream->buffs[0,1] - adjusted the comment explaining why the spinlock is used as suggested by Michael: - made the IRQ requested SHARED: the cif shares the IRQ with the io_mmu rockchip,rk3066-cif.yaml: - dropped the rk3066-cif compatible but kept the name and added the reason for this in the commit msg: the name of the file rk3066 is the first Rockchip SoC generation that uses cif instead of the px30 which is just one of the many iterations of the unit. V8 => V9: cif/capture.c cif/dev.c cif/dev.h: as suggested by Paul: - changed the name from "vip" back to "cif" - removed the scratch buffer and added frame dropping - removed mplane, only single plane formats are supported anyway - adjusted the Kconfig - added the match_data to the stream struct - some cosmetics, and error return codes changes as suggested by Michael: - changed the writel and readl helpers to be inline functions and changed the name - fixed typos in the commit message - changed the cif_device struct element "sensor" to "remote" rockchip,rk3066-cif.yaml: - changed the compatible rockchip,px30-vip to rockchip,rk3066-cif: rk3066 is the earliest Rockchip SoC that uses cif and it is the first model starting the RK30 lineup. - changed the node name to video-capture - adjusted the description V7 => V8: vip/capture.c: - fixed a warning: unused variable reported by the kernel test robot V6 => V7: vip/capture.c vip/dev.c vip/dev.h - renamed all struct rk_vip_dev dev => struct rk_vip_dev vip_dev - added some error when rk_vip_get_buffer() returns NULL - removed a WARN_ON - made the irq NOT shared - dropped of_match_ptr - added the rk_vip_get_resource() function rockchip,px30-vip.yaml: - changed filename to match the compatible - dropped the mention of the other rockchip SoC in the dt-binding description and added a more detailed description of VIP - removed unused labels in the example V5[1] => V6: vip/capture.c vip/dev.c vip/dev.h - added a video g_input_status subdev call, V4L2_IN_CAP_STD and the supported stds in rk_vip_enum_input callback - added rk_vip_g_std, rk_vip_s_std and rk_vip_querystd callbacks - added the supported video_device->tvnorms - s_std will now update the format as this depends on the standard NTSC/PAL (as suggested by Hans in [1]) - removed STD_ATSC - moved the colorimetry information to come from the subdev - removed the core s_power subdev calls - dropped cropping in rk_vip_stream struct rockchip-vip.yaml: - fixed a mistake in the name of third clock plckin -> plck - changed the reg maxItems 2 -> 1 [1] https://lore.kernel.org/linux-media/20201229161724.511102-1-maxime.chevallier@bootlin.com/ I used v4l-utils with HEAD: commit 3d6682746de535d1f7aa71b43a30af40d52a539c # v4l2-compliance v4l2-compliance 1.25.0, 64 bits, 64-bit time_t Compliance test for rockchip-cif device /dev/video0: Driver Info: Driver name : rockchip-cif Card type : rockchip-cif Bus info : platform:ff490000.video-capture Driver version : 6.6.0 Capabilities : 0x84200001 Video Capture Streaming Extended Pix Format Device Capabilities Device Caps : 0x04200001 Video Capture Streaming Extended Pix Format Media Driver Info: Driver name : rockchip-cif Model : cif Serial : Bus info : platform:ff490000.video-capture Media version : 6.6.0 Hardware revision: 0x00000000 (0) Driver version : 6.6.0 Interface Info: ID : 0x03000003 Type : V4L Video Entity Info: ID : 0x00000001 (1) Name : rockchip_cif Function : V4L2 I/O Pad 0x01000002 : 0: Sink Link 0x02000009: from remote pad 0x1000006 of entity 'tw9900 2-0044' (Digital Video Decoder): Data, Enabled Required ioctls: test MC information (see 'Media Driver Info' above): OK test VIDIOC_QUERYCAP: OK test invalid ioctls: OK Allow for multiple opens: test second /dev/video0 open: OK test VIDIOC_QUERYCAP: OK test VIDIOC_G/S_PRIORITY: OK test for unlimited opens: OK Debug ioctls: test VIDIOC_DBG_G/S_REGISTER: OK (Not Supported) test VIDIOC_LOG_STATUS: OK (Not Supported) Input ioctls: test VIDIOC_G/S_TUNER/ENUM_FREQ_BANDS: OK (Not Supported) test VIDIOC_G/S_FREQUENCY: OK (Not Supported) test VIDIOC_S_HW_FREQ_SEEK: OK (Not Supported) test VIDIOC_ENUMAUDIO: OK (Not Supported) test VIDIOC_G/S/ENUMINPUT: OK test VIDIOC_G/S_AUDIO: OK (Not Supported) Inputs: 1 Audio Inputs: 0 Tuners: 0 Output ioctls: test VIDIOC_G/S_MODULATOR: OK (Not Supported) test VIDIOC_G/S_FREQUENCY: OK (Not Supported) test VIDIOC_ENUMAUDOUT: OK (Not Supported) test VIDIOC_G/S/ENUMOUTPUT: OK (Not Supported) test VIDIOC_G/S_AUDOUT: OK (Not Supported) Outputs: 0 Audio Outputs: 0 Modulators: 0 Input/Output configuration ioctls: test VIDIOC_ENUM/G/S/QUERY_STD: OK test VIDIOC_ENUM/G/S/QUERY_DV_TIMINGS: OK (Not Supported) test VIDIOC_DV_TIMINGS_CAP: OK (Not Supported) test VIDIOC_G/S_EDID: OK (Not Supported) Control ioctls (Input 0): test VIDIOC_QUERY_EXT_CTRL/QUERYMENU: OK (Not Supported) test VIDIOC_QUERYCTRL: OK (Not Supported) test VIDIOC_G/S_CTRL: OK (Not Supported) test VIDIOC_G/S/TRY_EXT_CTRLS: OK (Not Supported) test VIDIOC_(UN)SUBSCRIBE_EVENT/DQEVENT: OK (Not Supported) test VIDIOC_G/S_JPEGCOMP: OK (Not Supported) Standard Controls: 0 Private Controls: 0 Format ioctls (Input 0): test VIDIOC_ENUM_FMT/FRAMESIZES/FRAMEINTERVALS: OK test VIDIOC_G/S_PARM: OK (Not Supported) test VIDIOC_G_FBUF: OK (Not Supported) test VIDIOC_G_FMT: OK test VIDIOC_TRY_FMT: OK test VIDIOC_S_FMT: OK test VIDIOC_G_SLICED_VBI_CAP: OK (Not Supported) test Cropping: OK (Not Supported) test Composing: OK (Not Supported) test Scaling: OK (Not Supported) Codec ioctls (Input 0): test VIDIOC_(TRY_)ENCODER_CMD: OK (Not Supported) test VIDIOC_G_ENC_INDEX: OK (Not Supported) test VIDIOC_(TRY_)DECODER_CMD: OK (Not Supported) Buffer ioctls (Input 0): test VIDIOC_REQBUFS/CREATE_BUFS/QUERYBUF: OK test VIDIOC_EXPBUF: OK test Requests: OK (Not Supported) Total for rockchip-cif device /dev/video0: 46, Succeeded: 46, Failed: 0, Warnings: 0 Mehdi Djait (3): media: dt-bindings: media: add bindings for Rockchip CIF media: rockchip: Add a driver for Rockchip's camera interface arm64: dts: rockchip: Add the camera interface .../bindings/media/rockchip,px30-vip.yaml | 173 +++ MAINTAINERS | 7 + arch/arm64/boot/dts/rockchip/px30.dtsi | 12 + drivers/media/platform/rockchip/Kconfig | 1 + drivers/media/platform/rockchip/Makefile | 1 + drivers/media/platform/rockchip/cif/Kconfig | 13 + drivers/media/platform/rockchip/cif/Makefile | 3 + drivers/media/platform/rockchip/cif/capture.c | 1120 +++++++++++++++++ drivers/media/platform/rockchip/cif/capture.h | 21 + drivers/media/platform/rockchip/cif/common.h | 129 ++ drivers/media/platform/rockchip/cif/dev.c | 302 +++++ drivers/media/platform/rockchip/cif/regs.h | 127 ++ 12 files changed, 1909 insertions(+) create mode 100644 Documentation/devicetree/bindings/media/rockchip,px30-vip.yaml create mode 100644 drivers/media/platform/rockchip/cif/Kconfig create mode 100644 drivers/media/platform/rockchip/cif/Makefile create mode 100644 drivers/media/platform/rockchip/cif/capture.c create mode 100644 drivers/media/platform/rockchip/cif/capture.h create mode 100644 drivers/media/platform/rockchip/cif/common.h create mode 100644 drivers/media/platform/rockchip/cif/dev.c create mode 100644 drivers/media/platform/rockchip/cif/regs.h -- 2.41.0