Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3406688imu; Mon, 17 Dec 2018 20:08:36 -0800 (PST) X-Google-Smtp-Source: AFSGD/URMi7DRZPSLLpTYx6CbnofuzF3PZs+lrjUl0En7hgVEyFAVm+WpBmUWR7ISA2KfWajc3xx X-Received: by 2002:a65:63d3:: with SMTP id n19mr14687912pgv.179.1545106116134; Mon, 17 Dec 2018 20:08:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1545106116; cv=none; d=google.com; s=arc-20160816; b=EOH3pGowVwMr8jnJ4wXebwPwu2FEtPx8hSNxrHAC/UZD2JkFY0dHHAKkefDXsjad74 IUv6sVwMM84+veS4r++14YDhCL0t2KIgw5xANM6WSvww7YXEU50K7zXOwsmkQphgAAIg 1RIqui5T5J6LK3+HQKS2ulxMQDLnb3ZlRGYxe82hmw5/bc7UVNMZTyjO3Ok7uUt6gb+2 4V/L6Rui+V47YslQSb+LEox/w8bIo8TwNkska+cj5QXA04zIABHvNAOSSB2Z83ZCXDp+ bFiOTcEJxSHtwxFRqjc2lonOzPXzpQBeaWIFVwb4eOZcYhTzlfF4GNI7IxoeLbrKeYZo TvFQ== 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:cc:to:from :dkim-signature; bh=3LZ1B+w3Ow4FWhJuytlSum7SxBX6UGqso+sY25998rQ=; b=AefYE6zrj3/8aNHZGAbc4MnqCR7l4GxAM/zwcm8C1eyDdA8i5GCJ5FcjG6Fi9M/G1T sGYFYtrLkgC9AR+izbmcGZQjcPHyZeaBVt2x5ytMK8wIfUU1awuEi6eBOcE7Kgc6iI1A CUsKqXDEAu3iPIHqJHDekamwITGcmQ6d+cNMvJrTqm/jUxKpNGg0nVP2t9i2oqdQdGHt w27valZLwGDrjSWZIekD7uK9lDiwS0cyM1ug6FhxuXR24n9mlaPu4/DUs3+KZrNYNSeN kf8AB9c6J8R6/XeujIZ4zu6MeB9Q+yFOSEYXDmmuvjM+gAT/a/YQmq3rYaeEsgAORa+F llYQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=UbtoYbhv; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l123si13008028pfc.187.2018.12.17.20.08.20; Mon, 17 Dec 2018 20:08:36 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=UbtoYbhv; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726639AbeLREHZ (ORCPT + 99 others); Mon, 17 Dec 2018 23:07:25 -0500 Received: from mail-pl1-f194.google.com ([209.85.214.194]:42941 "EHLO mail-pl1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726296AbeLREHY (ORCPT ); Mon, 17 Dec 2018 23:07:24 -0500 Received: by mail-pl1-f194.google.com with SMTP id y1so7162467plp.9; Mon, 17 Dec 2018 20:07:24 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=3LZ1B+w3Ow4FWhJuytlSum7SxBX6UGqso+sY25998rQ=; b=UbtoYbhvv9Eat1kVm+2FjWSgyz0/4weKMUa8yG19BwMQEB4ViL5SFei/0PB7OGQe+Q eCju7Q/j3RbzRgrUzm1BK5qBnH0RXObx4tcDitYhFcKoMoQNdVNwlMFnMArWEjcteH4u Tbx74m5Sw1nCu8g15NgGF0PMG+vXKRTyWg5JDe6bZoy+7YmoNtw48gtSgBlZGcJicETg CTLBUUSCWFJOJ7KUOBGUfYTAkkJl2sxFkriueg+9J8lE/gV3ZFxzmbT7Rz2n27zfh45K YnS1hPdarCGXXuCugwJZpLP7yrsehgy5kmFnPDR1VqSlAq7fxneRroca2Z/JsVab3I2K jWSQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=3LZ1B+w3Ow4FWhJuytlSum7SxBX6UGqso+sY25998rQ=; b=T9QFhk4+ztZOjrCp7tie1VsIF3QPdz4mZSIwGI1dbZbB2RkPXDImDuo6nZy5jHg0xl Kr+zvdOhzwnDQT+K8BDFSwd86vSxcTPZdQ0kTPaK30wmM5j6U47ybAJwkLrALQdbKFRu sqmmxJGh9io5jAdouMTcynZQ7UOBH9IBLyn5oxeDunbOsRt1qLjcUprauBY5tItiaNcy eczWrJ+X22m264nhqKrwk7or2iw6Shq3OnbnLOAMFS59G9ZoAWI0cmmM6loz6QU5+qPc 50jKCB5oK97yHy7BW3WCldSjH4CZkJDKPy2xNVKktTWPcPhHPBx+W0SLwItMHQ99D7ER zldQ== X-Gm-Message-State: AA+aEWYg00h65LFVwS5v/DlBna3yrmcz5qkvCKK9+CmUcOHefcD+tOFo qLC/tdm09zF56g66A90k+XQ= X-Received: by 2002:a17:902:b592:: with SMTP id a18mr15046487pls.293.1545106043679; Mon, 17 Dec 2018 20:07:23 -0800 (PST) Received: from squirtle.lan (c-24-22-235-96.hsd1.wa.comcast.net. [24.22.235.96]) by smtp.gmail.com with ESMTPSA id m67sm18538837pfm.73.2018.12.17.20.07.21 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 17 Dec 2018 20:07:22 -0800 (PST) From: Andrey Smirnov To: Lorenzo Pieralisi Cc: Andrey Smirnov , Bjorn Helgaas , Fabio Estevam , Chris Healy , Lucas Stach , Leonard Crestez , "A.s. Dong" , Richard Zhu , linux-imx@nxp.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-pci@vger.kernel.org Subject: [PATCH v3 2/3] PCI: imx6: Mark PHY functions as i.MX6 specific Date: Mon, 17 Dec 2018 20:07:01 -0800 Message-Id: <20181218040702.29231-3-andrew.smirnov@gmail.com> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181218040702.29231-1-andrew.smirnov@gmail.com> References: <20181218040702.29231-1-andrew.smirnov@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org PCIE PHY IP block on i.MX7D differs from the one used on i.MX6 family, so none of the code in current implementation of imx6_setup_phy_mpll() and imx6_pcie_reset_phy() is applicable. Tested-by: Trent Piepho Signed-off-by: Andrey Smirnov Reviewed-by: Lucas Stach Cc: Bjorn Helgaas Cc: Fabio Estevam Cc: Chris Healy Cc: Lucas Stach Cc: Leonard Crestez Cc: "A.s. Dong" Cc: Richard Zhu Cc: linux-imx@nxp.com Cc: linux-arm-kernel@lists.infradead.org Cc: linux-kernel@vger.kernel.org Cc: linux-pci@vger.kernel.org --- drivers/pci/controller/dwc/pci-imx6.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/drivers/pci/controller/dwc/pci-imx6.c b/drivers/pci/controller/dwc/pci-imx6.c index d50ed69e7a57..caa05104b90b 100644 --- a/drivers/pci/controller/dwc/pci-imx6.c +++ b/drivers/pci/controller/dwc/pci-imx6.c @@ -41,8 +41,11 @@ enum imx6_pcie_variants { IMX7D, }; +#define IMX6_PCIE_FLAG_IMX6_PHY BIT(0) + struct imx6_pcie_drvdata { enum imx6_pcie_variants variant; + u32 flags; }; struct imx6_pcie { @@ -256,6 +259,9 @@ static void imx6_pcie_reset_phy(struct imx6_pcie *imx6_pcie) { u32 tmp; + if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_IMX6_PHY)) + return; + pcie_phy_read(imx6_pcie, PHY_RX_OVRD_IN_LO, &tmp); tmp |= (PHY_RX_OVRD_IN_LO_RX_DATA_EN | PHY_RX_OVRD_IN_LO_RX_PLL_EN); @@ -573,6 +579,9 @@ static int imx6_setup_phy_mpll(struct imx6_pcie *imx6_pcie) int mult, div; u32 val; + if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_IMX6_PHY)) + return 0; + switch (phy_rate) { case 125000000: /* @@ -1088,12 +1097,15 @@ static void imx6_pcie_shutdown(struct platform_device *pdev) static const struct imx6_pcie_drvdata drvdata[] = { [IMX6Q] = { .variant = IMX6Q, + .flags = IMX6_PCIE_FLAG_IMX6_PHY, }, [IMX6SX] = { .variant = IMX6SX, + .flags = IMX6_PCIE_FLAG_IMX6_PHY, }, [IMX6QP] = { .variant = IMX6QP, + .flags = IMX6_PCIE_FLAG_IMX6_PHY, }, [IMX7D] = { .variant = IMX7D, -- 2.19.1