Received: by 2002:a05:6500:1b45:b0:1f5:f2ab:c469 with SMTP id cz5csp1298693lqb; Thu, 18 Apr 2024 06:12:17 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVO98oOluSLoAqQxtii7yNsPcAjUXHr4CKK25omGdpd6cz6HyOUJokLjXHVrieV/rO09/6+K6e2JZ32rWXEA6fXRMa371ztMnC6/qKENg== X-Google-Smtp-Source: AGHT+IEoVhBFassP0fJVi6tLPxRH27cRQo+/hkLPAJzvtCFDy5bpHYHzGQU+N7EPt0tifzQhedUy X-Received: by 2002:a17:90a:b293:b0:2a4:833f:2c1b with SMTP id c19-20020a17090ab29300b002a4833f2c1bmr2793602pjr.9.1713445937378; Thu, 18 Apr 2024 06:12:17 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1713445937; cv=pass; d=google.com; s=arc-20160816; b=dtaB9zGuvcNhTn86S5jKRgGsNPeH+/mTAXX+tFyf0mPPS2/5ubR5fuhatjv3on9iNm RnTxE4i4ZvX6Bxf1WbRAeAyrsmKhozz51h8aVwqJlxtFDnSixuT7dWNo1Vb48DTQ8qVN zsCaNn+K3mvRsxFOtGoP8czsPtjqN1TFtA8WIzOrF8e5jEn0vQH3stmavOMq2qUGP/uT B3V7nYOWgMQFkJ+95o95rRObE1E1P9NFVhXpCwLbMdaly+8V0g9ww+c5AbEPoxUMbXKN N5Tyc08I0FPZ7HmArO+nJiTwD55AIdd2RX/PH0ppDXpXBKwQ1jddYyi3ZLB88d2lASOI Bz6g== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-disposition:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:message-id:subject:cc :to:from:date:dkim-signature; bh=tMLA+lG99HJ2JCzYSMEf053GDe5r7nqGZ+x29uNeKco=; fh=aqVDum9phgI3SnxBoMwLLvi9aPgvFsefEypNl6YRPLM=; b=clL2t9LQXbnYCSMZZ/IewaiP8ugWL7tGiQi8WoA8Y5BsynaHBHQBw7nIhE9+Kr8vjN 3SJrih2nIA5Da1KY1BvJTodJh7YITwJpXomXVgJWzdWChzA4UXik9fDr7btZPeKCm5nt 1wTkcnJP8bZei+lrgQraCIhx2jOUcrGyDFjCBi2zy4KOSA1K8JVFgxl1kJLmXiqlA+PH yucVxqkGIf4/h982NPw2LkSobCkeA+fvLxkyiPxz8hgCHlMgrmzMz8LmhzW45axb4MHi m9Q9oXzcKjQR27FFdDvvlHiT1JRFztUHEi7XIeD8orRENb2InUR31usR7TNku/0goRS+ H2sQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Sm4Xj+Gz; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-150134-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-150134-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id m7-20020a170902bb8700b001e4802f1a69si1376410pls.161.2024.04.18.06.12.16 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 18 Apr 2024 06:12:17 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-150134-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Sm4Xj+Gz; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-150134-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-150134-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org 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 5EB26B22716 for ; Thu, 18 Apr 2024 13:09:33 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 7971015B157; Thu, 18 Apr 2024 13:09:20 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="Sm4Xj+Gz" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (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 7EE1313C3FF; Thu, 18 Apr 2024 13:09:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713445759; cv=none; b=P3rosMWwJjVLkZNQySb2BlkNYZxGj0qiZN+2fKBmgCfxJRHfjtein96eh6vZv6YQMMU4U9gW3GSMsvViZ3K2OFlsNicMZZPk4LF2NPsHmdORIqU2afeJgx5G4nxGeuvPhCU6jqfAvPlRBsBWyxx0eohcBE+GjvvfG8xgwYUWVW0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713445759; c=relaxed/simple; bh=hvKGkHxZPIW4Pt6T/rjRhahcUnodHa40YaR7g0BoD4g=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=aPixayGkQRoIXTB0Q8TOu2kIfMRz8wAxAyjTwPCKkKlzKnBPFH+ABeQufnkznYYRHCGdX+esyY37KXqNie4y8S6SNrGH4S/FHRS5hGYURUlhx6frTG1a/qjiOEnrU2cwPehioqlEIjdcw1/FGkUxWR/gvjsgipF5v7ovNPw+Hgk= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=Sm4Xj+Gz; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 02941C2BD11; Thu, 18 Apr 2024 13:09:18 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1713445759; bh=hvKGkHxZPIW4Pt6T/rjRhahcUnodHa40YaR7g0BoD4g=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=Sm4Xj+GzFlBaqZBkolIpZr8PxUyKoQG2PVErnF19y8dLXpdLOPkOtl2FJ37ynV7/X LxUEh7KqcTARhBsu7h9l2UroGgxcfjcN9gZoNqlk8P+qmD5USeDLUoV89CNBu4KRHn qaRqDWMEqquDO4KoXwWPhWoxDJ+RH5WIWSTYrA91J2WEUVA9da5ybx8KlDQScMgSHe udbgm4Ng1TxyQM/pwyPxeRT+zPSDKfNdXj167YzuRYbZJ5ZCyr6L+oTSZy3jgnsuqy IKj7vH7rbs10Z0aOCXwdCrYR3Ip7RdV2vK2E6EhWp7Qn9uO5g324KBbUGBWeeXHebt Z581LFFCjFAyw== Date: Thu, 18 Apr 2024 08:09:16 -0500 From: Rob Herring To: Sylvain Petinot Cc: benjamin.mugnier@foss.st.com, mchehab@kernel.org, krzysztof.kozlowski+dt@linaro.org, conor+dt@kernel.org, linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 1/2] media: dt-bindings: Add ST VD56G3 camera sensor binding Message-ID: <20240418130916.GA1016598-robh@kernel.org> References: <20240417133453.17406-1-sylvain.petinot@foss.st.com> <20240417133453.17406-2-sylvain.petinot@foss.st.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20240417133453.17406-2-sylvain.petinot@foss.st.com> On Wed, Apr 17, 2024 at 03:34:52PM +0200, Sylvain Petinot wrote: > Add devicetree bindings Documentation for ST VD56G3 & ST VD66GY camera > sensors. Update MAINTAINERS file. > > Signed-off-by: Sylvain Petinot > --- > .../bindings/media/i2c/st,st-vd56g3.yaml | 143 ++++++++++++++++++ > MAINTAINERS | 9 ++ > 2 files changed, 152 insertions(+) > create mode 100644 Documentation/devicetree/bindings/media/i2c/st,st-vd56g3.yaml > > diff --git a/Documentation/devicetree/bindings/media/i2c/st,st-vd56g3.yaml b/Documentation/devicetree/bindings/media/i2c/st,st-vd56g3.yaml > new file mode 100644 > index 000000000000..6792c02fea5c > --- /dev/null > +++ b/Documentation/devicetree/bindings/media/i2c/st,st-vd56g3.yaml > @@ -0,0 +1,143 @@ > +# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) > +# Copyright (c) 2024 STMicroelectronics SA. > +%YAML 1.2 > +--- > +$id: http://devicetree.org/schemas/media/i2c/st,st-vd56g3.yaml# > +$schema: http://devicetree.org/meta-schemas/core.yaml# > + > +title: STMicroelectronics VD56G3 Global Shutter Image Sensor > + > +maintainers: > + - Benjamin Mugnier > + - Sylvain Petinot > + > +description: |- > + The STMicroelectronics VD56G3 is a 1.5 M pixel global shutter image sensor > + with an active array size of 1124 x 1364 (portrait orientation). > + It is programmable through I2C, the address is fixed to 0x10. > + The sensor output is available via CSI-2, which is configured as either 1 or > + 2 data lanes. > + The sensor provides 8 GPIOS that can be used for either > + - frame synchronization (Master: out-sync or Slave: in-sync) > + - external LED signal (synchronized with sensor integration periods) > + > +properties: > + compatible: > + enum: > + - st,st-vd56g3 > + - st,st-vd66gy > + description: > + Two variants are availables; VD56G3 is a monochrome sensor while VD66GY > + is a colour variant. > + > + reg: > + maxItems: 1 > + > + clocks: > + maxItems: 1 > + > + VCORE-supply: Convention is lowercase. > + description: Digital core power supply (1.15V) > + > + VDDIO-supply: > + description: Digital IO power supply (1.8V) > + > + VANA-supply: > + description: Analog power supply (2.8V) > + > + reset-gpios: > + description: Sensor reset active low GPIO (XSHUTDOWN) > + maxItems: 1 > + > + st,leds: > + description: > + Sensor's GPIOs used for external LED control. > + Signal being the enveloppe of the integration time. > + $ref: /schemas/types.yaml#/definitions/uint32-array > + minItems: 1 > + maxItems: 8 > + items: > + minimum: 0 > + maximum: 7 > + > + port: > + $ref: /schemas/graph.yaml#/$defs/port-base > + > + properties: > + endpoint: > + $ref: /schemas/media/video-interfaces.yaml# > + unevaluatedProperties: false > + > + properties: > + clock-lanes: > + const: 0 If required and only 1 possible value, why does this need to be in DT? > + > + data-lanes: > + minItems: 1 > + maxItems: 2 > + items: > + enum: [1, 2] > + > + link-frequencies: > + minItems: 1 > + maxItems: 1 > + items: > + enum: [402000000, 750000000] > + > + lane-polarities: > + minItems: 1 > + maxItems: 3 > + items: > + enum: [0, 1] video-interfaces.yaml already defines this constraint, so you just need to define how many entries. > + description: Any lane can be inverted or not. > + > + required: > + - clock-lanes > + - data-lanes > + - link-frequencies > + > +required: > + - compatible > + - reg > + - clocks > + - VCORE-supply > + - VDDIO-supply > + - VANA-supply > + - reset-gpios > + - port > + > +additionalProperties: false > + > +examples: > + - | > + #include > + > + i2c { > + #address-cells = <1>; > + #size-cells = <0>; > + > + vd56g3: camera-sensor@10 { Drop unused labels. > + compatible = "st,st-vd56g3"; > + reg = <0x10>; > + > + clocks = <&camera_clk_12M>; > + > + VCORE-supply = <&camera_vcore_v1v15>; > + VDDIO-supply = <&camera_vddio_v1v8>; > + VANA-supply = <&camera_vana_v2v8>; > + > + reset-gpios = <&gpio 5 GPIO_ACTIVE_LOW>; > + st,leds = <6>; > + > + port { > + vd56g3_ep: endpoint { > + clock-lanes = <0>; > + data-lanes = <1 2>; > + link-frequencies = > + /bits/ 64 <402000000>; > + remote-endpoint = <&csiphy0_ep>; > + }; > + }; > + }; > + }; > +... > diff --git a/MAINTAINERS b/MAINTAINERS > index 7c121493f43d..991e65627e18 100644 > --- a/MAINTAINERS > +++ b/MAINTAINERS > @@ -20868,6 +20868,15 @@ S: Maintained > F: Documentation/hwmon/stpddc60.rst > F: drivers/hwmon/pmbus/stpddc60.c > > +ST VD56G3 DRIVER > +M: Benjamin Mugnier > +M: Sylvain Petinot > +L: linux-media@vger.kernel.org > +S: Maintained > +T: git git://linuxtv.org/media_tree.git This should be covered by the media maintainer entry. > +F: Documentation/devicetree/bindings/media/i2c/st,st-vd56g3.yaml > +F: drivers/media/i2c/st-vd56g3.c > + > ST VGXY61 DRIVER > M: Benjamin Mugnier > M: Sylvain Petinot > -- > 2.17.1 >