Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp9787667ybi; Wed, 24 Jul 2019 09:58:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqy5Qy1VR4ANbnd0A4RyTTiu6pX9Y3tPqyA22PocTilUADZzokk6sZqxNIhodvNOICi3wi/B X-Received: by 2002:a17:90a:8c18:: with SMTP id a24mr86065296pjo.111.1563987488757; Wed, 24 Jul 2019 09:58:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563987488; cv=none; d=google.com; s=arc-20160816; b=OdTPRSuEHeKFv3bszHIBlEtN1UGuJrcQWC5qmGv98EibsNKze8rSuZNyV8arMUQIX7 w2E1kQmpqrBBBrpJqzccEotbajbNRjGxK80KBj+pEZqguFAY4hVcd/tJum6l7UApZOX3 riz/5FrzPl4DCFN3vMiODUQSxOy6HMOP8HgHGui9nD5TBKMs8oPNjlJ1pqsEi2hV1APp ii+LzEJVdmhS4Pbr8djUmA1J2u73Yj2QWLFirbnzttEQWb3d+yQP3JvQ3S+hmqRI38k+ YlqUQrtwGnnQIsntKU0FRoA4XVeAeVo9nO28ZNQfmsAgJMbIgklqyxrD6kz5pepHIXlj 4p1Q== 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=GpyGsJMHEYvGVx3MsQY4KE9kpEOxt1WrTEcKsxprr8g=; b=mr2xQcu8gj8vQP8wYVFSVOoGX1+kOm6pX53XHXXfNoz1i8F/3dOqidO4JQfZWTuQAL 7/ijRNGzpOxjK4iE7k7LwBvTVkF9l+1V5r9hq5yVpubkChxI+mQz7g7B2gMS6QEfwOwP 88j0AdLsJ0HoN1ero4AnnQ2kDRU6MCR2KysFiIRccfXoj+tGWWc6tvkywGPIT0eI6t2B Je5BY5eEQ4ahkN/ZH7/I70MycaXrMWPe/7ELWpuN3jRpdK8gX9JvHNX5+YDo5FwmLrhW hjyG48CH2MIrP5tgghuizFnZfAqhXR3rTyDO9N5r8KXaCk1EYkenc7Ea2BVb9kqAMKUI +DWQ== 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 r199si18491427pfr.233.2019.07.24.09.57.52; Wed, 24 Jul 2019 09:58:08 -0700 (PDT) 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 S2387636AbfGXPwl (ORCPT + 99 others); Wed, 24 Jul 2019 11:52:41 -0400 Received: from honk.sigxcpu.org ([24.134.29.49]:33626 "EHLO honk.sigxcpu.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726371AbfGXPwj (ORCPT ); Wed, 24 Jul 2019 11:52:39 -0400 Received: from localhost (localhost [127.0.0.1]) by honk.sigxcpu.org (Postfix) with ESMTP id 24627FB07; Wed, 24 Jul 2019 17:52:37 +0200 (CEST) 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 KKtyjt1LKN-F; Wed, 24 Jul 2019 17:52:30 +0200 (CEST) Received: by bogon.sigxcpu.org (Postfix, from userid 1000) id 173364341C; Wed, 24 Jul 2019 17:52:27 +0200 (CEST) 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 Subject: [PATCH 3/3] drm/bridge: Add NWL MIPI DSI host controller support Date: Wed, 24 Jul 2019 17:52:26 +0200 Message-Id: <3158f4f8c97c21f98c394e5631d74bc60d796522.1563983037.git.agx@sigxcpu.org> X-Mailer: git-send-email 2.20.1 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 --- drivers/gpu/drm/bridge/Kconfig | 2 + drivers/gpu/drm/bridge/Makefile | 1 + drivers/gpu/drm/bridge/imx-nwl/Kconfig | 15 + drivers/gpu/drm/bridge/imx-nwl/Makefile | 2 + drivers/gpu/drm/bridge/imx-nwl/nwl-drv.c | 529 ++++++++++++++++ drivers/gpu/drm/bridge/imx-nwl/nwl-drv.h | 72 +++ drivers/gpu/drm/bridge/imx-nwl/nwl-dsi.c | 745 +++++++++++++++++++++++ drivers/gpu/drm/bridge/imx-nwl/nwl-dsi.h | 111 ++++ 8 files changed, 1477 insertions(+) create mode 100644 drivers/gpu/drm/bridge/imx-nwl/Kconfig create mode 100644 drivers/gpu/drm/bridge/imx-nwl/Makefile create mode 100644 drivers/gpu/drm/bridge/imx-nwl/nwl-drv.c create mode 100644 drivers/gpu/drm/bridge/imx-nwl/nwl-drv.h create mode 100644 drivers/gpu/drm/bridge/imx-nwl/nwl-dsi.c create mode 100644 drivers/gpu/drm/bridge/imx-nwl/nwl-dsi.h diff --git a/drivers/gpu/drm/bridge/Kconfig b/drivers/gpu/drm/bridge/Kconfig index a6eec908c43e..38c3145a7e57 100644 --- a/drivers/gpu/drm/bridge/Kconfig +++ b/drivers/gpu/drm/bridge/Kconfig @@ -152,6 +152,8 @@ source "drivers/gpu/drm/bridge/analogix/Kconfig" source "drivers/gpu/drm/bridge/adv7511/Kconfig" +source "drivers/gpu/drm/bridge/imx-nwl/Kconfig" + source "drivers/gpu/drm/bridge/synopsys/Kconfig" endmenu diff --git a/drivers/gpu/drm/bridge/Makefile b/drivers/gpu/drm/bridge/Makefile index 4934fcf5a6f8..904a9eb3a20a 100644 --- a/drivers/gpu/drm/bridge/Makefile +++ b/drivers/gpu/drm/bridge/Makefile @@ -16,4 +16,5 @@ 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-y += imx-nwl/ obj-y += synopsys/ diff --git a/drivers/gpu/drm/bridge/imx-nwl/Kconfig b/drivers/gpu/drm/bridge/imx-nwl/Kconfig new file mode 100644 index 000000000000..822dba1b380a --- /dev/null +++ b/drivers/gpu/drm/bridge/imx-nwl/Kconfig @@ -0,0 +1,15 @@ +config DRM_IMX_NWL_DSI + tristate "Support for Northwest Logic MIPI DSI Host controller" + depends on DRM && (ARCH_MXC || ARCH_MULTIPLATFORM || COMPILE_TEST) + 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 REGMAP_MMIO + help + This enables the Northwest Logic MIPI DSI Host controller as + found on NXP's i.MX8 Processors. + diff --git a/drivers/gpu/drm/bridge/imx-nwl/Makefile b/drivers/gpu/drm/bridge/imx-nwl/Makefile new file mode 100644 index 000000000000..9fa63483da5b --- /dev/null +++ b/drivers/gpu/drm/bridge/imx-nwl/Makefile @@ -0,0 +1,2 @@ +imx-nwl-objs := nwl-drv.o nwl-dsi.o +obj-$(CONFIG_DRM_IMX_NWL_DSI) += imx-nwl.o diff --git a/drivers/gpu/drm/bridge/imx-nwl/nwl-drv.c b/drivers/gpu/drm/bridge/imx-nwl/nwl-drv.c new file mode 100644 index 000000000000..451f8f067c6f --- /dev/null +++ b/drivers/gpu/drm/bridge/imx-nwl/nwl-drv.c @@ -0,0 +1,529 @@ +// 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