Received: by 2002:ac0:a679:0:0:0:0:0 with SMTP id p54csp723770imp; Wed, 20 Feb 2019 07:57:03 -0800 (PST) X-Google-Smtp-Source: AHgI3IaQ75RqaBRy3d40CDIfH/3ZBvgEJ+PFaQFUCo+2ceedvJJBZTdeSLiIfdhjv+TvCPHdD3WV X-Received: by 2002:a62:1d8c:: with SMTP id d134mr35484910pfd.96.1550678223440; Wed, 20 Feb 2019 07:57:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550678223; cv=none; d=google.com; s=arc-20160816; b=x+uJ1oS68OaWhKZSrIqdHXi4zztwfJSiLoLIQNZ7uVJnCHa8bYfcPqJaKNLtpmjgY+ Dw2t2jkstf+b9LJN7fkBKBzTa+dnTnurJmHXSEnLxVYNYZvL0wN2iWyO2ql2Gam4aMx9 TYBewBwP+sk5Q+DanAEwsEBZ+6JnsdevUS1D0Z6s880g+F4C+/9HiHGUuIP9dfmepcOr 0iQqeULTC9qHNyGjzMiCiFWZxulAk924ihSPh2bjkU7X50eY2HPU8l4N4RiGyLDevp8K WPHWE3Ql/C07DY38elXQ1CiH9hZsWhVUXhF1aw2sVi11j5/cSgmcKP3y0UkDGMJIQCo+ QThg== 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; bh=/kTcE8SQXU2zjQ1rFgVyKayng6AcMUoM3Cav/YpXrH4=; b=IxxvVspE+cd5Pmc3x/JSYRCiSEfFBFGOsqTgrGy7ZXg+9apBkF1V4AqzCmYTWOHtlS M5pD481tP7s+4Zftw+3JGAJjjYTf1KToEAg0fi47yy0zNxZp6eVWV5c8PgNT+XnnwAEZ MXlnZrO42iXVyVeQy+Xk/P/5CyYEbugJcxIeK2RIMGiZVyyKrHikMo0D4A2whDUbYYWi lO6o57Q9KaXvqan95pA8Ji8qq8ULY8A4HF5lkZlXJR/ie/GTMBYKoFT1sA805fhbF2wZ PyoV2bwLU/LRwtk1iI61wwTmNWWIEx+HusKCVD114jCm/MWppjgnY9Ed+yM5ZRuBCTK8 ajLg== ARC-Authentication-Results: i=1; mx.google.com; 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 ct15si6491503plb.333.2019.02.20.07.56.47; Wed, 20 Feb 2019 07:57:03 -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; 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 S1727604AbfBTPzE (ORCPT + 99 others); Wed, 20 Feb 2019 10:55:04 -0500 Received: from relmlor1.renesas.com ([210.160.252.171]:36447 "EHLO relmlie5.idc.renesas.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725883AbfBTPzE (ORCPT ); Wed, 20 Feb 2019 10:55:04 -0500 X-IronPort-AV: E=Sophos;i="5.58,391,1544454000"; d="scan'208";a="8394733" Received: from unknown (HELO relmlir5.idc.renesas.com) ([10.200.68.151]) by relmlie5.idc.renesas.com with ESMTP; 21 Feb 2019 00:55:02 +0900 Received: from renesas-VirtualBox.ree.adwin.renesas.com (unknown [10.226.37.56]) by relmlir5.idc.renesas.com (Postfix) with ESMTP id B81C340031CB; Thu, 21 Feb 2019 00:55:00 +0900 (JST) From: Gareth Williams To: Jarkko Nikula , Andy Shevchenko , Mika Westerberg , linux-i2c@vger.kernel.org Cc: Phil Edworthy , linux-kernel@vger.kernel.org, linux-renesas-soc@vger.kernel.org, Gareth Williams Subject: [PATCH v3 2/2] i2c: designware: Add support for a bus clock Date: Wed, 20 Feb 2019 15:50:03 +0000 Message-Id: <1550677803-29716-3-git-send-email-gareth.williams.jx@renesas.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1550677803-29716-1-git-send-email-gareth.williams.jx@renesas.com> References: <1550677803-29716-1-git-send-email-gareth.williams.jx@renesas.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Phil Edworthy The Synopsys I2C Controller has a bus clock, but most SoCs hide this away. However, on some SoCs you need to explicity enable the bus clock in order to access the registers. Therefore, add support for an optional bus clock. Signed-off-by: Phil Edworthy Signed-off-by: Gareth Williams --- v3: - busclk renamed to pclk. - Added comment with dw_i2c_dev struct definition describing pclk. - Added enable rollback of first clock if second fails to enable. v2: - Use new devm_clk_get_optional() function as it simplifies handling when the optional clock is not present. --- drivers/i2c/busses/i2c-designware-common.c | 18 ++++++++++++++++-- drivers/i2c/busses/i2c-designware-core.h | 2 ++ drivers/i2c/busses/i2c-designware-platdrv.c | 5 +++++ 3 files changed, 23 insertions(+), 2 deletions(-) diff --git a/drivers/i2c/busses/i2c-designware-common.c b/drivers/i2c/busses/i2c-designware-common.c index a473011..5f70078 100644 --- a/drivers/i2c/busses/i2c-designware-common.c +++ b/drivers/i2c/busses/i2c-designware-common.c @@ -251,13 +251,27 @@ unsigned long i2c_dw_clk_rate(struct dw_i2c_dev *dev) int i2c_dw_prepare_clk(struct dw_i2c_dev *dev, bool prepare) { + int ret; + if (IS_ERR(dev->clk)) return PTR_ERR(dev->clk); - if (prepare) - return clk_prepare_enable(dev->clk); + if (prepare) { + /* Optional bus clock */ + ret = clk_prepare_enable(dev->pclk); + if (ret) + return ret; + + ret = clk_prepare_enable(dev->clk); + if (ret) + clk_disable_unprepare(dev->pclk); + + return ret; + } clk_disable_unprepare(dev->clk); + clk_disable_unprepare(dev->pclk); + return 0; } EXPORT_SYMBOL_GPL(i2c_dw_prepare_clk); diff --git a/drivers/i2c/busses/i2c-designware-core.h b/drivers/i2c/busses/i2c-designware-core.h index b4a0b2b..e88c711 100644 --- a/drivers/i2c/busses/i2c-designware-core.h +++ b/drivers/i2c/busses/i2c-designware-core.h @@ -177,6 +177,7 @@ * @base: IO registers pointer * @cmd_complete: tx completion indicator * @clk: input reference clock + * @pclk: clock required to access the registers * @slave: represent an I2C slave device * @cmd_err: run time hadware error code * @msgs: points to an array of messages currently being transferred @@ -226,6 +227,7 @@ struct dw_i2c_dev { void __iomem *ext; struct completion cmd_complete; struct clk *clk; + struct clk *pclk; struct reset_control *rst; struct i2c_client *slave; u32 (*get_clk_rate_khz) (struct dw_i2c_dev *dev); diff --git a/drivers/i2c/busses/i2c-designware-platdrv.c b/drivers/i2c/busses/i2c-designware-platdrv.c index 9eaac3b..c550fb2 100644 --- a/drivers/i2c/busses/i2c-designware-platdrv.c +++ b/drivers/i2c/busses/i2c-designware-platdrv.c @@ -346,6 +346,11 @@ static int dw_i2c_plat_probe(struct platform_device *pdev) else i2c_dw_configure_master(dev); + /* Optional bus clock */ + dev->pclk = devm_clk_get_optional(&pdev->dev, "pclk"); + if (IS_ERR(dev->pclk)) + return PTR_ERR(dev->pclk); + dev->clk = devm_clk_get(&pdev->dev, NULL); if (!i2c_dw_prepare_clk(dev, true)) { u64 clk_khz; -- 2.7.4