Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp768369imm; Thu, 26 Jul 2018 11:38:31 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdgjpbfAslyJboXxkiDMk2u+3M5nf1ccvTDHtLGqX4jKUxaF9ImipXPyKL6+YsnymHHi4X1 X-Received: by 2002:a17:902:7287:: with SMTP id d7-v6mr2986675pll.54.1532630310954; Thu, 26 Jul 2018 11:38:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532630310; cv=none; d=google.com; s=arc-20160816; b=Edh2b6UOtaxvNgvoF+y0jQdfyGFqqm3iSFXDmXdcRgWhgXyNniXS0Zw8BrL1e9TmK3 IC5UrsZdcKyRkZ5UkbHk2V/BnXoL8kz/HOWPRpEXUCmMCOrH/a2KQndJMO6NAGEv+YQB 7G3FxQ7vOO1r9wlcwLCCPUXGcGne6HenScoWRd2Oppjv1d8dzHWgCbtILWq9nr/ADBdw fzA4dl9yr0abuYIjg/0LSQNfUuSnoiEWQ046QKL8ygH7BwjRzCoQisgZcHRuBuFvLB+g GJ4xB/S3vSH2dQK90lqOs3cdPOttIvNzfL3bjY3jPikA4GLPEyIfe0gcLWvgYWVE62kd 2mzQ== 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=ikdg6TfgJbzPXN5/M/XZa8ZiI6+BvFzInZO5gyiw3Kw=; b=M9sbTnCEkpOW1OD754D/8loNUzYwfUwQ9ldKzaH/qmejJnTxKG3CJ9x4S95oCUjpF1 XkIc34ZE8uN1c6Sudo+uVyurVzR1alVVogrfNmH0X/ZZXnEjA8HsxxHx6pxbOnRxXGKm fr0IeuIs6lA1NyGubPRPsbypuuysCixIrqzCMEM3kfCZs/HcelvOC7AN5AMDfqCUVfTq 4ZUWyAi0GbZk39d77BF9/Brt8TVU1WwgVemXGnEWi+iOtKlGoQM0M3NjVksWVzjpWsKT K5lwnWVQsWTxoRRw40Ib1QQVl8fET9l2JdBrdvceVisxBKe4P5QCG4dkJtt9MwRxwhdt 34ow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@broadcom.com header.s=google header.b=clNtaWq6; 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 y8-v6si2064724pfk.75.2018.07.26.11.38.16; Thu, 26 Jul 2018 11:38:30 -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=clNtaWq6; 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 S1732121AbeGZTyn (ORCPT + 99 others); Thu, 26 Jul 2018 15:54:43 -0400 Received: from mail-qt0-f196.google.com ([209.85.216.196]:44919 "EHLO mail-qt0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731701AbeGZTym (ORCPT ); Thu, 26 Jul 2018 15:54:42 -0400 Received: by mail-qt0-f196.google.com with SMTP id b15-v6so2573144qtp.11 for ; Thu, 26 Jul 2018 11:36:38 -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=ikdg6TfgJbzPXN5/M/XZa8ZiI6+BvFzInZO5gyiw3Kw=; b=clNtaWq6HMGhWj/1UqXXdWVqA1vrQYtltDiUjk/fR+U4fxv9Lg7U7lDiRex/NWz/BB tf4ItbodXkp0DD3k4eobgmaOJMSxt5OBLqdzSNCGzdg+NWvfRu9x6HAkN3s5cOOZ5bFI jpPGd2jt3EpHwVzU1edbYqBeZkTCb/C96q8OI= 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=ikdg6TfgJbzPXN5/M/XZa8ZiI6+BvFzInZO5gyiw3Kw=; b=ZmsmO6ySptQJAzeOUJqm+TKZ8niTCjeAaMmlx5UPSg3XggR+Z6DwOsex+WbnOjH07b JMLS6a6vu46+NeDpQzG2kTgi4Aqr/deO1ngLl4FJ06j6B7VnmIS7IKWfjrwEQ71B7nEp GuJeOsGMutUfpAve4c4+JG5xsIFAVTT7Z8YuU8pgMgmZZvHWEB8QfD+j/LCtAxWtC6sQ j9icru2J9zLMZMP+D3Oa0QF24vWcmmXtZ1KqY2juBgXZAV86FQGBTlR9X77Yy+UWUHb4 snk9Zg+UHxguFYc/FT1H7bQ9M5JJVH/EsTkf2dKTb6gA1OhxLsYRf4i7oH78BXSvA1sQ hZRw== X-Gm-Message-State: AOUpUlFiQ5vWLSh67N18wjkX5Zy2ut1XBxTHPasZcFok7kyYlTK+xaeS ifh2W5B27Q7FKBAREvhyHgHnIw== X-Received: by 2002:a0c:9308:: with SMTP id d8-v6mr2795146qvd.121.1532630197877; Thu, 26 Jul 2018 11:36:37 -0700 (PDT) Received: from lbrmn-lnxub86.ric.broadcom.com ([192.19.228.250]) by smtp.gmail.com with ESMTPSA id a187-v6sm1383359qkd.47.2018.07.26.11.36.34 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Thu, 26 Jul 2018 11:36:37 -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 5/7] net: phy: Add support to configure clock in Broadcom iProc mdio mux Date: Thu, 26 Jul 2018 11:36:22 -0700 Message-Id: <1532630184-29450-6-git-send-email-arun.parameswaran@broadcom.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1532630184-29450-1-git-send-email-arun.parameswaran@broadcom.com> References: <1532630184-29450-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 | 33 ++++++++++++++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/drivers/net/phy/mdio-mux-bcm-iproc.c b/drivers/net/phy/mdio-mux-bcm-iproc.c index dc65e95..6b400dd 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_PARAM_OFFSET 0x23c #define MDIO_PARAM_MIIM_CYCLE 29 #define MDIO_PARAM_INTERNAL_SEL 25 @@ -44,13 +48,32 @@ #define BUS_MAX_ADDR 32 #define EXT_BUS_START_ADDR 16 +#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_clk(struct iproc_mdiomux_desc *md) +{ + u32 val; + u32 divisor; + + if (md->core_clk) { + 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) { unsigned int timeout = 1000; /* loop for 1s */ @@ -175,6 +198,12 @@ static int mdio_mux_iproc_probe(struct platform_device *pdev) return PTR_ERR(md->base); } + md->core_clk = devm_clk_get(&pdev->dev, NULL); + if (IS_ERR(md->core_clk)) { + dev_info(&pdev->dev, "core_clk not specified\n"); + md->core_clk = NULL; + } + md->mii_bus = mdiobus_alloc(); if (!md->mii_bus) { dev_err(&pdev->dev, "mdiomux bus alloc failed\n"); @@ -206,6 +235,8 @@ static int mdio_mux_iproc_probe(struct platform_device *pdev) goto out_register; } + mdio_mux_iproc_config_clk(md); + dev_info(md->dev, "iProc mdiomux registered\n"); return 0; -- 1.9.1