From: Cosmin Tanislav <demonsingur@gmail.com>
To: "Cosmin Tanislav" <cosmin.tanislav@analog.com>,
"Tomi Valkeinen" <tomi.valkeinen+renesas@ideasonboard.com>,
"Mauro Carvalho Chehab" <mchehab@kernel.org>,
"Rob Herring" <robh@kernel.org>,
"Niklas Söderlund" <niklas.soderlund@ragnatech.se>,
"Julien Massot" <julien.massot@collabora.com>,
"Sakari Ailus" <sakari.ailus@linux.intel.com>,
"Laurent Pinchart" <laurent.pinchart@ideasonboard.com>,
"Greg Kroah-Hartman" <gregkh@linuxfoundation.org>,
"Linus Walleij" <linus.walleij@linaro.org>
Cc: linux-media@vger.kernel.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org,
linux-arm-kernel@lists.infradead.org,
linux-staging@lists.linux.dev, linux-gpio@vger.kernel.org,
Cosmin Tanislav <demonsingur@gmail.com>
Subject: [PATCH v5 14/24] dt-bindings: media: i2c: add MAX9296A, MAX96716A, MAX96792A
Date: Wed, 2 Jul 2025 16:20:40 +0300 [thread overview]
Message-ID: <20250702132104.1537926-15-demonsingur@gmail.com> (raw)
In-Reply-To: <20250702132104.1537926-1-demonsingur@gmail.com>
The MAX9296A deserializer converts single or dual serial inputs to MIPI
CSI-2 outputs. The GMSL2 links operate at a fixed rate of 3Gbps or 6Gbps
in the forward direction and 187.5Mbps in the reverse direction.
In GMSL1 mode, each serial link can be paired with 3.12Gbps or 1.5Gbps
GMSL1 serializers or operate up to 4.5Gbps with GMSL2 serializers with
GMSL1 backward compatibility. The MAX9296A supports mixed GMSL2 and
GMSL1 links. The serial inputs operate independently, allowing videos
with different timings and resolutions to be received on each input.
MAX96716A supports both tunnel and pixel mode.
MAX96792A supports both tunnel and pixel mode, and has two GMSL3 links.
Signed-off-by: Cosmin Tanislav <demonsingur@gmail.com>
Acked-by: Rob Herring (Arm) <robh@kernel.org>
---
.../bindings/media/i2c/maxim,max9296a.yaml | 242 ++++++++++++++++++
MAINTAINERS | 6 +
2 files changed, 248 insertions(+)
create mode 100644 Documentation/devicetree/bindings/media/i2c/maxim,max9296a.yaml
diff --git a/Documentation/devicetree/bindings/media/i2c/maxim,max9296a.yaml b/Documentation/devicetree/bindings/media/i2c/maxim,max9296a.yaml
new file mode 100644
index 000000000000..c0a8916353f6
--- /dev/null
+++ b/Documentation/devicetree/bindings/media/i2c/maxim,max9296a.yaml
@@ -0,0 +1,242 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+# Copyright (C) 2024 Collabora Ltd.
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/media/i2c/maxim,max9296a.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Maxim MAX9296A GMSL2 to CSI-2 Deserializer
+
+maintainers:
+ - Cosmin Tanislav <cosmin.tanislav@analog.com>
+
+description: >
+ The MAX9296A deserializer converts single or dual serial inputs to
+ MIPI CSI-2 outputs. The GMSL2 links operate at a fixed rate of 3Gbps
+ or 6Gbps in the forward direction and 187.5Mbps in the reverse
+ direction. In GMSL1 mode, each serial link can be paired with 3.12Gbps
+ or 1.5Gbps GMSL1 serializers or operate up to 4.5Gbps with GMSL2
+ serializers with GMSL1 backward compatibility. The MAX9296A supports
+ mixed GMSL2 and GMSL1 links. The serial inputs operate independently,
+ allowing videos with different timings and resolutions to be received
+ on each input.
+
+ MAX96716A supports both tunnel and pixel mode.
+
+ MAX96792A supports both tunnel and pixel mode, and has two GMSL3 links.
+
+properties:
+ compatible:
+ enum:
+ - maxim,max9296a
+ - maxim,max96716a
+ - maxim,max96792a
+
+ reg:
+ maxItems: 1
+
+ powerdown-gpios:
+ maxItems: 1
+ description: Specifier for the GPIO connected to the PWDNB pin.
+
+ port0-poc-supply:
+ description: Regulator providing Power over Coax for GMSL port 0
+
+ port1-poc-supply:
+ description: Regulator providing Power over Coax for GMSL port 1
+
+ i2c-alias-pool:
+ maxItems: 2
+
+ i2c-atr:
+ type: object
+ additionalProperties: false
+
+ properties:
+ '#address-cells':
+ const: 1
+
+ '#size-cells':
+ const: 0
+
+ patternProperties:
+ '^i2c@[0-1]$':
+ $ref: /schemas/i2c/i2c-controller.yaml#
+ unevaluatedProperties: false
+ properties:
+ reg:
+ items:
+ minimum: 0
+ maximum: 1
+
+ ports:
+ $ref: /schemas/graph.yaml#/properties/ports
+
+ patternProperties:
+ '^port@[0-1]$':
+ $ref: /schemas/graph.yaml#/properties/port
+ description: GMSL Input ports 0-1
+
+ '^port@[2-3]$':
+ $ref: /schemas/graph.yaml#/$defs/port-base
+ unevaluatedProperties: false
+ description: CSI-2 Output ports 0-1
+ properties:
+ endpoint:
+ $ref: /schemas/media/video-interfaces.yaml#
+ unevaluatedProperties: false
+
+ properties:
+ data-lanes:
+ minItems: 1
+ maxItems: 4
+
+ lane-polarities:
+ minItems: 1
+ maxItems: 5
+
+ link-frequencies:
+ maxItems: 1
+
+ required:
+ - data-lanes
+
+ anyOf:
+ - required:
+ - port@2
+ - required:
+ - port@3
+
+required:
+ - compatible
+ - reg
+ - ports
+
+additionalProperties: false
+
+allOf:
+ - $ref: /schemas/i2c/i2c-atr.yaml#
+
+dependentRequired:
+ i2c-atr: [i2c-alias-pool]
+ i2c-alias-pool: [i2c-atr]
+
+examples:
+ - |
+ #include <dt-bindings/gpio/gpio.h>
+ #include <dt-bindings/media/video-interfaces.h>
+
+ i2c {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ deserializer@28 {
+ compatible = "maxim,max9296a";
+ reg = <0x28>;
+ powerdown-gpios = <&main_gpio0 37 GPIO_ACTIVE_LOW>;
+
+ i2c-alias-pool = <0x40 0x41>;
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ port@0 {
+ reg = <0>;
+ des_gmsl_in_0: endpoint {
+ remote-endpoint = <&ser_0_gmsl_out>;
+ };
+ };
+
+ port@1 {
+ reg = <1>;
+ des_gmsl_in_1: endpoint {
+ remote-endpoint = <&ser_1_gmsl_out>;
+ };
+ };
+
+ port@2 {
+ reg = <2>;
+ des_csi_out: endpoint {
+ data-lanes = <1 2 3 4>;
+ link-frequencies = /bits/ 64 <400000000>;
+ remote-endpoint = <&csi_in>;
+ };
+ };
+ };
+
+ i2c-atr {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ i2c@0 {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <0>;
+
+ serializer@40 {
+ compatible = "maxim,max96717";
+ reg = <0x40>;
+ gpio-controller;
+ #gpio-cells = <2>;
+ #clock-cells = <0>;
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ port@0 {
+ reg = <0>;
+ ser_0_csi_in: endpoint {
+ data-lanes = <1 2>;
+ remote-endpoint = <&sensor_0_out>;
+ };
+ };
+
+ port@1 {
+ reg = <1>;
+ ser_0_gmsl_out: endpoint {
+ remote-endpoint = <&des_gmsl_in_0>;
+ };
+ };
+ };
+ };
+ };
+
+ i2c@1 {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <1>;
+
+ serializer@40 {
+ compatible = "maxim,max96717";
+ reg = <0x40>;
+ gpio-controller;
+ #gpio-cells = <2>;
+ #clock-cells = <0>;
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ port@0 {
+ reg = <0>;
+ ser_1_csi_in: endpoint {
+ data-lanes = <1 2>;
+ remote-endpoint = <&sensor_1_out>;
+ };
+ };
+
+ port@1 {
+ reg = <1>;
+ ser_1_gmsl_out: endpoint {
+ remote-endpoint = <&des_gmsl_in_1>;
+ };
+ };
+ };
+ };
+ };
+ };
+ };
+ };
+...
diff --git a/MAINTAINERS b/MAINTAINERS
index 2fd3edef879f..334195989c00 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -14764,6 +14764,12 @@ S: Maintained
F: Documentation/devicetree/bindings/iio/proximity/maxbotix,mb1232.yaml
F: drivers/iio/proximity/mb1232.c
+MAXIM GMSL2/3 SERIALIZERS AND DESERIALIZERS
+M: Cosmin Tanislav <cosmin.tanislav@analog.com>
+L: linux-media@vger.kernel.org
+S: Maintained
+F: Documentation/devicetree/bindings/media/i2c/maxim,max9296a.yaml
+
MAXIM MAX11205 DRIVER
M: Ramona Bolboaca <ramona.bolboaca@analog.com>
L: linux-iio@vger.kernel.org
--
2.50.0
next prev parent reply other threads:[~2025-07-02 13:21 UTC|newest]
Thread overview: 45+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-07-02 13:20 [PATCH v5 00/24] media: i2c: add Maxim GMSL2/3 serializer and deserializer drivers Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 01/24] media: mc: Add INTERNAL pad flag Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 02/24] dt-bindings: media: i2c: max96717: add myself as maintainer Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 03/24] dt-bindings: media: i2c: max96717: add support for I2C ATR Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 04/24] dt-bindings: media: i2c: max96717: add support for pinctrl/pinconf Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 05/24] dt-bindings: media: i2c: max96717: add support for MAX9295A Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 06/24] dt-bindings: media: i2c: max96717: add support for MAX96793 Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 07/24] dt-bindings: media: i2c: max96712: add myself as maintainer Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 08/24] dt-bindings: media: i2c: max96712: use pattern properties for ports Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 09/24] dt-bindings: media: i2c: max96712: add support for I2C ATR Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 10/24] dt-bindings: media: i2c: max96712: add support for POC supplies Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 11/24] dt-bindings: media: i2c: max96712: add support for MAX96724F/R Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 12/24] dt-bindings: media: i2c: max96714: add myself as maintainer Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 13/24] dt-bindings: media: i2c: max96714: add support for MAX96714R Cosmin Tanislav
2025-07-02 13:20 ` Cosmin Tanislav [this message]
2025-07-02 16:14 ` [PATCH v5 14/24] dt-bindings: media: i2c: add MAX9296A, MAX96716A, MAX96792A Rob Herring (Arm)
2025-07-02 13:20 ` [PATCH v5 15/24] media: i2c: add Maxim GMSL2/3 serializer and deserializer framework Cosmin Tanislav
2025-07-03 12:08 ` Julien Massot
2025-07-03 12:21 ` Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 16/24] media: i2c: add Maxim GMSL2/3 serializer framework Cosmin Tanislav
2025-07-03 12:10 ` Julien Massot
2025-07-03 12:24 ` Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 17/24] media: i2c: add Maxim GMSL2/3 deserializer framework Cosmin Tanislav
2025-07-03 12:13 ` Julien Massot
2025-07-03 12:29 ` Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 18/24] media: i2c: maxim-serdes: add MAX96717 driver Cosmin Tanislav
2025-07-03 12:16 ` Julien Massot
2025-07-03 12:31 ` Cosmin Tanislav
2025-07-03 14:03 ` Julien Massot
2025-07-02 13:20 ` [PATCH v5 19/24] media: i2c: maxim-serdes: add MAX96724 driver Cosmin Tanislav
2025-07-02 14:45 ` Niklas Söderlund
2025-07-02 13:20 ` [PATCH v5 20/24] media: i2c: maxim-serdes: add MAX9296A driver Cosmin Tanislav
2025-07-03 12:19 ` Julien Massot
2025-07-02 13:20 ` [PATCH v5 21/24] arm64: defconfig: disable deprecated MAX96712 driver Cosmin Tanislav
2025-07-02 14:48 ` Niklas Söderlund
2025-07-02 13:20 ` [PATCH v5 22/24] staging: media: remove " Cosmin Tanislav
2025-07-02 14:54 ` Niklas Söderlund
2025-07-02 13:20 ` [PATCH v5 23/24] media: i2c: remove MAX96717 driver Cosmin Tanislav
2025-07-02 13:20 ` [PATCH v5 24/24] media: i2c: remove MAX96714 driver Cosmin Tanislav
2025-07-03 12:07 ` [PATCH v5 00/24] media: i2c: add Maxim GMSL2/3 serializer and deserializer drivers Julien Massot
2025-07-03 12:17 ` Cosmin Tanislav
2025-07-03 13:54 ` Julien Massot
2025-07-03 14:46 ` Cosmin Tanislav
2025-07-04 7:11 ` Julien Massot
2025-07-16 18:54 ` vivekana
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250702132104.1537926-15-demonsingur@gmail.com \
--to=demonsingur@gmail.com \
--cc=cosmin.tanislav@analog.com \
--cc=devicetree@vger.kernel.org \
--cc=gregkh@linuxfoundation.org \
--cc=julien.massot@collabora.com \
--cc=laurent.pinchart@ideasonboard.com \
--cc=linus.walleij@linaro.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-gpio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-media@vger.kernel.org \
--cc=linux-staging@lists.linux.dev \
--cc=mchehab@kernel.org \
--cc=niklas.soderlund@ragnatech.se \
--cc=robh@kernel.org \
--cc=sakari.ailus@linux.intel.com \
--cc=tomi.valkeinen+renesas@ideasonboard.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).