Received: by 2002:a89:48b:0:b0:1f5:f2ab:c469 with SMTP id a11csp162649lqd; Tue, 23 Apr 2024 19:54:08 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWmH9UzGoVYaMR7l7O25+U3KsdhJ0tSDV6Qqi2afrqFcGz50W2OzfCmmglLPq6Wkcer3TgcMe8a4M+4RdK5DYpqJ9WiK3BX/OD85tsAcA== X-Google-Smtp-Source: AGHT+IFFCLnvITR5Fw9TJQ8FXb4FfEUuipdaYxLw738XGUcMkxYH+Tj6ZCNIqn+5NbaS3Ooa2UTW X-Received: by 2002:a05:6358:9797:b0:183:f62e:5d21 with SMTP id f23-20020a056358979700b00183f62e5d21mr987159rwb.7.1713927248339; Tue, 23 Apr 2024 19:54:08 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1713927248; cv=pass; d=google.com; s=arc-20160816; b=pCC2y7gjY/+Ww3qAdW9r2tPfHM/4JesvI8mpTbj0hudVTv431mlE/5cjMROVHwys7C 4THNVcoK3SuegOIvUen/w8wReBOGHEDwPF8M32uIkkTVtp2V5zO6ItlWj6zN7vpi2iXp oD9H1XRlcTlQtjS9tvs0H7VEIf3YgHRVRNKuzX07DxFLrBwHdKZVQtY30T4qV4eu0Px/ XAAVsWmEciQBJqbSn7NLM5Ehd3pNYhHOOgBqQInZtKVPwY5zpvTeQL4YkSB5DRIWpDmI lkt0LMs9N4Bb6HJFESiC4vcBgPoVuDS+fLvorw/xD6Hpt+P7UB3MqfM0gHubWHQjmXSB aECw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from; bh=FsbGQuRVDHQet/c+4QNC0z2zhJ5RZdVyVcXVp1oA+bQ=; fh=7QruN4gvYYHiIdU4Rq2L0pAC1/NGNbjzO3/t+wCm1Qk=; b=S5BbhAJf2FuCZqqNGVQhq9AxJ29G+Jo65C7SD6u1LkpHdJ62G2o3Qj2zRQgiwJrQfa gYKA9TXr8y9GVef038T32c7aOZbH4Rkm6BSPvXFhFdQXh7HGhh/VsRHeSbCGr6SodCHv /ntZWR4c1lwd3llaqP/z2xOzdSUtTEFPhWQy8oVVtAJMNq+O9v9FhhuWbT8pHDT08hUF ez7QmlyK+58Pl1Xme7qOkHW0UnNlL1QGUcFc0nBVT0z9lCucS54Xp4DCJBC9fLaG4AYE yGssPdyEmfC3EIEToNXYw2+RGKVkWIfuGmqtj9pZligvh729B03ZzEtsrNj6MXkaYTjC uO6A==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=toshiba.co.jp dmarc=pass fromdomain=toshiba.co.jp); spf=pass (google.com: domain of linux-kernel+bounces-156169-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-156169-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=toshiba.co.jp Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id e128-20020a636986000000b005cd7c92f504si10268017pgc.481.2024.04.23.19.54.07 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 23 Apr 2024 19:54:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-156169-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=toshiba.co.jp dmarc=pass fromdomain=toshiba.co.jp); spf=pass (google.com: domain of linux-kernel+bounces-156169-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-156169-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=toshiba.co.jp Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 70F21B23ADC for ; Wed, 24 Apr 2024 02:50:05 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 8C00C13F459; Wed, 24 Apr 2024 02:48:17 +0000 (UTC) Received: from mo-csw.securemx.jp (mo-csw1121.securemx.jp [210.130.202.132]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id E1974126F09; Wed, 24 Apr 2024 02:48:14 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=210.130.202.132 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713926896; cv=none; b=bf9zSVVu5bJAtdaiOlgiV/NsgbFgdTs8suF5DbtPR562O4WDYjPxrMuWo0GlMLX3O9UqKe8CK5ksoPSQqSUuRoLUO83fxFMmDF09WA14fU/a9got6JYw1iVZ08EjE7ZYuY9NlgqzDBwKwjohO+wOywyp3KLISYBLHc51c1Aj0QI= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713926896; c=relaxed/simple; bh=t2YMIeN4VFNeAV/ewWANWx3FcOb4SiqGQg7nearulGc=; h=From:To:Cc:Subject:Date:Message-Id:MIME-Version; b=dyoCnSJY8UGOLDa5Si1hHHKFksuYntNPDwh+k/ryTNrmxTi3PDseNLYVEJlkuW98Oay6iFSJU3QZuMyoDrKaFKtrysE9nnqfwzvnLAUqS6H3DoODsL0Ly9b+IpoEBCJzIdt8d5PF61Hx63eF0cQ80ubkd68wncHctxR/sVnjvpI= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=toshiba.co.jp; spf=pass smtp.mailfrom=toshiba.co.jp; arc=none smtp.client-ip=210.130.202.132 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=toshiba.co.jp Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=toshiba.co.jp Received: by mo-csw.securemx.jp (mx-mo-csw1121) id 43O2lYOR103201; Wed, 24 Apr 2024 11:47:35 +0900 X-Iguazu-Qid: 2rWhNMNebuq33UEeEk X-Iguazu-QSIG: v=2; s=0; t=1713926854; q=2rWhNMNebuq33UEeEk; m=MtG2up2gxYnjxQKZ3UHEUoLgl4Hx9DIPOiOd24TsaiM= Received: from imx2-a.toshiba.co.jp (imx2-a.toshiba.co.jp [106.186.93.35]) by relay.securemx.jp (mx-mr1123) id 43O2lWEe186609 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT); Wed, 24 Apr 2024 11:47:33 +0900 X-SA-MID: 21956130 From: Yuji Ishikawa To: Hans Verkuil , Laurent Pinchart , Mauro Carvalho Chehab , Rob Herring , Krzysztof Kozlowski , Conor Dooley , "Rafael J . Wysocki" , Nobuhiro Iwamatsu , Yuji Ishikawa Cc: linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v10 0/6] Add Toshiba Visconti Video Input Interface driver Date: Wed, 24 Apr 2024 11:42:09 +0900 X-TSB-HOP2: ON Message-Id: <20240424024215.1624299-1-yuji2.ishikawa@toshiba.co.jp> X-Mailer: git-send-email 2.34.1 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit This series is the Video Input Interface driver for Toshiba's ARM SoC, Visconti. This provides DT binding documentation, device driver, documentation and MAINTAINER files. A visconti VIIF driver instance exposes 1 media control device file, 3 video device files for capture and 2 video device files for controlling image signal processor. Detailed HW/SW are described in documentation directory. The VIIF hardware has CSI2 receiver, image signal processor and DMAC inside. The subdevice for image signal processor provides vendor specific V4L2 controls. The device driver depends on two other drivers under development; clock framework driver and IOMMU driver. Corresponding features will be added later. Best regards, Yuji Changelog v2: - Resend v1 because a patch exceeds size limit. Changelog v3: - Add documentation to describe SW and HW - Adapted to media control framework - Introduced ISP subdevice, capture device - Remove private IOCTLs and add vendor specific V4L2 controls - Change function name avoiding camelcase and uppercase letters Changelog v4: - Split patches because a patch exceeds size limit - fix dt-bindings document - stop specifying ID numbers for driver instance explicitly at device tree - use pm_runtime to trigger initialization of HW along with open/close of device files. - add a entry for a header file at MAINTAINERS file Changelog v5: - Fix coding style problem in viif.c (patch 2/6) Changelog v6: - add register definition of BUS-IF and MPU in dt-bindings - add CSI2RX subdevice (separeted from ISP subdevice) - change directory layout (moved to media/platform/toshiba/visconti) - change source file layout (removed hwd_xxxx.c) - pointer to userland memory is removed from uAPI parameters - change register access (from struct style to macro style) - remove unused macros Changelog v7: - remove redundant "bindings" from header and description text - fix multiline text of "description" - change "compatible" to "visconti5-viif" - explicitly define allowed properties for port::endpoint - remove unused variables - update kerneldoc comments - update references to headers Changelog v8: - rename bindings description file - remove/simplify items in bindings - update operations around v4l2_async_notifier - use v4l2_async_connection instead of v4l2_async_subdev - use dev_err_probe() - better error handling at probe - remove redundant mutex - add V4L2_CTRL_TYPE_VISCONTI_ISP constant Changelog v9: - dictionary ordering of dt-bindings properties - applied sparce checker - call div64_u64 for 64bit division - rebase to media_staging tree - fix warning for cast between ptr and dma_addr_t Changelog v10: - add an independent entry in MAINTAINERS - add paddings to uAPI structs - use parameter buffer to control ISP (instead of vendor specific controls) Yuji Ishikawa (6): dt-bindings: media: platform: visconti: Add Toshiba Visconti Video Input Interface media: videodev2.h: add visconti viif meta buffer format media: platform: visconti: Add Toshiba Visconti Video Input Interface driver media: platform: visconti: add streaming interface for ISP parameters and status documentation: media: add documentation for Toshiba Visconti Video Input Interface driver MAINTAINERS: Add entries for Toshiba Visconti Video Input Interface .../admin-guide/media/v4l-drivers.rst | 1 + .../admin-guide/media/visconti-viif.dot | 18 + .../admin-guide/media/visconti-viif.rst | 252 ++ .../media/toshiba,visconti5-viif.yaml | 105 + .../userspace-api/media/v4l/meta-formats.rst | 1 + .../media/v4l/metafmt-visconti-viif.rst | 48 + MAINTAINERS | 11 + drivers/media/platform/Kconfig | 1 + drivers/media/platform/Makefile | 1 + drivers/media/platform/toshiba/Kconfig | 6 + drivers/media/platform/toshiba/Makefile | 2 + .../media/platform/toshiba/visconti/Kconfig | 19 + .../media/platform/toshiba/visconti/Makefile | 8 + .../media/platform/toshiba/visconti/viif.c | 664 ++++++ .../media/platform/toshiba/visconti/viif.h | 398 ++++ .../platform/toshiba/visconti/viif_capture.c | 1472 ++++++++++++ .../platform/toshiba/visconti/viif_capture.h | 22 + .../platform/toshiba/visconti/viif_common.c | 239 ++ .../platform/toshiba/visconti/viif_common.h | 40 + .../platform/toshiba/visconti/viif_csi2rx.c | 657 ++++++ .../platform/toshiba/visconti/viif_csi2rx.h | 24 + .../toshiba/visconti/viif_csi2rx_regs.h | 102 + .../platform/toshiba/visconti/viif_isp.c | 1191 ++++++++++ .../platform/toshiba/visconti/viif_isp.h | 24 + .../platform/toshiba/visconti/viif_params.c | 2026 +++++++++++++++++ .../platform/toshiba/visconti/viif_params.h | 19 + .../platform/toshiba/visconti/viif_regs.h | 721 ++++++ .../platform/toshiba/visconti/viif_stats.c | 334 +++ .../platform/toshiba/visconti/viif_stats.h | 14 + include/uapi/linux/videodev2.h | 4 + include/uapi/linux/visconti_viif.h | 1921 ++++++++++++++++ 31 files changed, 10345 insertions(+) create mode 100644 Documentation/admin-guide/media/visconti-viif.dot create mode 100644 Documentation/admin-guide/media/visconti-viif.rst create mode 100644 Documentation/devicetree/bindings/media/toshiba,visconti5-viif.yaml create mode 100644 Documentation/userspace-api/media/v4l/metafmt-visconti-viif.rst create mode 100644 drivers/media/platform/toshiba/Kconfig create mode 100644 drivers/media/platform/toshiba/Makefile create mode 100644 drivers/media/platform/toshiba/visconti/Kconfig create mode 100644 drivers/media/platform/toshiba/visconti/Makefile create mode 100644 drivers/media/platform/toshiba/visconti/viif.c create mode 100644 drivers/media/platform/toshiba/visconti/viif.h create mode 100644 drivers/media/platform/toshiba/visconti/viif_capture.c create mode 100644 drivers/media/platform/toshiba/visconti/viif_capture.h create mode 100644 drivers/media/platform/toshiba/visconti/viif_common.c create mode 100644 drivers/media/platform/toshiba/visconti/viif_common.h create mode 100644 drivers/media/platform/toshiba/visconti/viif_csi2rx.c create mode 100644 drivers/media/platform/toshiba/visconti/viif_csi2rx.h create mode 100644 drivers/media/platform/toshiba/visconti/viif_csi2rx_regs.h create mode 100644 drivers/media/platform/toshiba/visconti/viif_isp.c create mode 100644 drivers/media/platform/toshiba/visconti/viif_isp.h create mode 100644 drivers/media/platform/toshiba/visconti/viif_params.c create mode 100644 drivers/media/platform/toshiba/visconti/viif_params.h create mode 100644 drivers/media/platform/toshiba/visconti/viif_regs.h create mode 100644 drivers/media/platform/toshiba/visconti/viif_stats.c create mode 100644 drivers/media/platform/toshiba/visconti/viif_stats.h create mode 100644 include/uapi/linux/visconti_viif.h -- 2.25.1