mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-26 21:54:11 +08:00
i2c: designware: Use standard optional ref clock implementation
Even though the DW I2C controller reference clock source is requested by the method devm_clk_get() with non-optional clock requirement the way the clock handler is used afterwards has a pure optional clock semantic (though in some circumstances we can get a warning about the clock missing printed in the system console). There is no point in reimplementing that functionality seeing the kernel clock framework already supports the optional interface from scratch. Thus let's convert the platform driver to using it. Note by providing this commit we get to fix two problems. The first one was introduced in commitc62ebb3d5f
("i2c: designware: Add support for an interface clock"). It causes not having the interface clock (pclk) enabled/disabled in case if the reference clock isn't provided. The second problem was first introduced in commitb33af11de2
("i2c: designware: Do not require clock when SSCN and FFCN are provided"). Since that modification the deferred probe procedure has been unsupported in case if the interface clock isn't ready. Fixes:c62ebb3d5f
("i2c: designware: Add support for an interface clock") Fixes:b33af11de2
("i2c: designware: Do not require clock when SSCN and FFCN are provided") Signed-off-by: Serge Semin <Sergey.Semin@baikalelectronics.ru> Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Acked-by: Jarkko Nikula <jarkko.nikula@linux.intel.com> Signed-off-by: Wolfram Sang <wsa@kernel.org>
This commit is contained in:
parent
5edc99f0c5
commit
27071b5cbc
@ -477,9 +477,6 @@ int i2c_dw_prepare_clk(struct dw_i2c_dev *dev, bool prepare)
|
|||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (IS_ERR(dev->clk))
|
|
||||||
return PTR_ERR(dev->clk);
|
|
||||||
|
|
||||||
if (prepare) {
|
if (prepare) {
|
||||||
/* Optional interface clock */
|
/* Optional interface clock */
|
||||||
ret = clk_prepare_enable(dev->pclk);
|
ret = clk_prepare_enable(dev->pclk);
|
||||||
|
@ -320,8 +320,17 @@ static int dw_i2c_plat_probe(struct platform_device *pdev)
|
|||||||
goto exit_reset;
|
goto exit_reset;
|
||||||
}
|
}
|
||||||
|
|
||||||
dev->clk = devm_clk_get(&pdev->dev, NULL);
|
dev->clk = devm_clk_get_optional(&pdev->dev, NULL);
|
||||||
if (!i2c_dw_prepare_clk(dev, true)) {
|
if (IS_ERR(dev->clk)) {
|
||||||
|
ret = PTR_ERR(dev->clk);
|
||||||
|
goto exit_reset;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = i2c_dw_prepare_clk(dev, true);
|
||||||
|
if (ret)
|
||||||
|
goto exit_reset;
|
||||||
|
|
||||||
|
if (dev->clk) {
|
||||||
u64 clk_khz;
|
u64 clk_khz;
|
||||||
|
|
||||||
dev->get_clk_rate_khz = i2c_dw_get_clk_rate_khz;
|
dev->get_clk_rate_khz = i2c_dw_get_clk_rate_khz;
|
||||||
|
Loading…
Reference in New Issue
Block a user