From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-lf1-f46.google.com (mail-lf1-f46.google.com [209.85.167.46]) (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 7FC933081B8 for ; Tue, 2 Dec 2025 08:26:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.167.46 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1764663981; cv=none; b=foC0O6BnJbecEC9UmkqyYEJrxqBva8t50X1TskT3NNpmTsxMVf8VdVyu90sAIzgGyeYvtpF5UXfX9W8OGc3iU3f41U083Yfb8LSM07uWrZelaatwBWh6RXjUIid3AVVfTp7NHiYKj6+5ruMtrlmsYuQwAKre4oxLOnrwpzBjqMY= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1764663981; c=relaxed/simple; bh=M2AEWs1PlE4kHIlUXzPT49FDEzkCCXRLe8Ws9kBRYLc=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=TyH4uRBv2CZqFA1XdjNaTBlVR4REsvo27szrNghPWPXpBjt8uUmzcYRbzuPcYyNncp8A0OUhMT+ys3DzFyT75PtoUtnyPTZR+t3BbLStlQ45YBGTg0WWRBIbwfon0Ij9R0IXc+naAH3IHEQrxS+cij+fa+6jIbbCed8pBSfUcU0= 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=XzV/w1gi; arc=none smtp.client-ip=209.85.167.46 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="XzV/w1gi" Received: by mail-lf1-f46.google.com with SMTP id 2adb3069b0e04-5943b62c47dso37877e87.1 for ; Tue, 02 Dec 2025 00:26:19 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1764663978; x=1765268778; darn=vger.kernel.org; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:from:to:cc:subject:date:message-id :reply-to; bh=OSUsJtZmVyJFMumy5C75Kafona0a7fDMqaNggZdL9to=; b=XzV/w1giwLgy5H3NHqMAhNB+7JVu4SKWCUaj5bEYmJAo/QL8RT5SVdIxQKjRiIU+il uA9HFTcB04VV558NH7sn/ZnxKjny7nkuZlkPz782lXzOkQ+zO6RSHwL2Nny0zuaa1ib6 Ipc9Xc3zALFEHic5PEEbx0AFXhaSyMWgackYeevHKSWPgorZttk2wzpc1wPAdSs7v4XQ 4xVX6/LmNQ0PjC3F+iP1kYYoNjTb9VPIdGjTqbHb1+2SixunPNtAygXT45JBdTeGnxD0 Ekt2vHXDq0x9AGnlNICxMo8fQjBqX142Wgd1ddtBjoXmpA2GE8QASqTt+QsO21/kXN+6 Bt8w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1764663978; x=1765268778; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:x-gm-gg:x-gm-message-state:from:to :cc:subject:date:message-id:reply-to; bh=OSUsJtZmVyJFMumy5C75Kafona0a7fDMqaNggZdL9to=; b=v+PmgATbXR1acLptN3CCEEFfjRkBXO0IJXXoIyM4F3qOq3JOiePdVQNEz5GDC3+eJk /MdkGSZCdAoNSYWWo34lozMLT7XdKbdbeJeS51lGQVdTgkcbN6qZdNGLMREjteJbYnWB wA8RXGzUF2IpV6oA6vG3X4deQx6ANrYz0taobA7AaH0BvDUIGcXwAVtq7Q0slLsAp81+ XNiW1XECyMhPzTEi5dEHDZdH2JOtVSwOF1LGU7L0DXwb9XMa/ADxyJbxEPTKi2d+Xej/ oIaJDWAuiRvgJa0OMW7aqHYcdp+HfSUvLNkciVCpveKL2db2onCiZTDXygeRtCFjhGfb Mscw== X-Forwarded-Encrypted: i=1; AJvYcCV4V/RTfwhA11wlMVFgbFVnvbsXo+VF3Kk6rRaO6wwAWeGuSusDRAVen71hLBDJ0MWwEaHwPoUDnHezpe4=@vger.kernel.org X-Gm-Message-State: AOJu0YynxOxJFW7xtYEud5vdsYAEprc90kKKQs0iqWQtQNgntB9bp8F9 nW5yy4Z6ltd9PuUzHrF3OVB/rlBP3SHKlx3OI8wU2jgGYJRGvJ3jcBoi X-Gm-Gg: ASbGncurL7ehRd1LPM/IAG69pfHgm1Z9YNgHzY4en6LnEhR9NdpaZuXUuQLIixqKdtu QYqQyQWKYeku+oOW3RHW3kjrzIi2Xe52LWWTopjBahNmDoUvSW6ndTHrxzkPvDBgUohWozeI4dM wppsbcESEdFD9YRLIwH8wrb1uNWmOWDggw4m7g1n72M1dOSnMDlFhFjYmAQv4R9mHULVUN571Ue uGzrN540KnwcWAJwsOmGV7tEkpePWLi+DFdoDOiVryhNVRqvZ4t1tDLXDZBvdYqneL7wauh/8vT THjCfhV02d+VUpxYjPehVCFMPUfhSDJfYrOoXCM+aUyxgXIn62FGlTNaGl0m3ZcZU5ZIu9+2jTT L0W8V/1w/LNQIeGTWlBEYATfVQQGc7F9JDqPsctqCmtDSX+B5x4IQTLitA3Ikn0Ud+fgqJEeLT+ piXwvcDePRQMF5byUNelul2xoTZsb84Epjv0F5FH9hMHzrSK2FSiX+XPi4ivMOd8BgeZA= X-Google-Smtp-Source: AGHT+IGjykhC2zoR8hTlVXXe+Skv0zw1/qAkZP6sy5Z13nSnub9A43A+C4Id3mGwfG9St6ZgSaDchA== X-Received: by 2002:a05:6512:1154:b0:595:7876:7b78 with SMTP id 2adb3069b0e04-596a3eac7edmr14185853e87.15.1764663977468; Tue, 02 Dec 2025 00:26:17 -0800 (PST) Received: from [192.168.1.168] (83-233-6-197.cust.bredband2.com. [83.233.6.197]) by smtp.gmail.com with ESMTPSA id 2adb3069b0e04-596bf8b06bcsm4423727e87.25.2025.12.02.00.26.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Dec 2025 00:26:16 -0800 (PST) From: Marcus Folkesson Date: Tue, 02 Dec 2025 09:25:22 +0100 Subject: [PATCH RESEND v2 6/6] drm/sitronix/st7571-spi: add support for SPI interface 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: 7bit Message-Id: <20251202-st7571-split-v2-6-1e537a09e92f@gmail.com> References: <20251202-st7571-split-v2-0-1e537a09e92f@gmail.com> In-Reply-To: <20251202-st7571-split-v2-0-1e537a09e92f@gmail.com> To: Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , Javier Martinez Canillas Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Marcus Folkesson X-Mailer: b4 0.14.3 X-Developer-Signature: v=1; a=openpgp-sha256; l=4371; i=marcus.folkesson@gmail.com; h=from:subject:message-id; bh=M2AEWs1PlE4kHIlUXzPT49FDEzkCCXRLe8Ws9kBRYLc=; b=owEBbQKS/ZANAwAKAYiATm9ZXVIyAcsmYgBpLqKZU7jBbtSJJ40+LT2OBg5HNtGXFaAbA3sIp HshImbm5RyJAjMEAAEKAB0WIQQFUaLotmy1TWTBLGWIgE5vWV1SMgUCaS6imQAKCRCIgE5vWV1S MnZ0D/wNq7LJe20xNdz7/iBRa3JcaSkQNJoiRTfDZCoOYmepqgB1lQeJREVhw3MeGoaDuK9oyNF 1SuhtEKY9mE+VzC5Ke+7r5nKm8H/fwMMPqWYtsFMzAotYbCO2EsCH0+GYYh15c6m6RBhKkCmIse NQkOeeRklldJG4jq+POUr1uhaBVC0dska4F+tYL+pMefWaHtvy9qGuJV0KGviBiMRQXv1JPE7Kh GM5wVFnKZxvgNy3BW0ZZwZ7ZzTeMJ5jJ2T4Ka5hzLN5kBAH2X3A3H2kaQln2fs/Rpmzx+Mn7T50 akLLeJMOcIm3Up4aepRr6mX/aW30Dd/IVcu+HOU70y9UZezwu1yDGmEWXoyZn7s4Peo9RGHnidW 1R/+AFxVyj8U1nbkUQtnoqa1VVDu/odnTUDs4w/u+2Z20OEzLzjtxjQLrY0r7FrAfaTiXMkGgAj aEPqDzJUcMvgNa+6kBsLtjy6m5DhiV74WpmE9G5KpmRWHhOXkGnd9sw8fJxVcUB310ZWOCHHulR X/UCtHrLXghCOYEo673Q0yI//JDtA4Ejb2R4JGmbu42iJfg6P+AIOUSb9ZcIfez5x/ifFJGZqY+ 6+rfzpiOOkwmF4E0DGmd9ZXfj9XC3MlZiAH9Y7OncUd9kB92hEUrmvsmgUNoQ8KvcZcJutyQYUX GJWWzutJ+G4EHUA== X-Developer-Key: i=marcus.folkesson@gmail.com; a=openpgp; fpr=AB91D46C7E0F6E6FB2AB640EC0FE25D598F6C127 Add support for ST7561/ST7571 connected to SPI bus. Signed-off-by: Marcus Folkesson --- MAINTAINERS | 1 + drivers/gpu/drm/sitronix/Kconfig | 12 ++++++ drivers/gpu/drm/sitronix/Makefile | 1 + drivers/gpu/drm/sitronix/st7571-spi.c | 76 +++++++++++++++++++++++++++++++++++ 4 files changed, 90 insertions(+) diff --git a/MAINTAINERS b/MAINTAINERS index 66e9ffb757c8..c89e521cafa1 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -8083,6 +8083,7 @@ S: Maintained F: Documentation/devicetree/bindings/display/sitronix,st7567.yaml F: Documentation/devicetree/bindings/display/sitronix,st7571.yaml F: drivers/gpu/drm/sitronix/st7571-i2c.c +F: drivers/gpu/drm/sitronix/st7571-spi.c F: drivers/gpu/drm/sitronix/st7571.c F: drivers/gpu/drm/sitronix/st7571.h diff --git a/drivers/gpu/drm/sitronix/Kconfig b/drivers/gpu/drm/sitronix/Kconfig index 0676a86661ca..2204250ab413 100644 --- a/drivers/gpu/drm/sitronix/Kconfig +++ b/drivers/gpu/drm/sitronix/Kconfig @@ -27,6 +27,18 @@ config DRM_ST7571_I2C if M is selected the module will be called st7571-i2c. +config DRM_ST7571_SPI + tristate "DRM support for Sitronix ST7567/ST7571 display panels (SPI)" + depends on DRM_ST7571 && SPI + select REGMAP_SPI + help + Sitronix ST7571 is a driver and controller for 4-level gray + scale and monochrome dot matrix LCD panels. + + DRM driver for Sitronix ST7565/ST7571 panels connected via SPI bus. + + if M is selected the module will be called st7571-spi. + config DRM_ST7586 tristate "DRM support for Sitronix ST7586 display panels" depends on DRM && SPI diff --git a/drivers/gpu/drm/sitronix/Makefile b/drivers/gpu/drm/sitronix/Makefile index 8073bb776ff9..c631e3359c3d 100644 --- a/drivers/gpu/drm/sitronix/Makefile +++ b/drivers/gpu/drm/sitronix/Makefile @@ -1,4 +1,5 @@ obj-$(CONFIG_DRM_ST7571) += st7571.o obj-$(CONFIG_DRM_ST7571_I2C) += st7571-i2c.o +obj-$(CONFIG_DRM_ST7571_SPI) += st7571-spi.o obj-$(CONFIG_DRM_ST7586) += st7586.o obj-$(CONFIG_DRM_ST7735R) += st7735r.o diff --git a/drivers/gpu/drm/sitronix/st7571-spi.c b/drivers/gpu/drm/sitronix/st7571-spi.c new file mode 100644 index 000000000000..0206e9162f1c --- /dev/null +++ b/drivers/gpu/drm/sitronix/st7571-spi.c @@ -0,0 +1,76 @@ +// SPDX-License-Identifier: GPL-2.0-or-later +/* + * Driver for Sitronix ST7571 connected via SPI bus. + * + * Copyright (C) 2025 Marcus Folkesson + */ + +#include +#include +#include + +#include "st7571.h" + +static const struct regmap_config st7571_spi_regmap_config = { + .reg_bits = 8, + .val_bits = 8, + .can_multi_write = true, +}; + +static int st7571_spi_probe(struct spi_device *spi) +{ + struct st7571_device *st7571; + struct regmap *regmap; + + regmap = devm_regmap_init_spi(spi, &st7571_spi_regmap_config); + if (IS_ERR(regmap)) { + return dev_err_probe(&spi->dev, PTR_ERR(regmap), + "Failed to initialize regmap\n"); + } + + st7571 = st7571_probe(&spi->dev, regmap); + if (IS_ERR(st7571)) + return dev_err_probe(&spi->dev, PTR_ERR(st7571), + "Failed to initialize regmap\n"); + + spi_set_drvdata(spi, st7571); + return 0; +} + +static void st7571_spi_remove(struct spi_device *spi) +{ + struct st7571_device *st7571 = spi_get_drvdata(spi); + + st7571_remove(st7571); +} + +static const struct of_device_id st7571_of_match[] = { + { .compatible = "sitronix,st7567", .data = &st7567_config }, + { .compatible = "sitronix,st7571", .data = &st7571_config }, + {}, +}; +MODULE_DEVICE_TABLE(of, st7571_of_match); + +static const struct spi_device_id st7571_spi_id[] = { + { "st7567", 0 }, + { "st7571", 0 }, + { } +}; +MODULE_DEVICE_TABLE(spi, st7571_spi_id); + +static struct spi_driver st7571_spi_driver = { + .driver = { + .name = "st7571-spi", + .of_match_table = st7571_of_match, + }, + .probe = st7571_spi_probe, + .remove = st7571_spi_remove, + .id_table = st7571_spi_id, +}; + +module_spi_driver(st7571_spi_driver); + +MODULE_AUTHOR("Marcus Folkesson "); +MODULE_DESCRIPTION("DRM Driver for Sitronix ST7571 LCD controller (SPI)"); +MODULE_LICENSE("GPL"); +MODULE_IMPORT_NS("DRM_ST7571"); -- 2.51.2