Received: by 2002:a05:6358:45e:b0:b5:b6eb:e1f9 with SMTP id 30csp262246rwe; Wed, 31 Aug 2022 21:33:26 -0700 (PDT) X-Google-Smtp-Source: AA6agR4jWgpTa135jBxG8l9vTbfDZd8dieUguLv3QM5UnWRSf0NA/024zhFzCERMKxxua3CszqMd X-Received: by 2002:aa7:8393:0:b0:537:701d:e7f3 with SMTP id u19-20020aa78393000000b00537701de7f3mr29660549pfm.50.1662006805851; Wed, 31 Aug 2022 21:33:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662006805; cv=none; d=google.com; s=arc-20160816; b=q9pJDvx5baXHmM+NWbBdhQkJBmdRvr7arqCwhDDhnQHvlhbbByyF8ZpkU1ODgfdD6H bIkarET8zvi2ngcrCXEZ5RokFrjmbVZvzfDNPs945PEj49+G/2Qw48VhjafIvPCYn4Qg dqzDfkL3gNi+3gfNPvcFBmShpNsnJkN6PFOPreEWQJeoHk5su+AgSRwg/B3IEeWqmA+n 7Gmc4gGaCjgRXAJk6LmXi1haoRE56tbISSzdf7XI0linJzJfsEnsH4fc8CueDS97orto VBngyPcmGi+5o4swzkC3hkZWoLVHJgWgk0BxwxONQeaKOcleH3raCMspv5+l73Obu4nu 77Lg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from; bh=z/WdZGgEuHSVTwOsV6C/2WleSvRl3dgyTtbrxXu+lJU=; b=NhWvfI73t9hVpX+fZcpYDmqpt5/SBzcoBpp6opizUydnacbsI4/DuWt8UzZeVsTyXd t4ZaloIZZjqBOfcUAsnZn26Txkwu20uYrlCFlaIFiFYTEPwncLpuxGu8YscGU64KA0mT 96BhTDlOIiiWyA+avIXBz+3kF+nFuT9rMosMmCSw2w7CL/CDeKQTM+bu8kFFD6h0yHPH eg9hSNMvlQMMb/ZPulwfSBy1StkCc7H9i4sIEEhDz3JyA8+DfIiDJI7XyhBcNKFQAu5J kJuu+NtnZH/TXUZKMUWFHOySDnW1o0j3DODIqb0qk98ESMP4sjUoW/AfQAVbwf5Fbcrp wqFQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id v3-20020a63bf03000000b0041d7381f7f7si6385940pgf.673.2022.08.31.21.33.14; Wed, 31 Aug 2022 21:33:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229614AbiIAEaX (ORCPT + 99 others); Thu, 1 Sep 2022 00:30:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38828 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232651AbiIAE3v (ORCPT ); Thu, 1 Sep 2022 00:29:51 -0400 Received: from inva020.nxp.com (inva020.nxp.com [92.121.34.13]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DB4298E0E7; Wed, 31 Aug 2022 21:20:25 -0700 (PDT) Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id A69631A4389; Thu, 1 Sep 2022 06:20:23 +0200 (CEST) Received: from aprdc01srsp001v.ap-rdc01.nxp.com (aprdc01srsp001v.ap-rdc01.nxp.com [165.114.16.16]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 702281A4371; Thu, 1 Sep 2022 06:20:23 +0200 (CEST) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by aprdc01srsp001v.ap-rdc01.nxp.com (Postfix) with ESMTP id 9165E181D0CA; Thu, 1 Sep 2022 12:20:21 +0800 (+08) From: Richard Zhu To: p.zabel@pengutronix.de, l.stach@pengutronix.de, bhelgaas@google.com, lorenzo.pieralisi@arm.com, robh@kernel.org, shawnguo@kernel.org, vkoul@kernel.org, alexander.stein@ew.tq-group.com, marex@denx.de, richard.leitner@linux.dev Cc: linux-phy@lists.infradead.org, devicetree@vger.kernel.org, linux-pci@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, kernel@pengutronix.de, linux-imx@nxp.com Subject: [PATCH v6 0/7] Add the iMX8MP PCIe support Date: Thu, 1 Sep 2022 12:02:33 +0800 Message-Id: <1662004960-14071-1-git-send-email-hongxing.zhu@nxp.com> X-Mailer: git-send-email 2.7.4 X-Virus-Scanned: ClamAV using ClamSMTP X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Based on the 6.0-rc1 of the pci/next branch. This series adds the i.MX8MP PCIe support and tested on i.MX8MP EVK board when one PCIe NVME device is used. - i.MX8MP PCIe has reversed initial PERST bit value refer to i.MX8MQ/i.MX8MM. Add the PHY PERST explicitly for i.MX8MP PCIe PHY. - Add the i.MX8MP PCIe PHY support in the i.MX8M PCIe PHY driver. And share as much as possible codes with i.MX8MM PCIe PHY. - Add the i.MX8MP PCIe support in binding document, DTS files, and PCIe driver. Main changes v5-->v6: - To avoid code duplication when find the gpr syscon regmap, add the gpr compatible into the drvdata. - Add one missing space before one curly brace in 3/7 of v5 series. - 4/7 of v5 had been applied by Phillipp, thanks. For ease of tests, still keep it in v6. Main changes v4-->v5: - Use Lucas' approach, let blk-ctrl driver do the hsio-mix resets. - Fetch the iomuxc-gpr regmap by the different phandles. Main changes v3-->v4: - Regarding Phillipp's suggestions, add fix tag into the first commit. - Add Reviewed and Tested tags. Main changes v2-->v3: - Fix the schema checking error in the PHY dt-binding patch. - Inspired by Lucas, the PLL configurations might not required when external OSC is used as PCIe referrence clock. It's true. Remove all the HSIO PLL bit manipulations, and PCIe works fine on i.MX8MP EVK board with one NVME device is used. - Drop the #4 patch of v2, since it had been applied by Rob. Main changes v1-->v2: - It's my fault forget including Vinod, re-send v2 after include Vinod and linux-phy@lists.infradead.org. - List the basements of this patch-set. The branch, codes changes and so on. - Clean up some useless register and bit definitions in #3 patch. Documentation/devicetree/bindings/phy/fsl,imx8-pcie-phy.yaml | 16 ++++++++-- arch/arm64/boot/dts/freescale/imx8mp-evk.dts | 53 +++++++++++++++++++++++++++++++ arch/arm64/boot/dts/freescale/imx8mp.dtsi | 43 +++++++++++++++++++++++++ drivers/pci/controller/dwc/pci-imx6.c | 27 ++++++++++++++-- drivers/phy/freescale/phy-fsl-imx8m-pcie.c | 143 +++++++++++++++++++++++++++++++++++++++++++++++++++++++--------------------------- drivers/reset/reset-imx7.c | 1 + drivers/soc/imx/imx8mp-blk-ctrl.c | 10 ++++++ 7 files changed, 241 insertions(+), 52 deletions(-) [PATCH v6 1/7] dt-binding: phy: Add iMX8MP PCIe PHY binding [PATCH v6 2/7] arm64: dts: imx8mp: Add iMX8MP PCIe support [PATCH v6 3/7] arm64: dts: imx8mp-evk: Add PCIe support [PATCH v6 4/7] reset: imx7: Fix the iMX8MP PCIe PHY PERST support [PATCH v6 5/7] soc: imx: imx8mp-blk-ctrl: handle PCIe PHY resets [PATCH v6 6/7] phy: freescale: imx8m-pcie: Add i.MX8MP PCIe PHY [PATCH v6 7/7] PCI: imx6: Add i.MX8MP PCIe support