Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp345299ybl; Mon, 2 Dec 2019 11:37:28 -0800 (PST) X-Google-Smtp-Source: APXvYqyvDLvZ/wlG9+jJ0w+1AswlDoUBsBppjLCn4a4g4eymGI8D77xvpl+09IQNcCQjjFxWklv1 X-Received: by 2002:a17:906:7c5:: with SMTP id m5mr927870ejc.231.1575315448716; Mon, 02 Dec 2019 11:37:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575315448; cv=none; d=google.com; s=arc-20160816; b=wT0WzvKMBL8WJ02J5q0Fp7oAQ/R2wfEuxB1cQcKKLIbop2h4fPndHp6SzK6V5khaSl fROMPzqrkECQmWO7FAyX8Abfj/hVXCpCDdAi0+BTz+gyBh/F0Jwx+VhDbOVziu5szJsA yWIKbEJERxYNxYFLZCmpIVTHMzT7rRRJEQDALV5REeAkTawY66FO8BtyEDTyfL3xjJLP 1ZF5OP46FLlsQQw3rqBfi2P/u/0o0cNYE7VNwSgTT25Vt0A0/udCqKeOj4t6lG2/O6wo k9BKfs1dmQvxylqevu1PBk97dSIro6OL+h0ooh8JerNW1Cbg9v6oQvfBXszJn7HX/VH2 3nXA== 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:to:from; bh=RVtH++FntXNNFsQaiP1OUzlyrKZiG9gyyaBmfyfLIsM=; b=SmZS2c0J/EowFCnEeZ5duuvQY3ogInBmQRtjxRbwVXc9ciJly9wEQESL0TeIALGWs/ iq2nNS/NReQZzj5YEdXK9vSrfS4qUfsgpaoUJ4lAJrO9nXaRwvPIq8ig80ycRP2v9RFG jtCRXTngL4UxTlPP7mzXtgeWumEy4frhuNgRA7D/Stin7bYbMHph0XK/tR9oJIhpE1Sp 4I9+pXbpQZZ0/CrWBMC3tqqq73my7VQHYAySyh9vopAwAVce4gyF4NnrC/fykDmJdi/r YAKGow4HWV5eOM47ngLuvgZuzqkxtkXwwolcjLOJw8YdhiDsHJQ/bRa13ekzD+C/NiSF L5+g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h36si330838eda.206.2019.12.02.11.37.04; Mon, 02 Dec 2019 11:37:28 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728117AbfLBTfV (ORCPT + 99 others); Mon, 2 Dec 2019 14:35:21 -0500 Received: from honk.sigxcpu.org ([24.134.29.49]:37496 "EHLO honk.sigxcpu.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728001AbfLBTfV (ORCPT ); Mon, 2 Dec 2019 14:35:21 -0500 Received: from localhost (localhost [127.0.0.1]) by honk.sigxcpu.org (Postfix) with ESMTP id 20E71FB07; Mon, 2 Dec 2019 20:35:18 +0100 (CET) X-Virus-Scanned: Debian amavisd-new at honk.sigxcpu.org Received: from honk.sigxcpu.org ([127.0.0.1]) by localhost (honk.sigxcpu.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id 08wWtg_oT9Yn; Mon, 2 Dec 2019 20:35:08 +0100 (CET) Received: by bogon.sigxcpu.org (Postfix, from userid 1000) id 905DA49221; Mon, 2 Dec 2019 20:35:03 +0100 (CET) From: =?UTF-8?q?Guido=20G=C3=BCnther?= To: David Airlie , Daniel Vetter , Rob Herring , Mark Rutland , Shawn Guo , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , NXP Linux Team , Andrzej Hajda , Neil Armstrong , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , Lee Jones , =?UTF-8?q?Guido=20G=C3=BCnther?= , dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Robert Chiras , Sam Ravnborg , Arnd Bergmann Subject: [PATCH v8 2/2] drm/bridge: Add NWL MIPI DSI host controller support Date: Mon, 2 Dec 2019 20:35:03 +0100 Message-Id: X-Mailer: git-send-email 2.23.0 In-Reply-To: References: 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 adds initial support for the NWL MIPI DSI Host controller found on i.MX8 SoCs. It adds support for the i.MX8MQ but the same IP can be found on e.g. the i.MX8QXP. It has been tested on the Librem 5 devkit using mxsfb. Signed-off-by: Guido Günther Co-developed-by: Robert Chiras Signed-off-by: Robert Chiras Tested-by: Robert Chiras --- drivers/gpu/drm/bridge/Kconfig | 16 + drivers/gpu/drm/bridge/Makefile | 3 + drivers/gpu/drm/bridge/nwl-dsi.c | 1230 ++++++++++++++++++++++++++++++ drivers/gpu/drm/bridge/nwl-dsi.h | 144 ++++ 4 files changed, 1393 insertions(+) create mode 100644 drivers/gpu/drm/bridge/nwl-dsi.c create mode 100644 drivers/gpu/drm/bridge/nwl-dsi.h diff --git a/drivers/gpu/drm/bridge/Kconfig b/drivers/gpu/drm/bridge/Kconfig index 34362976cd6f..6fb534f55d22 100644 --- a/drivers/gpu/drm/bridge/Kconfig +++ b/drivers/gpu/drm/bridge/Kconfig @@ -65,6 +65,22 @@ config DRM_MEGACHIPS_STDPXXXX_GE_B850V3_FW to DP++. This is used with the i.MX6 imx-ldb driver. You are likely to say N here. +config DRM_NWL_MIPI_DSI + tristate "Northwest Logic MIPI DSI Host controller" + depends on DRM + depends on COMMON_CLK + depends on OF && HAS_IOMEM + select DRM_KMS_HELPER + select DRM_MIPI_DSI + select DRM_PANEL_BRIDGE + select GENERIC_PHY_MIPI_DPHY + select MFD_SYSCON + select MULTIPLEXER + select REGMAP_MMIO + help + This enables the Northwest Logic MIPI DSI Host controller as + for example found on NXP's i.MX8 Processors. + config DRM_NXP_PTN3460 tristate "NXP PTN3460 DP/LVDS bridge" depends on OF diff --git a/drivers/gpu/drm/bridge/Makefile b/drivers/gpu/drm/bridge/Makefile index 4934fcf5a6f8..c3f3a43e9b8f 100644 --- a/drivers/gpu/drm/bridge/Makefile +++ b/drivers/gpu/drm/bridge/Makefile @@ -16,4 +16,7 @@ obj-$(CONFIG_DRM_ANALOGIX_DP) += analogix/ 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_NWL_MIPI_DSI) += nwl-dsi.o obj-y += synopsys/ + +header-test-y += nwl-dsi.h diff --git a/drivers/gpu/drm/bridge/nwl-dsi.c b/drivers/gpu/drm/bridge/nwl-dsi.c new file mode 100644 index 000000000000..023191894fe4 --- /dev/null +++ b/drivers/gpu/drm/bridge/nwl-dsi.c @@ -0,0 +1,1230 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * i.MX8 NWL MIPI DSI host driver + * + * Copyright (C) 2017 NXP + * Copyright (C) 2019 Purism SPC + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include + +#include