Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2700536pxj; Mon, 14 Jun 2021 05:17:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzy8FRkRjwAbHsQWs+98OCT4uPmje/fECugjcWREI95tb48c6QljjbWWOHubNQ3mthWPJOP X-Received: by 2002:aa7:d0cc:: with SMTP id u12mr16603490edo.48.1623673032600; Mon, 14 Jun 2021 05:17:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623673032; cv=none; d=google.com; s=arc-20160816; b=zUruVg8f8OjHlR6rgJQ/Psh8ojFrIQ0ECccRkwz8cSknv0XXuf4LfXPPpe96sGFYiX s+5rVvkN/uO7Zd/Vbl3lcnAoZBdc1kuE2q/6/ulGqxj/UNkjGP08vNjExVdrIpyUnPkQ 9SsTzmGI+TpO2HwcdR0azNVMqo+XvUjmG7OEuaibQ8lhp8zlXVGjO/X+N+fSWl/piGrI C0LfB85pxPibJcQcil8gsoepiEJ8dbWEJHk2V0PI/fbr9B0rgHcvB3x2s5BHMPDNsC9Z wY1ZNiMuO5SGPjyL81s/p96c7L7o6Fs3Ot3/rEuJS/3PG1mJFf9g4DSVXYakhoxO2SSq wiqw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:references:in-reply-to :message-id:date:subject:cc:to:from; bh=OYGg2yqtHEAxxIiBPhKuZmzwtvhBTuz78U5Gg8oKK3E=; b=jCa74T08gSPQAT15Y5TUnKqxC1L/epQPiWaRkvO4RfzKDtfC1tJluzz1/PU96Yej0t cEVd07m36qP1plfCrUELJA6vZ8z+n4VTAD7HsPGFqaPbynmQrh2IE6B3NnF+DScrArOR jpHBNW2r/6Wl8xUBycXQc8K2Vs8p6RVCwSuv1cq1hCXQ4YpOdHyw2gw6A/TKYIztWkHA HAxVaP3aKPHIobG6oClLhhJguuz2sN3Qe9Sa3O1bcc2G9gvR0TlmJdttd14Go767PgKx umL6ZAEMjvLG95vd48Ae0968KBZtx9G6Jzepo8SQ+P19VLvxvoD8ovaF20mRxVopzopg ixkw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=puri.sm Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w6si11516472ejf.324.2021.06.14.05.16.48; Mon, 14 Jun 2021 05:17:12 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=puri.sm Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233042AbhFNMRz (ORCPT + 99 others); Mon, 14 Jun 2021 08:17:55 -0400 Received: from comms.puri.sm ([159.203.221.185]:56388 "EHLO comms.puri.sm" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232559AbhFNMRz (ORCPT ); Mon, 14 Jun 2021 08:17:55 -0400 Received: from localhost (localhost [127.0.0.1]) by comms.puri.sm (Postfix) with ESMTP id 3EDEBE1FD3; Mon, 14 Jun 2021 05:15:52 -0700 (PDT) Received: from comms.puri.sm ([127.0.0.1]) by localhost (comms.puri.sm [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Xdk0FjcwTApp; Mon, 14 Jun 2021 05:15:48 -0700 (PDT) From: Martin Kepplinger To: martin.kepplinger@puri.sm, laurent.pinchart@ideasonboard.com Cc: devicetree@vger.kernel.org, festevam@gmail.com, kernel@pengutronix.de, kernel@puri.sm, krzk@kernel.org, linux-arm-kernel@lists.infradead.org, linux-imx@nxp.com, linux-kernel@vger.kernel.org, linux-media@vger.kernel.org, linux-staging@lists.linux.dev, mchehab@kernel.org, phone-devel@vger.kernel.org, robh@kernel.org, shawnguo@kernel.org, slongerbeam@gmail.com, m.felsch@pengutronix.de Subject: [PATCH v4 1/3] dt-bindings: media: document the nxp,imx8mq-mipi-csi2 receiver phy and controller Date: Mon, 14 Jun 2021 14:15:20 +0200 Message-Id: <20210614121522.2944593-2-martin.kepplinger@puri.sm> In-Reply-To: <20210614121522.2944593-1-martin.kepplinger@puri.sm> References: <20210614121522.2944593-1-martin.kepplinger@puri.sm> Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The i.MX8MQ SoC integrates a different MIPI CSI receiver as the i.MX8MM so describe the DT bindings for it. Signed-off-by: Martin Kepplinger --- .../bindings/media/nxp,imx8mq-mipi-csi2.yaml | 171 ++++++++++++++++++ 1 file changed, 171 insertions(+) create mode 100644 Documentation/devicetree/bindings/media/nxp,imx8mq-mipi-csi2.yaml diff --git a/Documentation/devicetree/bindings/media/nxp,imx8mq-mipi-csi2.yaml b/Documentation/devicetree/bindings/media/nxp,imx8mq-mipi-csi2.yaml new file mode 100644 index 000000000000..4fed224ebfdd --- /dev/null +++ b/Documentation/devicetree/bindings/media/nxp,imx8mq-mipi-csi2.yaml @@ -0,0 +1,171 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/media/nxp,imx8mq-mipi-csi2.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: NXP i.MX8MQ MIPI CSI-2 receiver + +maintainers: + - Martin Kepplinger + +description: |- + This binding covers the CSI-2 RX PHY and host controller included in the + NXP i.MX8MQ SoC. It handles the sensor/image input and process for all the + input imaging devices. + +properties: + compatible: + enum: + - fsl,imx8mq-mipi-csi2 + + reg: + maxItems: 1 + + clocks: + items: + - description: core is the RX Controller Core Clock input. This clock + must be exactly equal to or faster than the receive + byteclock from the RX DPHY. + - description: esc is the Rx Escape Clock. This must be the same escape + clock that the RX DPHY receives. + - description: pxl is the pixel clock (phy_ref up to 333Mhz). + - description: clko2 is the CLKO2 clock root. + See the reference manual for details. + + clock-names: + items: + - const: core + - const: esc + - const: pxl + - const: clko2 + + power-domains: + maxItems: 1 + + resets: + maxItems: 1 + + fsl,mipi-phy-gpr: + description: | + The phandle to the imx8mq syscon iomux-gpr with the register + for setting RX_ENABLE for the mipi receiver. + + The format should be as follows: + + gpr is the phandle to general purpose register node. + req_gpr is the gpr register offset of RX_ENABLE for the mipi phy. + $ref: /schemas/types.yaml#/definitions/phandle-array + items: + items: + - description: The 'gpr' is the phandle to general purpose register node. + - description: The 'req_gpr' is the gpr register offset containing + CSI2_1_RX_ENABLE or CSI2_2_RX_ENABLE respectively. + maximum: 0xff + + interconnects: + maxItems: 1 + + interconnect-names: + const: dram + + ports: + $ref: /schemas/graph.yaml#/properties/ports + + properties: + port@0: + $ref: /schemas/graph.yaml#/$defs/port-base + unevaluatedProperties: false + description: + Input port node, single endpoint describing the CSI-2 transmitter. + + properties: + endpoint: + $ref: video-interfaces.yaml# + unevaluatedProperties: false + + properties: + data-lanes: + items: + minItems: 1 + maxItems: 4 + items: + - const: 1 + - const: 2 + - const: 3 + - const: 4 + + required: + - data-lanes + + port@1: + $ref: /schemas/graph.yaml#/properties/port + description: + Output port node + + required: + - port@0 + - port@1 + +required: + - compatible + - reg + - clocks + - clock-names + - power-domains + - resets + - fsl,mipi-phy-gpr + - ports + +additionalProperties: false + +examples: + - | + #include + #include + + csi@30a70000 { + compatible = "fsl,imx8mq-mipi-csi2"; + reg = <0x30a70000 0x1000>; + clocks = <&clk IMX8MQ_CLK_CSI1_CORE>, + <&clk IMX8MQ_CLK_CSI1_ESC>, + <&clk IMX8MQ_CLK_CSI1_PHY_REF>, + <&clk IMX8MQ_CLK_CLKO2>; + clock-names = "core", "esc", "pxl", "clko2"; + assigned-clocks = <&clk IMX8MQ_CLK_CSI1_CORE>, + <&clk IMX8MQ_CLK_CSI1_PHY_REF>, + <&clk IMX8MQ_CLK_CSI1_ESC>; + assigned-clock-rates = <266000000>, <200000000>, <66000000>; + assigned-clock-parents = <&clk IMX8MQ_SYS1_PLL_266M>, + <&clk IMX8MQ_SYS2_PLL_1000M>, + <&clk IMX8MQ_SYS1_PLL_800M>; + power-domains = <&pgc_mipi_csi1>; + resets = <&src>; + fsl,mipi-phy-gpr = <&iomuxc_gpr 0x88>; + interconnects = <&noc IMX8MQ_ICM_CSI1 &noc IMX8MQ_ICS_DRAM>; + interconnect-names = "dram"; + + ports { + #address-cells = <1>; + #size-cells = <0>; + + port@0 { + reg = <0>; + + imx8mm_mipi_csi_in: endpoint { + remote-endpoint = <&imx477_out>; + data-lanes = <1 2 3 4>; + }; + }; + + port@1 { + reg = <1>; + + imx8mm_mipi_csi_out: endpoint { + remote-endpoint = <&csi_in>; + }; + }; + }; + }; + +... -- 2.30.2