Received: by 2002:a17:90b:8d0:0:0:0:0 with SMTP id ds16csp5059634pjb; Mon, 27 Jul 2020 11:52:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyTZWWJNHLh2oT55vugK3zx9CbJOZTSij5O1eUicjExB3CZ/C+wMxZdLnIwZBqPDNTdeCBZ X-Received: by 2002:a17:906:7a4d:: with SMTP id i13mr7921222ejo.351.1595875964005; Mon, 27 Jul 2020 11:52:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595875963; cv=none; d=google.com; s=arc-20160816; b=w4j6yJlNcDoIlx9a1YDNQky62pry6WufIS6JyKHkk1/blb6FG/LmeCS0dthiLugzk+ NW5ARES8ql56xJbwBJi2XBkfSmTFqx+aaXdovgcRDBURXlJa98z53wuQ3iclK4Neh6aF zEhIgCTh+AkMQ/NQhvWAiWFzht67WDeRIBskYS93O+AZDDljhZVsj5W5QXaXhvFF+wfP xd31jNxHHiCrXKxJBhsOpnxCKbU6Nu0X9BEmfSPkwwzS+DwFBG+JN7bRWRhB+5v7vvdU o2K8GwChu/961hABZTbM+Jh2wpVee4Fwkq7PaVOuTIeRhbY/ooq+0U+pvqdl5eryr1hN iSgg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=zsd9mflfQcsk+xgJqhjXGlGwSK2UjhoZdPN7rSg5rKU=; b=Oe8odVOi1BNYhtUPTwGf9ou+8kuF4BKo4MygVN7RfZYUIXRsHHnnlg+lWDsi8t1bOu FI5Isz/Z4pC+vvaxtwOv2kkwe3uz3I2VFXxsUJjR412a5uqx6tMzTJ36UfCN2Jqc4HGf JA+Yd9fhAPLBaBb6U8aBSSkUEX2j2Oo0QNXHViEPFtKwgaAZ2YFwgNrnJFafBiM8TGD7 bYCqsx5/ZAg6KftWlcDK/ZvtOR5a4f09SFrHH+ULBFKiN8fiQhxIWMdKcc2ujR8E8hVR jH2tVIHo6TXAsAhxSOsIHPskRYvkoUy0yxQnT2eHZ5mxfHqiTKX9RzToRGPlfBOav5FC jY6w== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@crapouillou.net header.s=mail header.b=PEM5Xzoo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=crapouillou.net Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m16si5928328eji.77.2020.07.27.11.52.21; Mon, 27 Jul 2020 11:52:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@crapouillou.net header.s=mail header.b=PEM5Xzoo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=crapouillou.net Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729005AbgG0Qqx (ORCPT + 99 others); Mon, 27 Jul 2020 12:46:53 -0400 Received: from crapouillou.net ([89.234.176.41]:37410 "EHLO crapouillou.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726753AbgG0Qqw (ORCPT ); Mon, 27 Jul 2020 12:46:52 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=crapouillou.net; s=mail; t=1595868393; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=zsd9mflfQcsk+xgJqhjXGlGwSK2UjhoZdPN7rSg5rKU=; b=PEM5XzooHWjJnb5Ltc4NFn76PNXFHlBQN6JyCi0irT3T0q5qPYMq2T/fb6CLfbuhfPjxE0 OU/l4fH6cZCd7GXwYpCEC7vsCDS8tjzJQsbz3ebkZzZuRabF/hNMt0yKHyYyT/TR2oW8CS LHuw71OK9rzYC7X3Rs+yLbxcbUeKRAk= From: Paul Cercueil To: Thierry Reding , Sam Ravnborg , David Airlie , Daniel Vetter , Rob Herring , Andrzej Hajda , Neil Armstrong , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , =?UTF-8?q?Noralf=20Tr=C3=B8nnes?= Cc: od@zcrc.me, dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Paul Cercueil Subject: [PATCH 3/6] drm/bridge: Add SPI DBI host driver Date: Mon, 27 Jul 2020 18:46:10 +0200 Message-Id: <20200727164613.19744-4-paul@crapouillou.net> In-Reply-To: <20200727164613.19744-1-paul@crapouillou.net> References: <20200727164613.19744-1-paul@crapouillou.net> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This driver will register a DBI host driver for panels connected over SPI. DBI types c1 and c3 are supported. C1 is a SPI protocol with 9 bits per word, with the data/command information in the 9th (MSB) bit. C3 is a SPI protocol with 8 bits per word, with the data/command information carried by a separate GPIO. Signed-off-by: Paul Cercueil --- drivers/gpu/drm/bridge/Kconfig | 8 + drivers/gpu/drm/bridge/Makefile | 1 + drivers/gpu/drm/bridge/dbi-spi.c | 261 +++++++++++++++++++++++++++++++ 3 files changed, 270 insertions(+) create mode 100644 drivers/gpu/drm/bridge/dbi-spi.c diff --git a/drivers/gpu/drm/bridge/Kconfig b/drivers/gpu/drm/bridge/Kconfig index c7f0dacfb57a..ed38366847c1 100644 --- a/drivers/gpu/drm/bridge/Kconfig +++ b/drivers/gpu/drm/bridge/Kconfig @@ -219,6 +219,14 @@ config DRM_TI_TPD12S015 Texas Instruments TPD12S015 HDMI level shifter and ESD protection driver. +config DRM_MIPI_DBI_SPI + tristate "SPI host support for MIPI DBI" + depends on OF && SPI + select DRM_MIPI_DSI + select DRM_MIPI_DBI + help + Driver to support DBI over SPI. + source "drivers/gpu/drm/bridge/analogix/Kconfig" source "drivers/gpu/drm/bridge/adv7511/Kconfig" diff --git a/drivers/gpu/drm/bridge/Makefile b/drivers/gpu/drm/bridge/Makefile index 7d7c123a95e4..c2c522c2774f 100644 --- a/drivers/gpu/drm/bridge/Makefile +++ b/drivers/gpu/drm/bridge/Makefile @@ -20,6 +20,7 @@ obj-$(CONFIG_DRM_I2C_ADV7511) += adv7511/ obj-$(CONFIG_DRM_TI_SN65DSI86) += ti-sn65dsi86.o obj-$(CONFIG_DRM_TI_TFP410) += ti-tfp410.o obj-$(CONFIG_DRM_TI_TPD12S015) += ti-tpd12s015.o +obj-$(CONFIG_DRM_MIPI_DBI_SPI) += dbi-spi.o obj-$(CONFIG_DRM_NWL_MIPI_DSI) += nwl-dsi.o obj-y += analogix/ diff --git a/drivers/gpu/drm/bridge/dbi-spi.c b/drivers/gpu/drm/bridge/dbi-spi.c new file mode 100644 index 000000000000..1060b8f95fba --- /dev/null +++ b/drivers/gpu/drm/bridge/dbi-spi.c @@ -0,0 +1,261 @@ +// SPDX-License-Identifier: GPL-2.0-or-later +/* + * MIPI Display Bus Interface (DBI) SPI support + * + * Copyright 2016 Noralf Trønnes + * Copyright 2020 Paul Cercueil + */ + +#include +#include +#include + +#include +#include + +#include