1
0
Fork 0
mirror of https://github.com/Ysurac/openmptcprouter.git synced 2025-02-15 04:42:02 +00:00
openmptcprouter/root/target/linux/bcm27xx/patches-5.15/950-0160-i2c-bcm2835-Set-clock-stretch-timeout-to-35ms.patch

48 lines
1.5 KiB
Diff
Raw Normal View History

2022-04-22 15:00:47 +00:00
From bfe64c398d4b3be2291178057d82bf5d1ee34855 Mon Sep 17 00:00:00 2001
2021-11-24 17:32:01 +00:00
From: Phil Elwell <phil@raspberrypi.org>
Date: Fri, 12 Jul 2019 15:38:35 +0100
2022-04-22 15:00:47 +00:00
Subject: [PATCH 160/828] i2c: bcm2835: Set clock-stretch timeout to 35ms
2021-11-24 17:32:01 +00:00
The BCM2835 I2C blocks have a register to set the clock-stretch
timeout - how long the device is allowed to hold SCL low - in bus
cycles. The current driver doesn't write to the register, therefore
the default value of 64 cycles is being used for all devices.
Set the timeout to the value recommended for SMBus - 35ms.
See: https://github.com/raspberrypi/linux/issues/3064
Signed-off-by: Phil Elwell <phil@raspberrypi.org>
---
drivers/i2c/busses/i2c-bcm2835.c | 12 ++++++++++++
1 file changed, 12 insertions(+)
--- a/drivers/i2c/busses/i2c-bcm2835.c
+++ b/drivers/i2c/busses/i2c-bcm2835.c
2022-04-22 15:00:47 +00:00
@@ -193,6 +193,7 @@ static int clk_bcm2835_i2c_set_rate(stru
2021-11-24 17:32:01 +00:00
{
struct clk_bcm2835_i2c *div = to_clk_bcm2835_i2c(hw);
u32 redl, fedl;
+ u32 clk_tout;
u32 divider = clk_bcm2835_i2c_calc_divider(rate, parent_rate);
if (divider == -EINVAL)
2022-04-22 15:00:47 +00:00
@@ -216,6 +217,17 @@ static int clk_bcm2835_i2c_set_rate(stru
2021-11-24 17:32:01 +00:00
bcm2835_i2c_writel(div->i2c_dev, BCM2835_I2C_DEL,
(fedl << BCM2835_I2C_FEDL_SHIFT) |
(redl << BCM2835_I2C_REDL_SHIFT));
+
+ /*
+ * Set the clock stretch timeout to the SMBUs-recommended 35ms.
+ */
+ if (rate > 0xffff*1000/35)
+ clk_tout = 0xffff;
+ else
+ clk_tout = 35*rate/1000;
+
+ bcm2835_i2c_writel(div->i2c_dev, BCM2835_I2C_CLKT, clk_tout);
+
return 0;
}