Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp810486ybi; Fri, 26 Jul 2019 20:30:24 -0700 (PDT) X-Google-Smtp-Source: APXvYqwS+LG92e32EfpJAhB2uXvSH+gH+BWvCeD5Yht5OQN57QnDGSTOYidjo7aE7gP/yXK+p0jB X-Received: by 2002:a63:fb14:: with SMTP id o20mr82297567pgh.136.1564198224053; Fri, 26 Jul 2019 20:30:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564198224; cv=none; d=google.com; s=arc-20160816; b=ZCluI3F2t119SB0Yz+e1MR0nCUOU14DFMt6usv9WWKLsaWi+H9hGjSnt9UhcsYKDkk yPgrEeH4AsB3BU2aB85q6zPt66EDUkxHyEO4kHWr8iR2g1wQF8wgCP/4jNsFZgeT3wFF WJ2G9pbnMqopo+ww1s62gyHjNCXM6ubLHPj3CLjaedXH/yvZ6wRGgzjbH+n/XmSM90mO /iM++C5qQqFDOIm81+6+Rof8VnjJDsmbNiKLid3E8cLOkVb+sTXeQgjknedp4SsWE3Tg EKILsLv9NAYBhFJtH3ZXjuuKULA55StzR5gj3PV56PIbfqGgS97huIUARh0+nJkE2wpE uylw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=oIfl/AtTVtmgBf0TKxRYhTV3MQtpsDZFFZ35mr7D59g=; b=NkMSPDkY2OUc/K0TfJ93RAPyfkJtCDohUQmQMp+20mEjOSH6WOtiJwQ0QMH96K8pO0 /xNRk50x8XbLROgZ83ZS25Z0kMvDL8l8hxrudO0q2JUYcC2Pb8ohRpfoSnKSR6Wj9J1K 5eqd/s3xB5eCr+ifWM6xkEobtyH8OT1rE8V2l2Mb7yhPsCkBeGDbR10oaQKQnUHQneA+ lOU18sm+K3A3fh1t761M3UGJUp3+Mqx5oPLAuSVuojxcOE9+NNVKRWmJhdEHFBH6EYHE wiGHmZMhWYbkBclnuGXA3V29AmSzOWxa77Ei+1BBENR0RqJl+eBY3aa+2PyRX6VbCm8b 1h/Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=avqfMP2O; 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 5si20690191plx.200.2019.07.26.20.30.08; Fri, 26 Jul 2019 20:30:24 -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; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=avqfMP2O; 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 S1726951AbfG0CrR (ORCPT + 99 others); Fri, 26 Jul 2019 22:47:17 -0400 Received: from perceval.ideasonboard.com ([213.167.242.64]:53210 "EHLO perceval.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726415AbfG0CrR (ORCPT ); Fri, 26 Jul 2019 22:47:17 -0400 Received: from pendragon.ideasonboard.com (om126200118163.15.openmobile.ne.jp [126.200.118.163]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 49F6A2E7; Sat, 27 Jul 2019 04:47:05 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1564195628; bh=ytPZCVH4pJPLeq+S11a8RJtySUSSV+9KfZLRjRZ7HHE=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=avqfMP2O9nK6Gs5n3FRbvqZ8ECxTsTeV7sPdkqGQLQQsxNtlfzk4hKXOlHT0GSZar U9uFiykIwIb4bdW+6tgXRuXdGYNWguctswAoh+8P2o+rFmGIirPzLgdXMhjD9wmjtE 27qqhH4AiYzGGiIvyQ4ggPI5af7b4PWVpTmOSNT8= Date: Sat, 27 Jul 2019 05:47:00 +0300 From: Laurent Pinchart To: Guido =?utf-8?Q?G=C3=BCnther?= Cc: David Airlie , Daniel Vetter , Rob Herring , Mark Rutland , Shawn Guo , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , NXP Linux Team , Andrzej Hajda , Neil Armstrong , Jonas Karlman , Jernej Skrabec , Lee Jones , dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Robert Chiras Subject: Re: [PATCH 3/3] drm/bridge: Add NWL MIPI DSI host controller support Message-ID: <20190727024700.GD4902@pendragon.ideasonboard.com> References: <3158f4f8c97c21f98c394e5631d74bc60d796522.1563983037.git.agx@sigxcpu.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <3158f4f8c97c21f98c394e5631d74bc60d796522.1563983037.git.agx@sigxcpu.org> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello Guido, Thank you for the patch. On Wed, Jul 24, 2019 at 05:52:26PM +0200, Guido Günther wrote: > 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" > + As this doesn't seem to be an i.MX-specific IP, I wouldn't use the name imx in file names or in the code, at least in the parts that are not NXP-specific. > 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 This doesn't seem to be needed. > +#include > +#include Same here. > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include