From nobody Tue Apr 7 13:09:46 2026 Received: from ironport.ite.com.tw (hc210-202-87-179.vdslpro.static.apol.com.tw [210.202.87.179]) (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 65565316199; Fri, 13 Mar 2026 06:47:47 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=210.202.87.179 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773384470; cv=none; b=a6PD5ryExH1Y4v4wANmouMvL6pgNq2nqZkUsrbAJjC5/uznC4MQwn+s8klbyLJR/Cl3BBX7EhQWjqFKAlChoFgiQl/pkGzPouhTVkxqUsKUheosugAyH+MwVJqmxosCH74WWrNIzPn9DrijLAImOFPLFs2YO/HSmy+maZ4eWFwI= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773384470; c=relaxed/simple; bh=oBifDU7mLKOesPNyG7znWlQ2If9yn/17LAjt9waNjco=; h=From:Date:Subject:MIME-Version:Content-Type:Message-ID:References: In-Reply-To:To:CC; b=tSytgazzXevODboqjRw0ARHNthGjOSup6AeQKb81F9fiH7o/qqM/xdc80BYkqzYPZ40pteYWpo/TVtn/zjsMqfXNZaWAw13ilKpo3vhz9H8HbpmqgFMS4NEtlBTIMo7/ePVEQeNR4s1a05mpIuPibDn6rVC1NptnpgDrvDKBIks= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ite.com.tw; spf=pass smtp.mailfrom=ite.com.tw; dkim=pass (2048-bit key) header.d=ite.com.tw header.i=@ite.com.tw header.b=Fmx/+zUC; arc=none smtp.client-ip=210.202.87.179 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ite.com.tw Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ite.com.tw Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=ite.com.tw header.i=@ite.com.tw header.b="Fmx/+zUC" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ite.com.tw; s=dkim; h=from:date:subject:mime-version:content-transfer-encoding: message-id:references:in-reply-to:to:cc; bh=i7RnpqRvawSo3DqBTVo6ZvZS6LJscOrdXdLnf/uqkyY=; b=Fmx/+zUCubUZ2xIIfzdTcF7NDZQgh7jtMPwbbpWRJGcolMhK/O37Lcj1 r1Z11+V7NUkoSvkfda0/QFtSif5Q827MdFdLj02Z6DmidZj0609WH4bmx Qr+ObCHoaK0MMzYl2SCJSMXU5xeBh2cOCEe8Iw5IHl65miyOTVfFWYF+R 9rvuUjSlBUnhewPd/t/hZlreIloo+qJnfXBbo6viWFIyeEsXQ+JhTwzqk OzYKJaOyp301CGIg1H4aPTVz/tQEjN3uWy8dDWOwDnb21xiJNZTAdr4mJ dHXUzMA79uvTR0M2WWFQHcF1n7LstQN0nbnl06jblEyf8rm6hZ74FQ3Nq g==; X-CSE-ConnectionGUID: Uwp5HlQ6S6iz9Gas0Z4eAw== X-CSE-MsgGUID: 14bhhvvVRHmqqoNAGfMvMQ== Received: from unknown (HELO mse.ite.com.tw) ([192.168.35.30]) by ironport.ite.com.tw with ESMTP; 13 Mar 2026 14:42:17 +0800 Received: from CSBMAIL1.internal.ite.com.tw (CSBMAIL2.internal.ite.com.tw [192.168.65.41]) by mse.ite.com.tw with ESMTP id 62D6lQWe021152; Fri, 13 Mar 2026 14:47:26 +0800 (+08) (envelope-from Pet.Weng@ite.com.tw) Received: from [127.0.1.1] (192.168.72.40) by CSBMAIL2.internal.ite.com.tw (192.168.65.41) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.2562.35; Fri, 13 Mar 2026 14:47:25 +0800 From: Pet Weng Date: Fri, 13 Mar 2026 14:48:15 +0800 Subject: [PATCH v7 1/2] dt-binding: display: Add ITE IT61620 MIPI DSI to HDMI bridge 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="utf-8" Content-Transfer-Encoding: quoted-printable Message-ID: <20260313-it61620-0714-v7-1-36a16dc036d6@ite.com.tw> References: <20260313-it61620-0714-v7-0-36a16dc036d6@ite.com.tw> In-Reply-To: <20260313-it61620-0714-v7-0-36a16dc036d6@ite.com.tw> To: Andrzej Hajda , Neil Armstrong , Robert Foss , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , Rob Herring , Krzysztof Kozlowski , Conor Dooley CC: , , , Hermes Wu , Kenneth Hung , Pet Weng , Jau-chih Tseng , Pin-yen Lin , Krzysztof Kozlowski X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1773384526; l=4518; i=pet.weng@ite.com.tw; s=20250702; h=from:subject:message-id; bh=oBifDU7mLKOesPNyG7znWlQ2If9yn/17LAjt9waNjco=; b=nZ7Lz2GIaBDBO/vSaFYmgQIQhYyyq8EKtoXFLM0DdRHypAadkyZRHqJaFG35RPitzzyLMLbWp K66IGiWTPsLBo9NQahzvVXHvFy4OZ/ih6jzT/BBWQAjoAg37/0CBwHS X-Developer-Key: i=pet.weng@ite.com.tw; a=ed25519; pk=wd08uBtTLb93x2ixbKVNsxiZPdMh1Ov4z5klodh2bqo= X-ClientProxiedBy: CSBMAIL1.internal.ite.com.tw (192.168.65.58) To CSBMAIL2.internal.ite.com.tw (192.168.65.41) X-TM-SNTS-SMTP: 56AC3DAC7D7491A80161A9E6500EB93FC3B8103FBC1F54454EE959CD0B2B00BB2002:8 X-MAIL: mse.ite.com.tw 62D6lQWe021152 This chip receives MIPI DSI input and outputs HDMI, and is commonly connected to SoCs via I2C and DSI. Signed-off-by: Pet Weng Reviewed-by: Krzysztof Kozlowski --- .../bindings/display/bridge/ite,it61620.yaml | 142 +++++++++++++++++= ++++ 1 file changed, 142 insertions(+) diff --git a/Documentation/devicetree/bindings/display/bridge/ite,it61620.y= aml b/Documentation/devicetree/bindings/display/bridge/ite,it61620.yaml new file mode 100644 index 0000000000000000000000000000000000000000..e195d192f6b1a2d092b3745e3e7= f62b8b1d2d8ce --- /dev/null +++ b/Documentation/devicetree/bindings/display/bridge/ite,it61620.yaml @@ -0,0 +1,142 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/display/bridge/ite,it61620.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: ITE IT61620 MIPI DSI to HDMI Bridge + +maintainers: + - Pet Weng + +description: | + The ITE IT61620 is a high-performance, low-power HDMI bridge that conver= ts + MIPI DSI input to HDMI 1.4b TMDS output. It supports up to 4 lanes of MI= PI + D-PHY 2.0 input at 2.5Gbps per lane (10Gbps total), compatible with DSI-2 + v2.0. + + The HDMI transmitter side supports up to 4Kx2K@30Hz resolutions, and is + compliant with HDMI 1.4b and HDCP 1.4. + + For audio, the IT61620 supports up to 8-channel LPCM via I2S (multi-line= or + TDM mode), with optional S/PDIF or DSD (for SACD). It supports audio + sampling rates up to 192kHz. + +allOf: + - $ref: /schemas/sound/dai-common.yaml# + +properties: + compatible: + const: ite,it61620 + + reg: + maxItems: 1 + + interrupts: + maxItems: 1 + + reset-gpios: + maxItems: 1 + + ivdd-supply: + description: core voltage + + ovdd-supply: + description: I/O voltage + + ovdd1833-supply: + description: flexible I/O voltage + + "#sound-dai-cells": + const: 0 + + ports: + $ref: /schemas/graph.yaml#/properties/ports + + properties: + port@0: + $ref: /schemas/graph.yaml#/$defs/port-base + unevaluatedProperties: false + description: Input port for MIPI DSI + + properties: + endpoint: + $ref: /schemas/media/video-interfaces.yaml# + unevaluatedProperties: false + required: + - data-lanes + + port@1: + $ref: /schemas/graph.yaml#/properties/port + description: Output port for HDMI output + + port@2: + $ref: /schemas/graph.yaml#/properties/port + description: Audio input port (I2S) + + required: + - port@0 + - port@1 + +required: + - compatible + - reg + - interrupts + - reset-gpios + - ivdd-supply + - ovdd-supply + - ovdd1833-supply + - ports + +unevaluatedProperties: false + +examples: + - | + #include + #include + + i2c { + #address-cells =3D <1>; + #size-cells =3D <0>; + + bridge@58 { + compatible =3D "ite,it61620"; + reg =3D <0x58>; + #sound-dai-cells =3D <0>; + interrupt-parent =3D <&pio>; + interrupts =3D <128 IRQ_TYPE_LEVEL_LOW>; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&it61620_pins>; + reset-gpios =3D <&pio 127 GPIO_ACTIVE_LOW>; + ivdd-supply =3D <&pp1000_hdmi_x>; + ovdd-supply =3D <&pp3300_vio28_x>; + ovdd1833-supply =3D <&pp1800_vcamio_x>; + + ports { + #address-cells =3D <1>; + #size-cells =3D <0>; + + port@0 { + reg =3D <0>; + it61620_dsi_in: endpoint { + data-lanes =3D <0 1 2 3>; + remote-endpoint =3D <&dsi_out>; + }; + }; + + port@1 { + reg =3D <1>; + it61620_hdmi_out: endpoint { + remote-endpoint =3D <&hdmi_connector_in>; + }; + }; + + port@2 { + reg =3D <2>; + it61620_audio_in: endpoint { + remote-endpoint =3D <&i2s0_out>; + }; + }; + }; + }; + }; --=20 2.34.1 From nobody Tue Apr 7 13:09:46 2026 Received: from ironport.ite.com.tw (hc210-202-87-179.vdslpro.static.apol.com.tw [210.202.87.179]) (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 7D27A306B37; Fri, 13 Mar 2026 06:47:41 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=210.202.87.179 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773384466; cv=none; b=UEy+Mbu2W/cW5KCguA5YNv7EKttk0Qn04r7t9L6l5aMLtpHnyMPZanEqOEPnRyP5M4EsiL4dSmk55rWLAN93t5s8QcfwgrmyPG3Gt6ewD6OtV19S7mjC7YPmb64kL9a8n9bIQTEztmV0gozRYxf+DjEqOpf8JZ7BPVi6ecom3mo= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773384466; c=relaxed/simple; bh=5b9HPiYQZo1O8htXG3DLkNctzkFBQzeJ8Q9UBFsgcwY=; h=From:Date:Subject:MIME-Version:Content-Type:Message-ID:References: In-Reply-To:To:CC; b=Y72rjxl0fstlICyzeL2pHwP915LFAMl/dVVnoedpD8jc6H9jaGLrMv3JC+lywhLdYHoIEcWhTHNZnoEXHLp/ydN42RcYFOhgUPFR8g6tay2o2XGO+vm/GH6+hEShG2dY1YJJf5Swk6zEWQZbVE9KRazxIt/hmHD+i1j3yl+0aCQ= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ite.com.tw; spf=pass smtp.mailfrom=ite.com.tw; dkim=pass (2048-bit key) header.d=ite.com.tw header.i=@ite.com.tw header.b=YS4H1I21; arc=none smtp.client-ip=210.202.87.179 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ite.com.tw Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ite.com.tw Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=ite.com.tw header.i=@ite.com.tw header.b="YS4H1I21" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ite.com.tw; s=dkim; h=from:date:subject:mime-version:content-transfer-encoding: message-id:references:in-reply-to:to:cc; bh=NEB5f//hbbXsnsT2r8dYravZIFYrc87G6FF8mNLfD/I=; b=YS4H1I21uLfB3+m7mBvbUw+S7JzKa+zwRs9XnJwxZRUa+KqYyCYaCo2R DQTWrfwoqHJ7QfAKeHmtYPC5h4YYGd6x55uQrG/qX5fJAVeQ+FLAqYMjF UB/WHWUJAY6WPqkMiwQaMw6XOSJ8fQw8M9JyCv8cPnHMoHnByu7NyIOsf YiVLLHp3EiDedXbHBdGfkIvq0ufI/mMd9kPf9aV1IVVz1Rf6bJC/JFjMo IolXONZG9rZqhWPn7nOWPHBJo3+jVn/Zi/1bLD1XsD7UgOb3/RJNu7Ogn /HC6mktdRKTK49auEp3+PNRN35jx9eIT0poQuVwmaBwSQyQivnhvl9P6F g==; X-CSE-ConnectionGUID: 0/DFlvl3Ruy4fg1ATtr/dA== X-CSE-MsgGUID: 6nj3lvlxQ72TB/4eB8zzLA== Received: from unknown (HELO mse.ite.com.tw) ([192.168.35.30]) by ironport.ite.com.tw with ESMTP; 13 Mar 2026 14:42:16 +0800 Received: from CSBMAIL1.internal.ite.com.tw (CSBMAIL2.internal.ite.com.tw [192.168.65.41]) by mse.ite.com.tw with ESMTP id 62D6lQUq021151; Fri, 13 Mar 2026 14:47:26 +0800 (+08) (envelope-from Pet.Weng@ite.com.tw) Received: from [127.0.1.1] (192.168.72.40) by CSBMAIL2.internal.ite.com.tw (192.168.65.41) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.2562.35; Fri, 13 Mar 2026 14:47:25 +0800 From: Pet Weng Date: Fri, 13 Mar 2026 14:48:16 +0800 Subject: [PATCH v7 2/2] drm/bridge: Add ITE IT61620 MIPI DSI to HDMI bridge driver 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="utf-8" Content-Transfer-Encoding: quoted-printable Message-ID: <20260313-it61620-0714-v7-2-36a16dc036d6@ite.com.tw> References: <20260313-it61620-0714-v7-0-36a16dc036d6@ite.com.tw> In-Reply-To: <20260313-it61620-0714-v7-0-36a16dc036d6@ite.com.tw> To: Andrzej Hajda , Neil Armstrong , Robert Foss , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , Rob Herring , Krzysztof Kozlowski , Conor Dooley CC: , , , Hermes Wu , Kenneth Hung , Pet Weng , Jau-chih Tseng , Pin-yen Lin X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1773384526; l=83998; i=pet.weng@ite.com.tw; s=20250702; h=from:subject:message-id; bh=5b9HPiYQZo1O8htXG3DLkNctzkFBQzeJ8Q9UBFsgcwY=; b=FRlevBx74G5wdciOOiskFYzJzepCHnYorvW1dcQtBP8wGteDdUNDCkI8zKRFbnQoOcPWiwMjy SjhOcEmhSUnCJ6sIoFjzdGU5Zfm5GOqaE986uWP9zvCU/T0IKI0XBge X-Developer-Key: i=pet.weng@ite.com.tw; a=ed25519; pk=wd08uBtTLb93x2ixbKVNsxiZPdMh1Ov4z5klodh2bqo= X-ClientProxiedBy: CSBMAIL1.internal.ite.com.tw (192.168.65.58) To CSBMAIL2.internal.ite.com.tw (192.168.65.41) X-TM-SNTS-SMTP: E7BC0956DF71697A100411A2C2985B580F55E82942D99A503640C6E232A6E6312002:8 X-MAIL: mse.ite.com.tw 62D6lQUq021151 This adds support for the ITE IT61620 bridge chip which converts MIPI DSI input to HDMI output. The Driver implements the basic bridge functions and integrates with the DRM bridge and connector frameworks. Supported features include: MIPI DSI input handling HDMI output setup Basic mode configuration I2C-based control and initialization HDCP 1.4 handling HPD handling clarification: Although IT61620 has an HPD pin, hotplug detection is handled by the system connector. The bridge only receives HPD notifications, and the HPD pin is used solely for short pulses during HDCP authentication. Therefore, this bridge does not implement OP_HPD or OP_DETECT, as it does not originate or determine hotplug or connection status. This driver will be used on platforms embedding the IT61620 for video output via HDMI from SoCs with MIPI DSI output. Add a MAINTAINERS entry for the IT61620 bridge driver. Signed-off-by: Pet Weng Reviewed-by: Dmitry Baryshkov --- MAINTAINERS | 7 + drivers/gpu/drm/bridge/Kconfig | 18 + drivers/gpu/drm/bridge/Makefile | 1 + drivers/gpu/drm/bridge/ite-it61620.c | 2590 ++++++++++++++++++++++++++++++= ++++ 4 files changed, 2616 insertions(+) diff --git a/MAINTAINERS b/MAINTAINERS index 00b05e5328bef0975d493953f569f5d0a2d6fc79..f3d09a3d10b40f00121165d5471= 7110449ad11e0 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -13648,6 +13648,13 @@ T: git https://gitlab.freedesktop.org/drm/misc/ker= nel.git F: Documentation/devicetree/bindings/display/bridge/ite,it6263.yaml F: drivers/gpu/drm/bridge/ite-it6263.c =20 +ITE IT61620 MIPI DSI TO HDMI BRIDGE DRIVER +M: Pet Weng +L: dri-devel@lists.freedesktop.org +S: Maintained +F: Documentation/devicetree/bindings/display/bridge/ite,it61620.yaml +F: drivers/gpu/drm/bridge/ite-it61620.c + ITE IT66121 HDMI BRIDGE DRIVER M: Phong LE M: Neil Armstrong diff --git a/drivers/gpu/drm/bridge/Kconfig b/drivers/gpu/drm/bridge/Kconfig index 1cabfa1d2b2efc6fca68619eea6050fe96a892e8..2d074d522b952aa5a514897202b= 37c4d9a20c7ed 100644 --- a/drivers/gpu/drm/bridge/Kconfig +++ b/drivers/gpu/drm/bridge/Kconfig @@ -118,6 +118,24 @@ config DRM_ITE_IT6263 help ITE IT6263 LVDS to HDMI bridge chip driver. =20 +config DRM_ITE_IT61620 + tristate "ITE IT61620 DSI/HDMI bridge" + depends on OF + select DRM_DISPLAY_CONNECTOR + select DRM_DISPLAY_HDMI_HELPER + select DRM_DISPLAY_HDCP_HELPER + select DRM_DISPLAY_HELPER + select DRM_MIPI_DSI + select DRM_KMS_HELPER + select DRM_HDMI_HELPER + select CRYPTO_LIB_SHA1 + help + Driver for ITE IT61620 MIPI DSI to HDMI bridge + chip driver. + + It enables display output through HDMI when connected to a MIPI + DSI source. The bridge translates the video signals for HDMI monitors. + config DRM_ITE_IT6505 tristate "ITE IT6505 DisplayPort bridge" depends on OF diff --git a/drivers/gpu/drm/bridge/Makefile b/drivers/gpu/drm/bridge/Makef= ile index fb0cf0bf88756bed8323830c80f3f1d066b51e36..c70f084c30368695b9cae9791c9= 1c224aa5a32a5 100644 --- a/drivers/gpu/drm/bridge/Makefile +++ b/drivers/gpu/drm/bridge/Makefile @@ -12,6 +12,7 @@ obj-$(CONFIG_DRM_I2C_NXP_TDA998X) +=3D tda998x.o =20 obj-$(CONFIG_DRM_INNO_HDMI) +=3D inno-hdmi.o obj-$(CONFIG_DRM_ITE_IT6263) +=3D ite-it6263.o +obj-$(CONFIG_DRM_ITE_IT61620) +=3D ite-it61620.o obj-$(CONFIG_DRM_ITE_IT6505) +=3D ite-it6505.o obj-$(CONFIG_DRM_LONTIUM_LT8912B) +=3D lontium-lt8912b.o obj-$(CONFIG_DRM_LONTIUM_LT9211) +=3D lontium-lt9211.o diff --git a/drivers/gpu/drm/bridge/ite-it61620.c b/drivers/gpu/drm/bridge/= ite-it61620.c new file mode 100644 index 0000000000000000000000000000000000000000..855c8cd07a86c8a6ca15b43f616= 53df6dd8b7d57 --- /dev/null +++ b/drivers/gpu/drm/bridge/ite-it61620.c @@ -0,0 +1,2590 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Copyright (C) 2025 ITE Tech. Inc. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include