From nobody Thu Dec 18 22:29:49 2025 Received: from mail-lj1-f173.google.com (mail-lj1-f173.google.com [209.85.208.173]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id A725120B1E1; Sun, 23 Feb 2025 15:33:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.173 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1740324802; cv=none; b=CPwA2y8ixSRFnnsHSUwMJ4N+x7htu/w9vfKA7EzXNEdEoY5ST9YRUN3Qy7peEapZ5q5kkvC17SNn8f6DqOmA7DZENLjf97gXnnEWJfo+pXgKku8O2z1zdraqQGIrvh+MUVewB0mZwIpGamejTl5P86teKNESYBVBbsOUTXYhr6g= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1740324802; c=relaxed/simple; bh=1P3NMOnif0Lu/Wdk5Q7PJAtZ2TA49ZlWJcM3LakJrOQ=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=PAsDDOT3ldSPb4pHNYriEtH9KV1qLMK1CUMpldb18RWZQX9Kpxm/46RJ7y8H/zE2p/M9Ehrn8awYIkbvi3jAyrbCy35QY5w2RUlBcOBHRbz1RApammmMGITLmXekNhRv/7wiPM+C0Wzcseqy1sdf4c6hN/OVXEckcZw/ydC2wq0= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=eloBIBd0; arc=none smtp.client-ip=209.85.208.173 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="eloBIBd0" Received: by mail-lj1-f173.google.com with SMTP id 38308e7fff4ca-30a3092a9ebso41741091fa.1; Sun, 23 Feb 2025 07:33:19 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1740324798; x=1740929598; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=78M/0Nez5cUJxIBZadJWbUxgypznPIuSGkiLHMGj3oU=; b=eloBIBd0c6IOiQxuY6/vsRjjTifslExAqCHGojjloOS7+pOH6cWeVBuuHPPHnQC8Qw i1FTyHPqkEGUUrulngrvf7HdXmEPH5mDpmbzP8fIdi8inOCguzkJLG5kFHpNiVNM96Ya iBL0B8Rm61X00XenjX41s1zGLUeKB/gobiieD9UK+kvSyL7rmHBpDbHALOGsg+wyDJlh sMJ3wu3mCffy+vmZaznX+AokUOxGCt5eXpREwuhZi5VlIpc4wUGNjH7WqnH4e3uOFvgX Hp6sRpgygroQeek9pFp9HC1aA9L7riGQR9/27g51ZtPSG8XvnMOmmhgEhtJDPsaA2oep XWlQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1740324798; x=1740929598; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=78M/0Nez5cUJxIBZadJWbUxgypznPIuSGkiLHMGj3oU=; b=K1jQAohWu/Ct3yd573g8+ZXVQrrJStpPVWstpLupDHiMplxI4r7UizJ2Jj6yCwmX3c qV7oPQbHFHRsBM9bTE0vPBejK6Uov25Mmzk2ln2uZoIkYxhJXqW2ItZiAWQS2S7++E5X kcm07YRRD0pv67phPU6bZUwSLLQ/+E2v5ujWsFfHK3haAF56sr7IVnIgjPFThfvgHGA4 89nez3ulvqmqkMyeKrf0yfFyzSOKkJcfEZy5JbW5L9Y2JN5sl7C2uqCb0V7UUiO0Dwpl /M3KEwYohhOSpfe5Yn2xa7eGuWX1ixOalVAdpXV9dDqUgb7hRXF2bU7CIk5WfeUbZrro zadA== X-Forwarded-Encrypted: i=1; AJvYcCWSpn3Ez4A1uJ4TS8TiBmC2uE3HgNaj6cgwZjLoglOm62BsFCZMz0s+NrLYOXw4KOYI7BVCAKhLSbf3@vger.kernel.org, AJvYcCXoIuFcQu22Eh2Fp+ZZibgGMNJZLQ4MxTq7+1BblprK4UN5e3Ac42MN2/gCUcCTaJ6LKz70yI3B8BIJy4CX@vger.kernel.org X-Gm-Message-State: AOJu0Yxae55bK1moLReDICgTvpLB0/PBa91AXtBwaHp3Y4giiXjiqQkp /wu+O5hnwrW3NDyinY/pW+xc/fIoxNsZoEff5mDVIeqVyEC6Hye7 X-Gm-Gg: ASbGncsNoxYGRYBlwVJ8vQny72FG9AW/5kAPCO9uAjux/ZUOIWfnGxAuoC43i+2UAe2 SxwSg1nWSC0grA7wKEQ25DDz2Qp+ab46OfJaBJKBdN3XJVpdfv0zN9FobYApaYzqujFZcmZo2Wm SdckCHfgw3JIWEWxfShGwrOLKmrD2c5Id2dXKlK4grNiDmeCPzvOxDnAuzs70W4pcyfkliAdjOU tjJbmRo9v6vwvKIpXk0vbf7n+HaQZD+qu8UrT738n5V7n8EDEfwSoOc6maNEYS17d8mspBEOkxh 6npvC3UiFoaF5qip X-Google-Smtp-Source: AGHT+IGnfAOVfNJC7Xp2SZDDh4llQv3SYBgcWo9LVlo4AgHfPoBK3PItV3XuZNdyMAJ5sCH9m43AcQ== X-Received: by 2002:a05:6512:1390:b0:545:1773:30a0 with SMTP id 2adb3069b0e04-54839140092mr4141379e87.21.1740324797277; Sun, 23 Feb 2025 07:33:17 -0800 (PST) Received: from xeon.. ([188.163.112.51]) by smtp.gmail.com with ESMTPSA id 2adb3069b0e04-54523dd8ca3sm3025569e87.181.2025.02.23.07.33.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 23 Feb 2025 07:33:16 -0800 (PST) From: Svyatoslav Ryhel 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 , Svyatoslav Ryhel Cc: dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v3 2/2] drm: bridge: Add support for Solomon SSD2825 RGB/DSI bridge Date: Sun, 23 Feb 2025 17:32:44 +0200 Message-ID: <20250223153244.149102-3-clamor95@gmail.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250223153244.149102-1-clamor95@gmail.com> References: <20250223153244.149102-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" SSD2825 is a cost-effective MIPI Bridge Chip solution targeting mainly smartphones. It can convert 24bit RGB interface into 4-lane MIPI-DSI interface to drive display modules of up to 800 x 1366, while supporting AMOLED, a-si LCD or LTPS panel technologies for smartphone applications. Signed-off-by: Svyatoslav Ryhel --- drivers/gpu/drm/bridge/Kconfig | 13 + drivers/gpu/drm/bridge/Makefile | 1 + drivers/gpu/drm/bridge/ssd2825.c | 821 +++++++++++++++++++++++++++++++ 3 files changed, 835 insertions(+) create mode 100644 drivers/gpu/drm/bridge/ssd2825.c diff --git a/drivers/gpu/drm/bridge/Kconfig b/drivers/gpu/drm/bridge/Kconfig index 6b4664d91faa..8e915bab1cfd 100644 --- a/drivers/gpu/drm/bridge/Kconfig +++ b/drivers/gpu/drm/bridge/Kconfig @@ -306,6 +306,19 @@ config DRM_SIMPLE_BRIDGE Support for non-programmable DRM bridges, such as ADI ADV7123, TI THS8134 and THS8135 or passive resistor ladder DACs. =20 +config DRM_SOLOMON_SSD2825 + tristate "SSD2825 RGB/DSI bridge" + depends on SPI_MASTER && OF + select DRM_MIPI_DSI + select DRM_KMS_HELPER + select DRM_PANEL + help + Say Y here if you want support for the Solomon SSD2825 RGB/DSI + SPI bridge driver. + + Say M here if you want to support this hardware as a module. + The module will be named "solomon-ssd2825". + config DRM_THINE_THC63LVD1024 tristate "Thine THC63LVD1024 LVDS decoder bridge" depends on OF diff --git a/drivers/gpu/drm/bridge/Makefile b/drivers/gpu/drm/bridge/Makef= ile index 97304b429a53..c621ab3fa3a9 100644 --- a/drivers/gpu/drm/bridge/Makefile +++ b/drivers/gpu/drm/bridge/Makefile @@ -23,6 +23,7 @@ obj-$(CONFIG_DRM_SIL_SII8620) +=3D sil-sii8620.o obj-$(CONFIG_DRM_SII902X) +=3D sii902x.o obj-$(CONFIG_DRM_SII9234) +=3D sii9234.o obj-$(CONFIG_DRM_SIMPLE_BRIDGE) +=3D simple-bridge.o +obj-$(CONFIG_DRM_SOLOMON_SSD2825) +=3D ssd2825.o obj-$(CONFIG_DRM_THINE_THC63LVD1024) +=3D thc63lvd1024.o obj-$(CONFIG_DRM_TOSHIBA_TC358762) +=3D tc358762.o obj-$(CONFIG_DRM_TOSHIBA_TC358764) +=3D tc358764.o diff --git a/drivers/gpu/drm/bridge/ssd2825.c b/drivers/gpu/drm/bridge/ssd2= 825.c new file mode 100644 index 000000000000..102e24a1fb40 --- /dev/null +++ b/drivers/gpu/drm/bridge/ssd2825.c @@ -0,0 +1,821 @@ +// SPDX-License-Identifier: GPL-2.0 +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include