Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp3278714img; Mon, 25 Mar 2019 07:15:51 -0700 (PDT) X-Google-Smtp-Source: APXvYqwct3sd/LWOkmQqVOfjkRbifIuRGDmmqEGpEiFaGId0Bbd4SLnfmilajrLXeugE2U2JwQHz X-Received: by 2002:a17:902:6b08:: with SMTP id o8mr25633173plk.105.1553523351891; Mon, 25 Mar 2019 07:15:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553523351; cv=none; d=google.com; s=arc-20160816; b=Id4kf7FLCtBFp4B08z8yLQgfbuiwYIOM84nV086w16K3CNFR2YDi6SDDT2BUM+z6iv oMtzjtwpqmdjmndDONyY3l2DTigQKj0pH6iclvw26RYMLoP2b2mLTr/7tBBzYcvW/3LR W82UFbJyFrzGHI1woEGKEWw2dxXAGH3sc2wuAzLZ6zKAYWEMb5lZWIZ7Mj16Pu+yhDG9 oj8cGQPdthef/8VuIXs9YpFIfBSaz+2tQyIzHfGh3RD5GFanE0AFp36ZXdPamKz6ZF2C ihrTpByzNuMWKBLfswfgbtEOoNVvg9gJGTjBgHt14itioVzrYyKgzbsPkO+gV5MQZ/2a qozA== 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 :message-id:date:subject:to:from; bh=ZfMW1OeHu9y6av8j3AaCBJY1cmEUBy0iJ/MP04eEbDs=; b=St30+v61aHS9tN86V3OruJ5VyAJlv3GAdBbXvsaqbsAilnT1ezId3C8Czz/nqY+T8Z bkh4LOy9b7cQa4jd+ChXckAPY3nEYYJzQXExe66GvyPvCqL1lwDufeEjweFIVr2g8mFy PgbMxselu6SgQS/l2mNPaJs+n+R2AjyGPDA4F3XZWkivcwU/SkRIPnNhV+RxmJLtgeRa WoZCtQwC0YfUbx77nxIA7vx7KNWdEcou6GItxSFV93akPI/eHuFaNjKY3Iwfn+n8tx9z zyty7j5KEQ7YEPdbXtSm2xXHpfgBaLiiWy1Cv2MLpEEU5IHBCSNi7R/ilEcazclJHWUl OLGg== 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 t16si13312375pgu.51.2019.03.25.07.15.37; Mon, 25 Mar 2019 07:15:51 -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 S1729169AbfCYOOz (ORCPT + 99 others); Mon, 25 Mar 2019 10:14:55 -0400 Received: from honk.sigxcpu.org ([24.134.29.49]:47357 "EHLO honk.sigxcpu.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726194AbfCYOOv (ORCPT ); Mon, 25 Mar 2019 10:14:51 -0400 Received: from localhost (localhost [127.0.0.1]) by honk.sigxcpu.org (Postfix) with ESMTP id EC398FB04; Mon, 25 Mar 2019 15:14:49 +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 kNvEXCclaEH0; Mon, 25 Mar 2019 15:14:44 +0100 (CET) Received: by bogon.sigxcpu.org (Postfix, from userid 1000) id C7B1C4027E; Mon, 25 Mar 2019 15:14:43 +0100 (CET) From: =?UTF-8?q?Guido=20G=C3=BCnther?= To: Maxime Ripard , dri-devel@lists.freedesktop.org, linux-arm-kernel@lists.infradead.org, Robert Chiras , Sam Ravnborg , Fabio Estevam , linux-kernel@vger.kernel.org Subject: [PATCH v7 0/3] Mixel DPHY support for i.MX8 Date: Mon, 25 Mar 2019 15:14:40 +0100 Message-Id: X-Mailer: git-send-email 2.20.1 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 tl;dr: v7 fixes a build issued due to the lack of a HAS_IOMEM This adds initial support for the Mixel IP based mipi dphy as found on i.MX8 processors. It has support for the i.MX8MQ, support for other variants can be added - once the platform specific parts are in - via the provided devdata. The driver is somewhat based on what's found in NXPs BSP. Public documentation on the DPHY's registers is currently thin in the i.MX8 reference manuals (even on the i.MX8QXP form 11/18) so most of the values were taken from existing drivers. Newer NXP drivers have a bit more details so where possible the timings are calculated and validated. I've also sent out an initial version of a NWL mipi dsi host controller driver using this: https://lists.freedesktop.org/archives/dri-devel/2019-March/209685.html Robert Chiras (the author of the corresponding driver in NXPs vendor tree) got this driver to work in his tree as well: https://www.spinics.net/lists/arm-kernel/msg711950.html Chages from v6 * Depend on HAS_IOMEM (fixes a build problem on UM spotted by kbuild) Chages from v5 * Fix build problems on mips (spotted by the kbuild test robot) by using u32 consistently and long long for lp_t. Changes from v4 * Build by default on ARCH_MXC && ARM64 Changes form v3 * Check correct variable after devm_ioremap_resource * Add Robert Chiras as Co-authored-by since he's the author of the driver in NXPs BSP. Changes from v2 * As per review comments from Fabio Estevam * KConfig: select REGMAP_MMIO * Drop phy_read * Don't make phy_write inline * Remove duplicate debugging output * Comment style and typo fixes * Add #defines's for PLL lock timing values * Return correct error value when PLL fails to lock * Check error when enabling clock * Use devm_ioremap_resource * As per review comments from Robert Chiras * Deassert PD_DPHY after PLL lock (as per mixel ref manual) * Assert PD_{DPHY,PLL} before power on (as per mixel ref manual)manual * Add exit phy_op to reset CN/CM/CO Changes from v1 * As per review comments from Fabio Estevam * Kconfig: tristate mixel dphy support. * Drop unused 'ret' in mixel_dphy_ref_power_off. * Match values of DPHY_RXL{PRP,DRP} to those of https://source.codeaurora.org/external/imx/linux-imx/log/?h=imx_4.14.78_1.0.0_ga The previous values were based on 4.9. * Use resource size on devm_ioremap, we have that in dt already. * Use regmap so it's simple to dump the registers. * Use regmap_read_poll_timeout instead of open coded loop. * Add undocumented rxhs_settle register * As per review comments from Sam Ravnborg * Move driver to d/phy/freescale/ * Move SPDX-License-Identifier to top of file. * Drop '/* #define DEBUG 1 */'. * Use GPL-2.0+ since the vendor driver uses that as well. * Drop the mutex, register access is now protected by regmap. * Fix various style / indentation issues. * Check for register read, write and ioremap errors * Improve phy timing calculations * Use LP clock rate where sensible, check for errors * Use ad hoc forumulas for timings involving hs clock * Switch from dphy_ops to devdata. Other i.MX8 variants differ in register layout too * Add Mixel Inc to vendor-prefixes.txt Guido Günther (3): dt-bindings: Add vendor prefix for Mixel Inc dt-bindings: phy: Add documentation for mixel dphy phy: Add driver for mixel dphy found on imx8 .../bindings/phy/mixel,mipi-dsi-phy.txt | 29 + .../devicetree/bindings/vendor-prefixes.txt | 1 + drivers/phy/freescale/Kconfig | 11 + drivers/phy/freescale/Makefile | 1 + .../phy/freescale/phy-fsl-imx8-mipi-dphy.c | 506 ++++++++++++++++++ 5 files changed, 548 insertions(+) create mode 100644 Documentation/devicetree/bindings/phy/mixel,mipi-dsi-phy.txt create mode 100644 drivers/phy/freescale/phy-fsl-imx8-mipi-dphy.c -- 2.20.1