From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mx07-00178001.pphosted.com (mx07-00178001.pphosted.com [185.132.182.106]) (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 3CB2D304BD8; Thu, 21 Aug 2025 11:12:27 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=185.132.182.106 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1755774749; cv=none; b=TlZNe0Dcn1WktH4EDR4m3GVegZRG9zzMowYLbP3f6bVaO3P3ezpc0sgymIQZjpYs6bVFH7nOUTdBfwEPrrXNjyuHMOoIlXqOpGMtgWyrBl9HXKyG3SBcaehh/NuRuDsCXhW+JR7WqzqeUqaJj5PrJ/ufapJ91jf3TcCbfr8b3OU= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1755774749; c=relaxed/simple; bh=rh2xmRDg16batEKdcuvG/Ijbj9vj0VGi+3thcgNZo/A=; h=From:Subject:Date:Message-ID:MIME-Version:Content-Type:To:CC; b=n582WMYATe1owfFHnFWTHOsHn0Dul7HClQEHiZ4A5TnBYcAHc333B7DeESJbPnsFVFKYJOtuo8Xsgq7176aKiE1e9Ta1iZ0bTQlpVe308Q869sHZqbwzTpmFTkr/+suMJR4cbE3SFxepCyRqh7suzBPvbvuYXlTqqWMS4O+D80k= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=foss.st.com; spf=pass smtp.mailfrom=foss.st.com; dkim=pass (2048-bit key) header.d=foss.st.com header.i=@foss.st.com header.b=t0Y5RbJm; arc=none smtp.client-ip=185.132.182.106 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=foss.st.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=foss.st.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=foss.st.com header.i=@foss.st.com header.b="t0Y5RbJm" Received: from pps.filterd (m0369458.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 57LAg3FU015986; Thu, 21 Aug 2025 13:12:07 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=foss.st.com; h= cc:content-transfer-encoding:content-type:date:from:message-id :mime-version:subject:to; s=selector1; bh=X+qzU/CTwFD1hKZMqSzOxX ahtSY5VOj2gTRB2d6uLcM=; b=t0Y5RbJmiRbMtS506SvgSz4xp/cZCGARjz6IkI IFYoAg/9DXtj/drHkpn8hp22FlxyUyK7RsZaJKveb6Hv2OsADZRNosfQ51LISE5i yt7V0Kv19XOPNCFiIJubu1z8zfsO9oPOY5A8LF3dGNcE7DQ/5vVKYC+Mq9cZuFSA dyNS0nza7MgbEzYzmOqzg0mRqo6d3Y2/PKYEZyLuaUxBpLNhEoKLN50u6WeI6jp5 2KmyS4hc/NL1mABdvm/eYDuUF88UB9XWBUPy3GbELwbPlcqH/F6kUcdhsyt5NluT 7gdOWEqCAno7LNxCqamLwpyEv/en1jrtOQfKpSJlsnKnVPiA== Received: from beta.dmz-ap.st.com (beta.dmz-ap.st.com [138.198.100.35]) by mx07-00178001.pphosted.com (PPS) with ESMTPS id 48nj3v3n7y-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 21 Aug 2025 13:12:07 +0200 (MEST) Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-ap.st.com (STMicroelectronics) with ESMTP id E0F814004C; Thu, 21 Aug 2025 13:10:48 +0200 (CEST) Received: from Webmail-eu.st.com (shfdag1node2.st.com [10.75.129.70]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id 7C75B74E7CE; Thu, 21 Aug 2025 13:09:50 +0200 (CEST) Received: from localhost (10.252.7.99) by SHFDAG1NODE2.st.com (10.75.129.70) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.39; Thu, 21 Aug 2025 13:09:50 +0200 From: Raphael Gallais-Pou Subject: [PATCH v4 00/13] Enable display support for STM32MP25 Date: Thu, 21 Aug 2025 13:08:50 +0200 Message-ID: <20250821-drm-misc-next-v4-0-7060500f8fd3@foss.st.com> Precedence: bulk X-Mailing-List: devicetree@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 8bit X-B4-Tracking: v=1; b=H4sIAEL+pmgC/2XMSQ6CMACF4auQri3pPLjyHsYFdJAuANOSBkO4u wUXKi7fS75/AcnF4BI4VwuILocUxqEMdqqA6Zrh7mCwZQOCCEcCS2hjD/uQDBzcPEHWeIaEwYZ xD4p5ROfDvPeut7K7kKYxPvd8xtv7LknCD6WMIYIN14opJ4jx+uLHlOo01WbswdbK5OMVJkdPi seUeKsYE9TKf0+/vT56WjximFMtlWtt++vXdX0BDTzX0iwBAAA= X-Change-ID: 20250617-drm-misc-next-4af406c1c45f To: Yannick Fertre , Philippe Cornu , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , Rob Herring , "Krzysztof Kozlowski" , Conor Dooley , "Maxime Coquelin" , Alexandre Torgue , Catalin Marinas , Will Deacon , Christophe Roullier CC: , , , , , Krzysztof Kozlowski X-Mailer: b4 0.14.2 X-ClientProxiedBy: SHFCAS1NODE2.st.com (10.75.129.73) To SHFDAG1NODE2.st.com (10.75.129.70) X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1099,Hydra:6.1.9,FMLib:17.12.80.40 definitions=2025-08-21_03,2025-08-20_03,2025-03-28_01 This series aims to add and enable sufficient LVDS display support for STM32MP257F-EV1 board. LVDS is the default use case to drive a display panel on STM32MP257F-EV, even though DSI panels will be supported in the near future. The LTDC needs a pixel rate in sync with the bridge currently in use. For that both DSI and LVDS bridges need to declare an internal clock and become clock provider to the mux. The mux then selects the reference clock for the LTDC pixel rate generation. For now this mux is handled internally in the LTDC, while waiting for the STM32 clock framework to merge a 'clk-mux' based on the SYSCFG. This explains the link done in the patch [7/8] between the LVDS, providing the reference clock for the LTDC internals. +----------+ |\ | DSI PHY |------------->| \ +------------+ | |ck_dsi_phy | | | | +----------+ | |--------->| LTDC | +----------+ | |pixel_clk | | | LVDS PHY |------------->| | +------------+ | |clk_pix_lvds | | +----------+ | | | | ck_ker_ltdc ------------>| / |/| └- SYSCFG Clock selection applies as follow: - 0b00: Selects ck_dsi_phy - 0b01: Selects clk_pix_lvds - 0b10: Selects ck_ker_ltdc (for parallel or DSI display). - 0b11: Reserved The reset value of the register controlling the mux is 0b01, meaning that the default clock assigned is the clk_pix_lvds. This causes two things: - In order to get basic display on the LVDS encoder, like intended, nothing has to be done on this mux within the LTDC driver (which for now explains the unused syscfg phandle on the LTDC node in the device-tree). - 'pixel_clk' is dependent from 'clk_pix_lvds' because of the LTDC clock domains. They also need to be sync to get a coherent pixel rate though the display clock tree (which explains the LVDS phandle on the LTDC node in the device-tree). Signed-off-by: Raphael Gallais-Pou --- Changes in v4: - Documentation: - LTDC: Add "st,stm32mp255-ltdc" compatible. After internal discussion, we came to the solution that the LTDC on STM32MP255 SoC needs its own compatible, since it does have the same amount of clocks than on STM32MP251 SoC. - Devicetree: - Add "st,stm32mp255" compatible on corresponding dtsi - Drivers: - LTDC: Handle "st,stm32mp255" compatible - Remove Rob's r-b from patch [01/13] since it was modified. - Link to v3: https://lore.kernel.org/r/20250819-drm-misc-next-v3-0-04153978ebdb@foss.st.com Changes in v3: - Rebased on latest drm-misc-next - Documentation: - LTDC: Clamp correctly min/maxItems value - LVDS: Remove second 'items' keyword - Add Krzysztof's trailer where relevant - Link to v2: https://lore.kernel.org/r/20250812-drm-misc-next-v2-0-132fd84463d7@foss.st.com Changes in v2: - Documentation: - Add support for new compatible "st,stm32mp255-lvds" - Change LTDC compatible for SoC compliant one - Make clearer LTDC clock-names property - Devicetree: - Change compatible according to the documentation - Change clock and clock-names order to match documentation (and avoid warnings) - Drivers: - Change LTDC compatible - Add Rob's trailer where relevant - Link to v1: https://lore.kernel.org/r/20250725-drm-misc-next-v1-0-a59848e62cf9@foss.st.com --- Raphael Gallais-Pou (11): dt-bindings: display: st: add two new compatibles to LTDC device dt-bindings: display: st,stm32-ltdc: add access-controllers property dt-bindings: display: st: add new compatible to LVDS device dt-bindings: display: st,stm32mp25-lvds: add access-controllers property dt-bindings: display: st,stm32mp25-lvds: add power-domains property dt-bindings: arm: stm32: add required #clock-cells property arm64: dts: st: add ltdc support on stm32mp251 arm64: dts: st: add ltdc support on stm32mp255 arm64: dts: st: add lvds support on stm32mp255 arm64: dts: st: add clock-cells to syscfg node on stm32mp251 arm64: dts: st: enable display support on stm32mp257f-ev1 board Yannick Fertre (2): drm/stm: ltdc: support new hardware version for STM32MP25 SoC drm/stm: ltdc: handle lvds pixel clock .../bindings/arm/stm32/st,stm32-syscon.yaml | 31 ++++++--- .../devicetree/bindings/display/st,stm32-ltdc.yaml | 53 ++++++++++++++- .../bindings/display/st,stm32mp25-lvds.yaml | 13 +++- arch/arm64/boot/dts/st/stm32mp251.dtsi | 19 ++++++ arch/arm64/boot/dts/st/stm32mp255.dtsi | 20 +++++- arch/arm64/boot/dts/st/stm32mp257f-ev1.dts | 79 ++++++++++++++++++++++ drivers/gpu/drm/stm/drv.c | 12 +++- drivers/gpu/drm/stm/ltdc.c | 58 +++++++++++++++- drivers/gpu/drm/stm/ltdc.h | 6 ++ 9 files changed, 273 insertions(+), 18 deletions(-) --- base-commit: c8cea4371e5eca30cda8660aabb337747dabc51d change-id: 20250617-drm-misc-next-4af406c1c45f Best regards, -- Raphael Gallais-Pou