Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp815275imm; Thu, 26 Jul 2018 12:29:04 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdMrXy7XNV2VxJidna5kw1Ey2tThidHTw/bb6K+Qd+ufDn70IaZhDTzVeHTwxDvhTd5uBl3 X-Received: by 2002:a62:2f84:: with SMTP id v126-v6mr3400702pfv.115.1532633344245; Thu, 26 Jul 2018 12:29:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532633344; cv=none; d=google.com; s=arc-20160816; b=Vb7jungNrFGKNUqsrpx8WtlwdEJzRZzbubVNbcm6vyccIIedQu4b1VnafIiVMOPr6k uENOSgfqCJIByHkaGa/FdQ8W9uILLV0hFftpVBAX2NqGMKZVr0iX4Je6uVPuQjQ/tlTI 2jTC6PMaYxZJzrJBbkR3Lb3AP5D2X6yxdwGQrswAmfCcFrMTPRvmzJtRswD1UTz2Hx0k oby8CYfYIQdhFX4GTaNeZdRcCNPQww8pu4UNIqGXjIb9gFtYUmnpNgIzr3NO38n7WooG 8+eRjBMQxi7UIfjOSQ+GcOeUh590yA/opyEHG3O6i3JF9L3wOJ38QZ6gcwvHXeeq5zkx vPBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature:arc-authentication-results; bh=n1Ds1kRmOLpQCbXRs6qD02lDHBfSFwSdJMg7LzarIZo=; b=W3ddz76odiQtSQRtLqyL1nQjBCftQNhF88DWoEdp4CEy/cdkg68yD86Tes8q9Ru8cb WZhGCII7qigEOzmgTLT/+YSmerZAYOLA9ed+KmAN5g0RGr/VpYc7oakcaRBLPVo9zqz/ kLNY8a3MaJmR/PNhayHJyK7jyI3SMIA6f9+fD7znc2M+s8ROmKOa0joF+eTVqOPQhf8X Dl9uuOQ+T71z9gs7WpiU2raEP0fEoKWwZcRJxxUOF5/VTXQjHRx71s6wN/HObOEMgcuQ LVMXHV+OP0CHajsoNL8y7jGzOJWGNEAZ6pS3E2HUYcfZZNm8aAzKQx14RFsXdYxIKj57 qJgQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lunn.ch header.s=20171124 header.b=n48sKoTN; 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 ca2-v6si2246634plb.305.2018.07.26.12.28.49; Thu, 26 Jul 2018 12:29:04 -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=@lunn.ch header.s=20171124 header.b=n48sKoTN; 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 S1732037AbeGZUpL (ORCPT + 99 others); Thu, 26 Jul 2018 16:45:11 -0400 Received: from vps0.lunn.ch ([185.16.172.187]:47694 "EHLO vps0.lunn.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731644AbeGZUpL (ORCPT ); Thu, 26 Jul 2018 16:45:11 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lunn.ch; s=20171124; h=In-Reply-To:Content-Type:MIME-Version:References:Message-ID:Subject:Cc:To:From:Date; bh=n1Ds1kRmOLpQCbXRs6qD02lDHBfSFwSdJMg7LzarIZo=; b=n48sKoTNcPCPqbyafK8sNAubiT3lL1dsvg1/SIjQ0I2xeQZfLXsINKs+L5f8l/B8+lCtrVQVa1bqSbpSf8vb8RRmeFnieoOCleINehZqTNCBJEjdpswJ/K0i7zO8zPSJNinfrs3LgtWU9LaJjavWDMFiEjgeQ52aCO37UkIlY/U=; Received: from andrew by vps0.lunn.ch with local (Exim 4.84_2) (envelope-from ) id 1filuV-0005Yt-3e; Thu, 26 Jul 2018 21:26:51 +0200 Date: Thu, 26 Jul 2018 21:26:51 +0200 From: Andrew Lunn To: Arun Parameswaran Cc: "David S. Miller" , Florian Fainelli , Rob Herring , Mark Rutland , Ray Jui , Scott Branden , Catalin Marinas , Will Deacon , 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 Subject: Re: [PATCH 5/7] net: phy: Add support to configure clock in Broadcom iProc mdio mux Message-ID: <20180726192651.GK10686@lunn.ch> References: <1532630184-29450-1-git-send-email-arun.parameswaran@broadcom.com> <1532630184-29450-6-git-send-email-arun.parameswaran@broadcom.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1532630184-29450-6-git-send-email-arun.parameswaran@broadcom.com> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org > +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; /** * clk_get_rate - obtain the current clock rate (in Hz) for a clock source. * This is only valid once the clock source has been enabled. * @clk: clock source */ unsigned long clk_get_rate(struct clk *clk); It is generally good practice to call clk_prepare_enable() sometime before clk_get_rate() to ensure the clock is ticking, and to show this driver is making use of the clock, so it does not get turned off. > + 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); > + } > +}