Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp733732pxb; Thu, 15 Apr 2021 05:26:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyDdbcYAGLCjflAy6omQyvyqXfjq4llrrU/SErGB/2FCMEVr9/8A0ReyKsUXhxezEoAJgTf X-Received: by 2002:a17:90b:228a:: with SMTP id kx10mr3697308pjb.105.1618489592990; Thu, 15 Apr 2021 05:26:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618489592; cv=none; d=google.com; s=arc-20160816; b=xi4y8B3o0SX94nCxj2wPdQIepGeCQjfme2hi4OrpVrquzt35fLIRI0rMB0OIFOrEeA YLdYWEbjzOfs/6d5L/rMTu9PXWsbBzMxUusVXjqDQPTdTrX6dK2dTKpIemCLIICe4H10 wR87jFZEkzuSbU2EYj6FwIapJuUD7eqEkP3F9zjtXnqBDrotcTY8zQgRd5py6vi67+BK w42l9YhaB2OCnx2m0dHkKTQUbdqZ9hvT7orpiOgOCoP03ZoqvVm5VrmH84wZOM4Bl3U0 ctvoLjjRkCR6j+hQQqPplzP40Dd37wJurkD+atV0aSR+NLQvXtobuhp1se162Yto0w0y uiTw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=aGIxriktZgXme2WX0wYg7iGfZheOEkTvaZIcAu/1G3I=; b=0IfoX9eW/9EHkOWNPomD2dPbL9/PFWmKwcwkgvwH3fgmoAeq+X+yR8bX447qKingt/ jxgxKBo69FYjyPBA6uMFeix+QLhrVpvpvOdJ0Z7O/5vel4Gf+VOh4L54VmiSXTxnLRER teS4h3Y8CQesRlQKmiA4KV7sT2exTWBOWOrPjDZMoT4odZpLgUE+AcUMzXmgqIoaZ0QP c1ifkjpc1dsaYf6LrSFskLEW/8m6AQgG1pIiHLVJMtpyNfuXPwBowBDX60JU7zql59Zw hXGiHZ8fJvtjT4cDSb65oxzi1NbCFomfAkMcFCzJnn5RDWrsoFIapSoh1n5Hjdm78mrz 6AXw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d4si3219189pfd.1.2021.04.15.05.26.20; Thu, 15 Apr 2021 05:26:32 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232925AbhDOM0J (ORCPT + 99 others); Thu, 15 Apr 2021 08:26:09 -0400 Received: from relay5-d.mail.gandi.net ([217.70.183.197]:42133 "EHLO relay5-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232743AbhDOMZ6 (ORCPT ); Thu, 15 Apr 2021 08:25:58 -0400 X-Originating-IP: 93.61.96.190 Received: from uno.LocalDomain (93-61-96-190.ip145.fastwebnet.it [93.61.96.190]) (Authenticated sender: jacopo@jmondi.org) by relay5-d.mail.gandi.net (Postfix) with ESMTPSA id 06D051C0007; Thu, 15 Apr 2021 12:25:32 +0000 (UTC) From: Jacopo Mondi To: Geert Uytterhoeven , Magnus Damm , Laurent Pinchart , Kieran Bingham , Rob Herring Cc: Jacopo Mondi , linux-renesas-soc@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v4 2/7] dt-bindings: media: max9286: Define 'maxim,gpio-poc' Date: Thu, 15 Apr 2021 14:25:57 +0200 Message-Id: <20210415122602.87697-3-jacopo+renesas@jmondi.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210415122602.87697-1-jacopo+renesas@jmondi.org> References: <20210415122602.87697-1-jacopo+renesas@jmondi.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Define a new vendor property in the maxim,max9286 binding schema. The new property allows to declare that the remote camera power-over-coax is controlled by one of the MAX9286 gpio lines. As it is currently not possible to establish a regulator as consumer of the MAX9286 gpio controller for this purpose, the property allows to declare that the camera power is controlled by the MAX9286 directly. The property accepts a gpio-index (0 or 1) and one line polarity flag as defined by dt-bindings/gpio/gpio.h. Reviewed-by: Laurent Pinchart Signed-off-by: Jacopo Mondi --- .../bindings/media/i2c/maxim,max9286.yaml | 71 ++++++++++++++++++- 1 file changed, 70 insertions(+), 1 deletion(-) diff --git a/Documentation/devicetree/bindings/media/i2c/maxim,max9286.yaml b/Documentation/devicetree/bindings/media/i2c/maxim,max9286.yaml index 0e7162998b77..e2422241b7d0 100644 --- a/Documentation/devicetree/bindings/media/i2c/maxim,max9286.yaml +++ b/Documentation/devicetree/bindings/media/i2c/maxim,max9286.yaml @@ -70,6 +70,28 @@ properties: a remote serializer whose high-threshold noise immunity is not enabled is 100000 micro volts + maxim,gpio-poc: + $ref: '/schemas/types.yaml#/definitions/uint32-array' + minItems: 2 + maxItems: 2 + description: | + Index of the MAX9286 gpio output line (0 or 1) that controls Power over + Coax to the cameras and its associated polarity flag. + + The property accepts an array of two unsigned integers, the first being + the gpio line index (0 or 1) and the second being the gpio line polarity + flag (GPIO_ACTIVE_HIGH or GPIO_ACTIVE_LOW) as defined in + . + + When the remote cameras power is controlled by one of the MAX9286 gpio + lines, this property has to be used to specify which line among the two + available ones controls the remote camera power enablement. + + When this property is used it is not possible to register a gpio + controller as the gpio lines are controlled directly by the MAX9286 and + not available for consumers, nor the 'poc-supply' property should be + specified. + ports: $ref: /schemas/graph.yaml#/properties/ports @@ -182,7 +204,20 @@ required: - reg - ports - i2c-mux - - gpio-controller + +# If 'maxim,gpio-poc' is present, then 'poc-supply' and 'gpio-controller' +# are not allowed. +if: + required: + - maxim,gpio-poc +then: + allOf: + - not: + required: + - poc-supply + - not: + required: + - gpio-controller additionalProperties: false @@ -327,4 +362,38 @@ examples: }; }; }; + + /* + * Example of a deserializer that controls the camera Power over Coax + * through one of its gpio lines. + */ + gmsl-deserializer@6c { + compatible = "maxim,max9286"; + reg = <0x6c>; + enable-gpios = <&gpio 14 GPIO_ACTIVE_HIGH>; + + /* + * The remote camera power is controlled by MAX9286 GPIO line #0. + * No 'poc-supply' nor 'gpio-controller' are specified. + */ + maxim,gpio-poc = <0 GPIO_ACTIVE_LOW>; + + /* + * Do not describe connections as they're the same as in the previous + * example. + */ + ports { + #address-cells = <1>; + #size-cells = <0>; + + port@4 { + reg = <4>; + }; + }; + + i2c-mux { + #address-cells = <1>; + #size-cells = <0>; + }; + }; }; -- 2.31.1