2
0

855-pending-i2c-mt65xx-add-additional-clocks.patch 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. From 94bf61df9201195d6d8ce82e299fb231b31fbaae Mon Sep 17 00:00:00 2001
  2. From: Daniel Golle <[email protected]>
  3. Date: Fri, 26 May 2023 10:29:45 +0100
  4. Subject: [PATCH] i2c: mt65xx: add additional clocks
  5. On MT7981 additional clocks are required when accessing I2C registers.
  6. Add MCK and PCK optional clocks to i2c-mt65xx driver so we don't have
  7. to always have them enabled, but really only if I2C is used.
  8. Signed-off-by: Daniel Golle <[email protected]>
  9. ---
  10. drivers/i2c/busses/i2c-mt65xx.c | 14 +++++++++++++-
  11. 1 file changed, 13 insertions(+), 1 deletion(-)
  12. --- a/drivers/i2c/busses/i2c-mt65xx.c
  13. +++ b/drivers/i2c/busses/i2c-mt65xx.c
  14. @@ -93,6 +93,8 @@
  15. * @I2C_MT65XX_CLK_DMA: DMA clock for i2c via DMA
  16. * @I2C_MT65XX_CLK_PMIC: PMIC clock for i2c from PMIC
  17. * @I2C_MT65XX_CLK_ARB: Arbitrator clock for i2c
  18. + * @I2C_MT65XX_CLK_MCK: MCK clock for i2c
  19. + * @I2C_MT65XX_CLK_PCK: PCK clock for i2c
  20. * @I2C_MT65XX_CLK_MAX: Number of supported clocks
  21. */
  22. enum i2c_mt65xx_clks {
  23. @@ -100,11 +102,13 @@ enum i2c_mt65xx_clks {
  24. I2C_MT65XX_CLK_DMA,
  25. I2C_MT65XX_CLK_PMIC,
  26. I2C_MT65XX_CLK_ARB,
  27. + I2C_MT65XX_CLK_MCK,
  28. + I2C_MT65XX_CLK_PCK,
  29. I2C_MT65XX_CLK_MAX
  30. };
  31. static const char * const i2c_mt65xx_clk_ids[I2C_MT65XX_CLK_MAX] = {
  32. - "main", "dma", "pmic", "arb"
  33. + "main", "dma", "pmic", "arb", "mck", "pck"
  34. };
  35. enum DMA_REGS_OFFSET {
  36. @@ -1444,6 +1448,14 @@ static int mtk_i2c_probe(struct platform
  37. if (IS_ERR(i2c->clocks[I2C_MT65XX_CLK_ARB].clk))
  38. return PTR_ERR(i2c->clocks[I2C_MT65XX_CLK_ARB].clk);
  39. + i2c->clocks[I2C_MT65XX_CLK_MCK].clk = devm_clk_get_optional(&pdev->dev, "mck");
  40. + if (IS_ERR(i2c->clocks[I2C_MT65XX_CLK_MCK].clk))
  41. + return PTR_ERR(i2c->clocks[I2C_MT65XX_CLK_MCK].clk);
  42. +
  43. + i2c->clocks[I2C_MT65XX_CLK_PCK].clk = devm_clk_get_optional(&pdev->dev, "pck");
  44. + if (IS_ERR(i2c->clocks[I2C_MT65XX_CLK_PCK].clk))
  45. + return PTR_ERR(i2c->clocks[I2C_MT65XX_CLK_PCK].clk);
  46. +
  47. if (i2c->have_pmic) {
  48. i2c->clocks[I2C_MT65XX_CLK_PMIC].clk = devm_clk_get(&pdev->dev, "pmic");
  49. if (IS_ERR(i2c->clocks[I2C_MT65XX_CLK_PMIC].clk)) {