Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1507905imm; Wed, 1 Aug 2018 17:55:17 -0700 (PDT) X-Google-Smtp-Source: AAOMgpf+l+nl+vEigIOt/BAvqxDCL3Avb0b/d2t7kZDT0GgR/hXawcKOa7b33BZM/3F8fHScK0b/ X-Received: by 2002:a63:e247:: with SMTP id y7-v6mr548939pgj.231.1533171317878; Wed, 01 Aug 2018 17:55:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533171317; cv=none; d=google.com; s=arc-20160816; b=VoagQbZdguNMkOUdqyJzfFWGfZdqROW3aySJ2iPd7ZZnzDzImY/N5Zvr7T2HKF5SrI 5XS8/I5DP8ikt1MUyKGZLXabx0K4HdpTcYbn5rMiGLl29N3KWnhQJv5hnX2NGilNM8/I gxvTW3MHd+NzN2G6LxnddwD7BR4+h96FlRNTZpe+cydvn7yIIGpfb7ZtrhWwRZisonOk s0OjruLqU0FrYYrQTlY8C6whlC/FhqaxNnh2CoZmOApveA0OsH0xmfQeTgpYd4RbCNlG MhGgx9ijHYIyC2HWcN8v44mPvFLC+E1pNsNoDtaxxfhZfY/BfsNqM0C9xueAManic0pf fTEg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=8J6/E5DOdpzfUXnnAqdehMeunvpbQEWEvs4XzhoSLhM=; b=b/LXyKrmoS19n5GcMpNodoNLooi7M3Zm9HhWzP2X1WaYf7HW2L7Ljx7lZFlgfI8MI4 kLM6v2pz2c1KPtmCzeSxoYWKfQcWvWI+o29ASnTCayOQ4O8A0UlMRYrLdAP1BI5hC8Sq cheToNqlj839veXr/yvh3MEPaB2/Vyj+9mytGDb0xuj30qlplnRZaNQkOidfA9EeXv18 sydVLB1U9llGxyeoUCn0r30iHr/MczaTrX0eXW0TSBCHSu2FZHV1eSWHF3qPi1AuUxnu oBue9dMfbXRe0BYpzBZK324kFswd7RVAYsNSk5gIwHORyyhPTLQrYyavmqvW8yxXJOpr 7WGw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@broadcom.com header.s=google header.b=Y1QhijyF; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g1-v6si322035pld.79.2018.08.01.17.55.03; Wed, 01 Aug 2018 17:55:17 -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 header.i=@broadcom.com header.s=google header.b=Y1QhijyF; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732622AbeHBCmc (ORCPT + 99 others); Wed, 1 Aug 2018 22:42:32 -0400 Received: from mail-qt0-f194.google.com ([209.85.216.194]:45992 "EHLO mail-qt0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732606AbeHBCmb (ORCPT ); Wed, 1 Aug 2018 22:42:31 -0400 Received: by mail-qt0-f194.google.com with SMTP id y5-v6so496358qti.12 for ; Wed, 01 Aug 2018 17:54:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=8J6/E5DOdpzfUXnnAqdehMeunvpbQEWEvs4XzhoSLhM=; b=Y1QhijyF/0FEGSt6ebXo51NoscfwxhPvmVEWW5QQtxiISUZ0Oo/P5BbdxNtiD5zjOj b36E7rciHZuap/ewYq438GbxLqLGWS6GEoFHU8R6FLQsBf30U40FDSisJJ2A+9k5xgP3 bukJ2PFNcm8Jcfa9BpoSyJkfFTRMNpWEOsGS4= 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; bh=8J6/E5DOdpzfUXnnAqdehMeunvpbQEWEvs4XzhoSLhM=; b=LrFCkI84KRJ59BlaPrJMVYUCjfpQC3Fz2CsX5tfhnXsxMIlKnaKebFL7kfw0iyJCJV je111HRi/UAeBPiJ3Gzcd/rw0rsgFF/SS1VTxEXHDlWGYPH/799uY0LkDrKrsdqYgPTe I9B2hPXM9OGJ9BtEFflZksM6y9H3INISsq/Hp1nJ9NnmZOjDeOewcSxVdJETE8d81Wv4 A3iGGcUk6EAMZWZ78bLoUOb9adLgHq2lxG0OI9GWDmLe/EtlSEamvAInJLsxjGXG+DBS 2kvKKGM/Yep2mkfSTCp6Gk0n3lKD0aQJnVFH8yphW+YbfK8s3X6f9IkCW/ICWuxEyzAq zdTg== X-Gm-Message-State: AOUpUlF+EW58DCd0Z4er//L7YtrJLtozomG96Y359d7wYwngQSeeB3wE in52gPt52CrF72QOoyR90Vh6pw== X-Received: by 2002:ac8:37c2:: with SMTP id e2-v6mr593938qtc.417.1533171241252; Wed, 01 Aug 2018 17:54:01 -0700 (PDT) Received: from lbrmn-lnxub86.ric.broadcom.com ([192.19.228.250]) by smtp.gmail.com with ESMTPSA id e81-v6sm325116qka.3.2018.08.01.17.53.58 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Wed, 01 Aug 2018 17:54:00 -0700 (PDT) From: Arun Parameswaran To: "David S. Miller" , Florian Fainelli , Andrew Lunn , Rob Herring , Mark Rutland , Ray Jui , Scott Branden , Catalin Marinas , Will Deacon Cc: netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com, Arun Parameswaran Subject: [PATCH v4 7/8] net: phy: Add support to configure clock in Broadcom iProc mdio mux Date: Wed, 1 Aug 2018 17:53:52 -0700 Message-Id: <1533171233-14557-8-git-send-email-arun.parameswaran@broadcom.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1533171233-14557-1-git-send-email-arun.parameswaran@broadcom.com> References: <1533171233-14557-1-git-send-email-arun.parameswaran@broadcom.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add support to configure the internal rate adjust register based on the core clock supplied through device tree in the Broadcom iProc mdio mux. The operating frequency of the mdio mux block is 11MHz. This is derrived by dividing the clock to the mdio mux with the rate adjust register. In some SoC's the default values of the rate adjust register do not yield 11MHz. These SoC's are required to specify the clock via the device tree for proper operation. Signed-off-by: Arun Parameswaran --- drivers/net/phy/mdio-mux-bcm-iproc.c | 41 ++++++++++++++++++++++++++++++++++-- 1 file changed, 39 insertions(+), 2 deletions(-) diff --git a/drivers/net/phy/mdio-mux-bcm-iproc.c b/drivers/net/phy/mdio-mux-bcm-iproc.c index 3ba9616..c608e3c4 100644 --- a/drivers/net/phy/mdio-mux-bcm-iproc.c +++ b/drivers/net/phy/mdio-mux-bcm-iproc.c @@ -13,7 +13,7 @@ * You should have received a copy of the GNU General Public License * version 2 (GPLv2) along with this source code. */ - +#include #include #include #include @@ -22,6 +22,10 @@ #include #include +#define MDIO_RATE_ADJ_EXT_OFFSET 0x000 +#define MDIO_RATE_ADJ_INT_OFFSET 0x004 +#define MDIO_RATE_ADJ_DIVIDENT_SHIFT 16 + #define MDIO_SCAN_CTRL_OFFSET 0x008 #define MDIO_SCAN_CTRL_OVRIDE_EXT_MSTR 28 @@ -49,21 +53,38 @@ #define MDIO_REG_ADDR_SPACE_SIZE 0x250 +#define MDIO_OPERATING_FREQUENCY 11000000 +#define MDIO_RATE_ADJ_DIVIDENT 1 + struct iproc_mdiomux_desc { void *mux_handle; void __iomem *base; struct device *dev; struct mii_bus *mii_bus; + struct clk *core_clk; }; static void mdio_mux_iproc_config(struct iproc_mdiomux_desc *md) { + u32 divisor; u32 val; /* Disable external mdio master access */ val = readl(md->base + MDIO_SCAN_CTRL_OFFSET); val |= BIT(MDIO_SCAN_CTRL_OVRIDE_EXT_MSTR); writel(val, md->base + MDIO_SCAN_CTRL_OFFSET); + + if (md->core_clk) { + /* use rate adjust regs to derrive the mdio's operating + * frequency from the specified core clock + */ + divisor = clk_get_rate(md->core_clk) / MDIO_OPERATING_FREQUENCY; + divisor = divisor / (MDIO_RATE_ADJ_DIVIDENT + 1); + val = divisor; + val |= MDIO_RATE_ADJ_DIVIDENT << MDIO_RATE_ADJ_DIVIDENT_SHIFT; + writel(val, md->base + MDIO_RATE_ADJ_EXT_OFFSET); + writel(val, md->base + MDIO_RATE_ADJ_INT_OFFSET); + } } static int iproc_mdio_wait_for_idle(void __iomem *base, bool result) @@ -204,6 +225,19 @@ static int mdio_mux_iproc_probe(struct platform_device *pdev) return -ENOMEM; } + md->core_clk = devm_clk_get(&pdev->dev, NULL); + if (md->core_clk == ERR_PTR(-ENOENT) || + md->core_clk == ERR_PTR(-EINVAL)) + md->core_clk = NULL; + else if (IS_ERR(md->core_clk)) + return PTR_ERR(md->core_clk); + + rc = clk_prepare_enable(md->core_clk); + if (rc) { + dev_err(&pdev->dev, "failed to enable core clk\n"); + return rc; + } + bus = md->mii_bus; bus->priv = md; bus->name = "iProc MDIO mux bus"; @@ -217,7 +251,7 @@ static int mdio_mux_iproc_probe(struct platform_device *pdev) rc = mdiobus_register(bus); if (rc) { dev_err(&pdev->dev, "mdiomux registration failed\n"); - return rc; + goto out_clk; } platform_set_drvdata(pdev, md); @@ -236,6 +270,8 @@ static int mdio_mux_iproc_probe(struct platform_device *pdev) out_register: mdiobus_unregister(bus); +out_clk: + clk_disable_unprepare(md->core_clk); return rc; } @@ -245,6 +281,7 @@ static int mdio_mux_iproc_remove(struct platform_device *pdev) mdio_mux_uninit(md->mux_handle); mdiobus_unregister(md->mii_bus); + clk_disable_unprepare(md->core_clk); return 0; } -- 1.9.1