* [PATCH v2 1/3] dt-bindings: i2c: spacemit: add optional resets
2025-12-19 7:42 [PATCH v2 0/3] i2c: spacemit: add reset support Encrow Thorne
@ 2025-12-19 7:42 ` Encrow Thorne
2025-12-19 8:03 ` Krzysztof Kozlowski
2025-12-19 7:42 ` [PATCH v2 2/3] i2c: k1: add reset support Encrow Thorne
` (2 subsequent siblings)
3 siblings, 1 reply; 16+ messages in thread
From: Encrow Thorne @ 2025-12-19 7:42 UTC (permalink / raw)
To: Troy Mitchell, Andi Shyti, Rob Herring, Krzysztof Kozlowski,
Conor Dooley, Yixun Lan, Philipp Zabel, Paul Walmsley,
Palmer Dabbelt, Albert Ou, Alexandre Ghiti
Cc: Troy Mitchell, Guodong Xu, linux-i2c, devicetree, linux-riscv,
spacemit, linux-kernel, Encrow Thorne
The I2C controller requires a reset to ensure it starts from a clean state.
Add the 'resets' property to support this hardware requirement.
Signed-off-by: Encrow Thorne <jyc0019@gmail.com>
---
Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml | 3 +++
1 file changed, 3 insertions(+)
diff --git a/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml b/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml
index b7220fff2235..1290106e28e6 100644
--- a/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml
+++ b/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml
@@ -32,6 +32,9 @@ properties:
- const: func
- const: bus
+ resets:
+ maxItems: 1
+
clock-frequency:
description: |
K1 support three different modes which running different frequencies
--
2.25.1
^ permalink raw reply related [flat|nested] 16+ messages in thread* Re: [PATCH v2 1/3] dt-bindings: i2c: spacemit: add optional resets
2025-12-19 7:42 ` [PATCH v2 1/3] dt-bindings: i2c: spacemit: add optional resets Encrow Thorne
@ 2025-12-19 8:03 ` Krzysztof Kozlowski
2025-12-26 3:25 ` Troy Mitchell
0 siblings, 1 reply; 16+ messages in thread
From: Krzysztof Kozlowski @ 2025-12-19 8:03 UTC (permalink / raw)
To: Encrow Thorne, Troy Mitchell, Andi Shyti, Rob Herring,
Krzysztof Kozlowski, Conor Dooley, Yixun Lan, Philipp Zabel,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti
Cc: Troy Mitchell, Guodong Xu, linux-i2c, devicetree, linux-riscv,
spacemit, linux-kernel
On 19/12/2025 08:42, Encrow Thorne wrote:
> The I2C controller requires a reset to ensure it starts from a clean state.
>
> Add the 'resets' property to support this hardware requirement.
>
> Signed-off-by: Encrow Thorne <jyc0019@gmail.com>
> ---
> Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml | 3 +++
> 1 file changed, 3 insertions(+)
>
> diff --git a/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml b/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml
> index b7220fff2235..1290106e28e6 100644
> --- a/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml
> +++ b/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml
> @@ -32,6 +32,9 @@ properties:
> - const: func
> - const: bus
>
> + resets:
> + maxItems: 1
> +
Still between other clock-related properties. You already got such
comment...
> clock-frequency:
> description: |
> K1 support three different modes which running different frequencies
>
Best regards,
Krzysztof
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH v2 1/3] dt-bindings: i2c: spacemit: add optional resets
2025-12-19 8:03 ` Krzysztof Kozlowski
@ 2025-12-26 3:25 ` Troy Mitchell
0 siblings, 0 replies; 16+ messages in thread
From: Troy Mitchell @ 2025-12-26 3:25 UTC (permalink / raw)
To: Krzysztof Kozlowski, Encrow Thorne, Troy Mitchell, Andi Shyti,
Rob Herring, Krzysztof Kozlowski, Conor Dooley, Yixun Lan,
Philipp Zabel, Paul Walmsley, Palmer Dabbelt, Albert Ou,
Alexandre Ghiti
Cc: Troy Mitchell, Guodong Xu, linux-i2c, devicetree, linux-riscv,
spacemit, linux-kernel
On Fri, Dec 19, 2025 at 09:03:14AM +0100, Krzysztof Kozlowski wrote:
> On 19/12/2025 08:42, Encrow Thorne wrote:
> > The I2C controller requires a reset to ensure it starts from a clean state.
> >
> > Add the 'resets' property to support this hardware requirement.
> >
> > Signed-off-by: Encrow Thorne <jyc0019@gmail.com>
> > ---
> > Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml | 3 +++
> > 1 file changed, 3 insertions(+)
> >
> > diff --git a/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml b/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml
> > index b7220fff2235..1290106e28e6 100644
> > --- a/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml
> > +++ b/Documentation/devicetree/bindings/i2c/spacemit,k1-i2c.yaml
> > @@ -32,6 +32,9 @@ properties:
> > - const: func
> > - const: bus
> >
> > + resets:
> > + maxItems: 1
> > +
>
> Still between other clock-related properties. You already got such
> comment...
Please replace it below clock-frequency.
With this fix, you can add my tag:
Reviewed-by: Troy Mitchell <troy.mitchell@linux.spacemit.com>
>
> > clock-frequency:
> > description: |
> > K1 support three different modes which running different frequencies
> >
>
>
> Best regards,
> Krzysztof
>
^ permalink raw reply [flat|nested] 16+ messages in thread
* [PATCH v2 2/3] i2c: k1: add reset support
2025-12-19 7:42 [PATCH v2 0/3] i2c: spacemit: add reset support Encrow Thorne
2025-12-19 7:42 ` [PATCH v2 1/3] dt-bindings: i2c: spacemit: add optional resets Encrow Thorne
@ 2025-12-19 7:42 ` Encrow Thorne
2025-12-25 21:01 ` Andi Shyti
2025-12-26 3:24 ` Troy Mitchell
2025-12-19 7:42 ` [PATCH v2 3/3] riscv: dts: spacemit: add reset property Encrow Thorne
2025-12-19 8:03 ` [PATCH v2 0/3] i2c: spacemit: add reset support Krzysztof Kozlowski
3 siblings, 2 replies; 16+ messages in thread
From: Encrow Thorne @ 2025-12-19 7:42 UTC (permalink / raw)
To: Troy Mitchell, Andi Shyti, Rob Herring, Krzysztof Kozlowski,
Conor Dooley, Yixun Lan, Philipp Zabel, Paul Walmsley,
Palmer Dabbelt, Albert Ou, Alexandre Ghiti
Cc: Troy Mitchell, Guodong Xu, linux-i2c, devicetree, linux-riscv,
spacemit, linux-kernel, Encrow Thorne
The K1 I2C controller provides a reset line that needs to be deasserted
before the controller can be accessed.
Add reset support to the driver to ensure the controller starts in the
required state.
Signed-off-by: Encrow Thorne <jyc0019@gmail.com>
---
drivers/i2c/busses/i2c-k1.c | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/drivers/i2c/busses/i2c-k1.c b/drivers/i2c/busses/i2c-k1.c
index d42c03ef5db5..23661c7ddb67 100644
--- a/drivers/i2c/busses/i2c-k1.c
+++ b/drivers/i2c/busses/i2c-k1.c
@@ -10,6 +10,7 @@
#include <linux/module.h>
#include <linux/of_address.h>
#include <linux/platform_device.h>
+ #include <linux/reset.h>
/* spacemit i2c registers */
#define SPACEMIT_ICR 0x0 /* Control register */
@@ -534,6 +535,7 @@ static int spacemit_i2c_probe(struct platform_device *pdev)
struct device *dev = &pdev->dev;
struct device_node *of_node = pdev->dev.of_node;
struct spacemit_i2c_dev *i2c;
+ struct reset_control *rst;
int ret;
i2c = devm_kzalloc(dev, sizeof(*i2c), GFP_KERNEL);
@@ -578,6 +580,11 @@ static int spacemit_i2c_probe(struct platform_device *pdev)
if (IS_ERR(clk))
return dev_err_probe(dev, PTR_ERR(clk), "failed to enable bus clock");
+ rst = devm_reset_control_get_optional_exclusive_deasserted(dev, NULL);
+ if (IS_ERR(rst))
+ return dev_err_probe(dev, PTR_ERR(rst),
+ "failed to acquire deasserted reset\n");
+
spacemit_i2c_reset(i2c);
i2c_set_adapdata(&i2c->adapt, i2c);
--
2.25.1
^ permalink raw reply related [flat|nested] 16+ messages in thread
* Re: [PATCH v2 2/3] i2c: k1: add reset support
2025-12-19 7:42 ` [PATCH v2 2/3] i2c: k1: add reset support Encrow Thorne
@ 2025-12-25 21:01 ` Andi Shyti
2025-12-25 23:38 ` Guodong Xu
2025-12-26 3:24 ` Troy Mitchell
1 sibling, 1 reply; 16+ messages in thread
From: Andi Shyti @ 2025-12-25 21:01 UTC (permalink / raw)
To: Encrow Thorne
Cc: Troy Mitchell, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Yixun Lan, Philipp Zabel, Paul Walmsley, Palmer Dabbelt,
Albert Ou, Alexandre Ghiti, Troy Mitchell, Guodong Xu, linux-i2c,
devicetree, linux-riscv, spacemit, linux-kernel
Hi Encrow,
...
> + rst = devm_reset_control_get_optional_exclusive_deasserted(dev, NULL);
> + if (IS_ERR(rst))
> + return dev_err_probe(dev, PTR_ERR(rst),
> + "failed to acquire deasserted reset\n");
If this is optional, why are we returning with error?
Thanks,
Andi
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH v2 2/3] i2c: k1: add reset support
2025-12-25 21:01 ` Andi Shyti
@ 2025-12-25 23:38 ` Guodong Xu
2025-12-27 19:26 ` Andi Shyti
0 siblings, 1 reply; 16+ messages in thread
From: Guodong Xu @ 2025-12-25 23:38 UTC (permalink / raw)
To: Andi Shyti
Cc: Encrow Thorne, Troy Mitchell, Rob Herring, Krzysztof Kozlowski,
Conor Dooley, Yixun Lan, Philipp Zabel, Paul Walmsley,
Palmer Dabbelt, Albert Ou, Alexandre Ghiti, Troy Mitchell,
linux-i2c, devicetree, linux-riscv, spacemit, linux-kernel
Hi, Andi
On Fri, Dec 26, 2025 at 5:01 AM Andi Shyti <andi.shyti@kernel.org> wrote:
>
> Hi Encrow,
>
> ...
>
> > + rst = devm_reset_control_get_optional_exclusive_deasserted(dev, NULL);
> > + if (IS_ERR(rst))
> > + return dev_err_probe(dev, PTR_ERR(rst),
> > + "failed to acquire deasserted reset\n");
>
> If this is optional, why are we returning with error?
>
According to include/linux/reset.h, if the requested reset is not
specified in the device tree, this function returns NULL instead of
an error. Therefore, IS_ERR(rst) will only be true for actual
errors (e.g probe deferral).
BR,
Guodong
> Thanks,
> Andi
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH v2 2/3] i2c: k1: add reset support
2025-12-25 23:38 ` Guodong Xu
@ 2025-12-27 19:26 ` Andi Shyti
2025-12-28 0:42 ` Guodong Xu
0 siblings, 1 reply; 16+ messages in thread
From: Andi Shyti @ 2025-12-27 19:26 UTC (permalink / raw)
To: Guodong Xu
Cc: Encrow Thorne, Troy Mitchell, Rob Herring, Krzysztof Kozlowski,
Conor Dooley, Yixun Lan, Philipp Zabel, Paul Walmsley,
Palmer Dabbelt, Albert Ou, Alexandre Ghiti, Troy Mitchell,
linux-i2c, devicetree, linux-riscv, spacemit, linux-kernel
Hi Guodong,
On Fri, Dec 26, 2025 at 07:38:22AM +0800, Guodong Xu wrote:
> On Fri, Dec 26, 2025 at 5:01 AM Andi Shyti <andi.shyti@kernel.org> wrote:
> > > + rst = devm_reset_control_get_optional_exclusive_deasserted(dev, NULL);
> > > + if (IS_ERR(rst))
> > > + return dev_err_probe(dev, PTR_ERR(rst),
> > > + "failed to acquire deasserted reset\n");
> >
> > If this is optional, why are we returning with error?
> >
>
> According to include/linux/reset.h, if the requested reset is not
> specified in the device tree, this function returns NULL instead of
> an error. Therefore, IS_ERR(rst) will only be true for actual
> errors (e.g probe deferral).
And this is quite obvious, but you haven't answered my qestion.
Why do we care of internal failures in reset? If reset fails on
an optional reset control function why should we kill our driver?
Just ignore the error and move forward as we have done until now.
If the kernel is suffering from internal failures (say ENOMEM),
it will fail anyway or, with some luck, recover.
Andi
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH v2 2/3] i2c: k1: add reset support
2025-12-27 19:26 ` Andi Shyti
@ 2025-12-28 0:42 ` Guodong Xu
2025-12-30 14:11 ` Troy Mitchell
0 siblings, 1 reply; 16+ messages in thread
From: Guodong Xu @ 2025-12-28 0:42 UTC (permalink / raw)
To: Andi Shyti
Cc: Encrow Thorne, Troy Mitchell, Rob Herring, Krzysztof Kozlowski,
Conor Dooley, Yixun Lan, Philipp Zabel, Paul Walmsley,
Palmer Dabbelt, Albert Ou, Alexandre Ghiti, Troy Mitchell,
linux-i2c, devicetree, linux-riscv, spacemit, linux-kernel
Hi, Andi
On Sun, Dec 28, 2025 at 3:26 AM Andi Shyti <andi.shyti@kernel.org> wrote:
>
> Hi Guodong,
>
> On Fri, Dec 26, 2025 at 07:38:22AM +0800, Guodong Xu wrote:
> > On Fri, Dec 26, 2025 at 5:01 AM Andi Shyti <andi.shyti@kernel.org> wrote:
> > > > + rst = devm_reset_control_get_optional_exclusive_deasserted(dev, NULL);
> > > > + if (IS_ERR(rst))
> > > > + return dev_err_probe(dev, PTR_ERR(rst),
> > > > + "failed to acquire deasserted reset\n");
> > >
> > > If this is optional, why are we returning with error?
> > >
> >
> > According to include/linux/reset.h, if the requested reset is not
> > specified in the device tree, this function returns NULL instead of
> > an error. Therefore, IS_ERR(rst) will only be true for actual
> > errors (e.g probe deferral).
>
> And this is quite obvious, but you haven't answered my qestion.
>
> Why do we care of internal failures in reset? If reset fails on
> an optional reset control function why should we kill our driver?
Thanks for the clarification. I see your point now.
My reasoning is that if the resets property is explicitly listed in the
Device Tree, the driver must respect it. If the property is present but
we encounter an error (like -EPROBE_DEFER), ignoring that failure could
put the hardware in an undefined or dirty state.
> Just ignore the error and move forward as we have done until now.
I want to double-check what you mean.
I checked other drivers in drivers/i2c/busses (e.g. i2c-riic.c, i2c-mv64xxx.c,
i2c-designware-platdrv.c), and they seem to follow this pattern of returning
errors even for optional resets.
BR,
Guodong
>
> If the kernel is suffering from internal failures (say ENOMEM),
> it will fail anyway or, with some luck, recover.
>
> Andi
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH v2 2/3] i2c: k1: add reset support
2025-12-28 0:42 ` Guodong Xu
@ 2025-12-30 14:11 ` Troy Mitchell
2025-12-30 14:14 ` Troy Mitchell
0 siblings, 1 reply; 16+ messages in thread
From: Troy Mitchell @ 2025-12-30 14:11 UTC (permalink / raw)
To: Guodong Xu, Andi Shyti
Cc: Encrow Thorne, Troy Mitchell, Rob Herring, Krzysztof Kozlowski,
Conor Dooley, Yixun Lan, Philipp Zabel, Paul Walmsley,
Palmer Dabbelt, Albert Ou, Alexandre Ghiti, Troy Mitchell,
linux-i2c, devicetree, linux-riscv, spacemit, linux-kernel
On Sun, Dec 28, 2025 at 08:42:47AM +0800, Guodong Xu wrote:
> Hi, Andi
>
> On Sun, Dec 28, 2025 at 3:26 AM Andi Shyti <andi.shyti@kernel.org> wrote:
> >
> > Hi Guodong,
> >
> > On Fri, Dec 26, 2025 at 07:38:22AM +0800, Guodong Xu wrote:
> > > On Fri, Dec 26, 2025 at 5:01 AM Andi Shyti <andi.shyti@kernel.org> wrote:
> > > > > + rst = devm_reset_control_get_optional_exclusive_deasserted(dev, NULL);
> > > > > + if (IS_ERR(rst))
> > > > > + return dev_err_probe(dev, PTR_ERR(rst),
> > > > > + "failed to acquire deasserted reset\n");
> > > >
> > > > If this is optional, why are we returning with error?
> > > >
> > >
> > > According to include/linux/reset.h, if the requested reset is not
> > > specified in the device tree, this function returns NULL instead of
> > > an error. Therefore, IS_ERR(rst) will only be true for actual
> > > errors (e.g probe deferral).
> >
> > And this is quite obvious, but you haven't answered my qestion.
> >
> > Why do we care of internal failures in reset? If reset fails on
> > an optional reset control function why should we kill our driver?
>
> Thanks for the clarification. I see your point now.
>
> My reasoning is that if the resets property is explicitly listed in the
> Device Tree, the driver must respect it.
It's not required.
>
> If the property is present but
> we encounter an error (like -EPROBE_DEFER), ignoring that failure could
> put the hardware in an undefined or dirty state.
Then why it's optional?
The real reason:
"Optional" here means the reset line is allowed to be absent from the
Device Tree. It does not mean we can ignore the failure when it is
defined in the DT but fails to be acquired.
If devm_reset_control_get_optional_* returns an error (e.g.,
-EPROBE_DEFER), it indicates the hardware description expects a reset
control, but the system is not yet ready to provide it. Ignoring this
error would break the probe deferral mechanism and potentially cause the
driver to access hardware in an invalid state.
- Troy
^ permalink raw reply [flat|nested] 16+ messages in thread* Re: [PATCH v2 2/3] i2c: k1: add reset support
2025-12-30 14:11 ` Troy Mitchell
@ 2025-12-30 14:14 ` Troy Mitchell
0 siblings, 0 replies; 16+ messages in thread
From: Troy Mitchell @ 2025-12-30 14:14 UTC (permalink / raw)
To: Guodong Xu, Andi Shyti
Cc: Encrow Thorne, Troy Mitchell, Rob Herring, Krzysztof Kozlowski,
Conor Dooley, Yixun Lan, Philipp Zabel, Paul Walmsley,
Palmer Dabbelt, Albert Ou, Alexandre Ghiti, Troy Mitchell,
linux-i2c, devicetree, linux-riscv, spacemit, linux-kernel
On Tue, Dec 30, 2025 at 10:11:16PM +0800, Troy Mitchell wrote:
> On Sun, Dec 28, 2025 at 08:42:47AM +0800, Guodong Xu wrote:
> > Hi, Andi
> >
> > On Sun, Dec 28, 2025 at 3:26 AM Andi Shyti <andi.shyti@kernel.org> wrote:
> > >
> > > Hi Guodong,
> > >
> > > On Fri, Dec 26, 2025 at 07:38:22AM +0800, Guodong Xu wrote:
> > > > On Fri, Dec 26, 2025 at 5:01 AM Andi Shyti <andi.shyti@kernel.org> wrote:
> > > > > > + rst = devm_reset_control_get_optional_exclusive_deasserted(dev, NULL);
> > > > > > + if (IS_ERR(rst))
> > > > > > + return dev_err_probe(dev, PTR_ERR(rst),
> > > > > > + "failed to acquire deasserted reset\n");
> > > > >
> > > > > If this is optional, why are we returning with error?
> > > > >
> > > >
> > > > According to include/linux/reset.h, if the requested reset is not
> > > > specified in the device tree, this function returns NULL instead of
> > > > an error. Therefore, IS_ERR(rst) will only be true for actual
> > > > errors (e.g probe deferral).
> > >
> > > And this is quite obvious, but you haven't answered my qestion.
> > >
> > > Why do we care of internal failures in reset? If reset fails on
> > > an optional reset control function why should we kill our driver?
> >
> > Thanks for the clarification. I see your point now.
> >
> > My reasoning is that if the resets property is explicitly listed in the
> > Device Tree, the driver must respect it.
Sorry, I misread your comment. I thought you were referring to the
bindings. In that case, we are on the same page.
- Troy
> It's not required.
>
> >
> > If the property is present but
> > we encounter an error (like -EPROBE_DEFER), ignoring that failure could
> > put the hardware in an undefined or dirty state.
> Then why it's optional?
>
> The real reason:
> "Optional" here means the reset line is allowed to be absent from the
> Device Tree. It does not mean we can ignore the failure when it is
> defined in the DT but fails to be acquired.
>
> If devm_reset_control_get_optional_* returns an error (e.g.,
> -EPROBE_DEFER), it indicates the hardware description expects a reset
> control, but the system is not yet ready to provide it. Ignoring this
> error would break the probe deferral mechanism and potentially cause the
> driver to access hardware in an invalid state.
>
> - Troy
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH v2 2/3] i2c: k1: add reset support
2025-12-19 7:42 ` [PATCH v2 2/3] i2c: k1: add reset support Encrow Thorne
2025-12-25 21:01 ` Andi Shyti
@ 2025-12-26 3:24 ` Troy Mitchell
1 sibling, 0 replies; 16+ messages in thread
From: Troy Mitchell @ 2025-12-26 3:24 UTC (permalink / raw)
To: Encrow Thorne, Troy Mitchell, Andi Shyti, Rob Herring,
Krzysztof Kozlowski, Conor Dooley, Yixun Lan, Philipp Zabel,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti
Cc: Troy Mitchell, Guodong Xu, linux-i2c, devicetree, linux-riscv,
spacemit, linux-kernel
On Fri, Dec 19, 2025 at 03:42:21PM +0800, Encrow Thorne wrote:
> The K1 I2C controller provides a reset line that needs to be deasserted
> before the controller can be accessed.
>
> Add reset support to the driver to ensure the controller starts in the
> required state.
>
> Signed-off-by: Encrow Thorne <jyc0019@gmail.com>
Reviewed-by: Troy Mitchell <troy.mitchell@linux.spacemit.com>
^ permalink raw reply [flat|nested] 16+ messages in thread
* [PATCH v2 3/3] riscv: dts: spacemit: add reset property
2025-12-19 7:42 [PATCH v2 0/3] i2c: spacemit: add reset support Encrow Thorne
2025-12-19 7:42 ` [PATCH v2 1/3] dt-bindings: i2c: spacemit: add optional resets Encrow Thorne
2025-12-19 7:42 ` [PATCH v2 2/3] i2c: k1: add reset support Encrow Thorne
@ 2025-12-19 7:42 ` Encrow Thorne
2025-12-19 8:03 ` [PATCH v2 0/3] i2c: spacemit: add reset support Krzysztof Kozlowski
3 siblings, 0 replies; 16+ messages in thread
From: Encrow Thorne @ 2025-12-19 7:42 UTC (permalink / raw)
To: Troy Mitchell, Andi Shyti, Rob Herring, Krzysztof Kozlowski,
Conor Dooley, Yixun Lan, Philipp Zabel, Paul Walmsley,
Palmer Dabbelt, Albert Ou, Alexandre Ghiti
Cc: Troy Mitchell, Guodong Xu, linux-i2c, devicetree, linux-riscv,
spacemit, linux-kernel, Encrow Thorne
Add resets property to K1 I2C node.
---
arch/riscv/boot/dts/spacemit/k1.dtsi | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/arch/riscv/boot/dts/spacemit/k1.dtsi b/arch/riscv/boot/dts/spacemit/k1.dtsi
index 7818ca4979b6..085987643638 100644
--- a/arch/riscv/boot/dts/spacemit/k1.dtsi
+++ b/arch/riscv/boot/dts/spacemit/k1.dtsi
@@ -367,6 +367,7 @@ i2c0: i2c@d4010800 {
<&syscon_apbc CLK_TWSI0_BUS>;
clock-names = "func", "bus";
clock-frequency = <400000>;
+ resets = <&syscon_apbc RESET_TWSI0>;
interrupts = <36>;
status = "disabled";
};
@@ -380,6 +381,7 @@ i2c1: i2c@d4011000 {
<&syscon_apbc CLK_TWSI1_BUS>;
clock-names = "func", "bus";
clock-frequency = <400000>;
+ resets = <&syscon_apbc RESET_TWSI1>;
interrupts = <37>;
status = "disabled";
};
@@ -393,6 +395,7 @@ i2c2: i2c@d4012000 {
<&syscon_apbc CLK_TWSI2_BUS>;
clock-names = "func", "bus";
clock-frequency = <400000>;
+ resets = <&syscon_apbc RESET_TWSI2>;
interrupts = <38>;
status = "disabled";
};
@@ -406,6 +409,7 @@ i2c4: i2c@d4012800 {
<&syscon_apbc CLK_TWSI4_BUS>;
clock-names = "func", "bus";
clock-frequency = <400000>;
+ resets = <&syscon_apbc RESET_TWSI4>;
interrupts = <40>;
status = "disabled";
};
@@ -419,6 +423,7 @@ i2c5: i2c@d4013800 {
<&syscon_apbc CLK_TWSI5_BUS>;
clock-names = "func", "bus";
clock-frequency = <400000>;
+ resets = <&syscon_apbc RESET_TWSI5>;
interrupts = <41>;
status = "disabled";
};
@@ -443,6 +448,7 @@ i2c6: i2c@d4018800 {
<&syscon_apbc CLK_TWSI6_BUS>;
clock-names = "func", "bus";
clock-frequency = <400000>;
+ resets = <&syscon_apbc RESET_TWSI6>;
interrupts = <70>;
status = "disabled";
};
@@ -546,6 +552,7 @@ i2c7: i2c@d401d000 {
<&syscon_apbc CLK_TWSI7_BUS>;
clock-names = "func", "bus";
clock-frequency = <400000>;
+ resets = <&syscon_apbc RESET_TWSI7>;
interrupts = <18>;
status = "disabled";
};
@@ -559,6 +566,7 @@ i2c8: i2c@d401d800 {
<&syscon_apbc CLK_TWSI8_BUS>;
clock-names = "func", "bus";
clock-frequency = <400000>;
+ resets = <&syscon_apbc RESET_TWSI8>;
interrupts = <19>;
status = "disabled";
};
--
2.25.1
^ permalink raw reply related [flat|nested] 16+ messages in thread* Re: [PATCH v2 0/3] i2c: spacemit: add reset support
2025-12-19 7:42 [PATCH v2 0/3] i2c: spacemit: add reset support Encrow Thorne
` (2 preceding siblings ...)
2025-12-19 7:42 ` [PATCH v2 3/3] riscv: dts: spacemit: add reset property Encrow Thorne
@ 2025-12-19 8:03 ` Krzysztof Kozlowski
2025-12-27 23:53 ` Guodong Xu
3 siblings, 1 reply; 16+ messages in thread
From: Krzysztof Kozlowski @ 2025-12-19 8:03 UTC (permalink / raw)
To: Encrow Thorne, Troy Mitchell, Andi Shyti, Rob Herring,
Krzysztof Kozlowski, Conor Dooley, Yixun Lan, Philipp Zabel,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti
Cc: Troy Mitchell, Guodong Xu, linux-i2c, devicetree, linux-riscv,
spacemit, linux-kernel
On 19/12/2025 08:42, Encrow Thorne wrote:
> Add reset support for the K1 I2C driver. A reset ensures that the
> controller starts in a clean and known state.
>
> Reset ensures that the I2C hardware is in a clean state. We cannot assume
> that no program used I2C before the kernel booted.
>
> Signed-off-by: Encrow Thorne <jyc0019@gmail.com>
> ---
> Changes in v2:
> - Replace reset property in dt-bindings.
Replace with what? I don't see anything else there - you still have
reset property.
Best regards,
Krzysztof
^ permalink raw reply [flat|nested] 16+ messages in thread* Re: [PATCH v2 0/3] i2c: spacemit: add reset support
2025-12-19 8:03 ` [PATCH v2 0/3] i2c: spacemit: add reset support Krzysztof Kozlowski
@ 2025-12-27 23:53 ` Guodong Xu
2025-12-30 13:56 ` Encrow Thorne
0 siblings, 1 reply; 16+ messages in thread
From: Guodong Xu @ 2025-12-27 23:53 UTC (permalink / raw)
To: Krzysztof Kozlowski
Cc: Encrow Thorne, Troy Mitchell, Andi Shyti, Rob Herring,
Krzysztof Kozlowski, Conor Dooley, Yixun Lan, Philipp Zabel,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Troy Mitchell, linux-i2c, devicetree, linux-riscv, spacemit,
linux-kernel
On Fri, Dec 19, 2025 at 4:03 PM Krzysztof Kozlowski <krzk@kernel.org> wrote:
>
> On 19/12/2025 08:42, Encrow Thorne wrote:
> > Add reset support for the K1 I2C driver. A reset ensures that the
> > controller starts in a clean and known state.
> >
> > Reset ensures that the I2C hardware is in a clean state. We cannot assume
> > that no program used I2C before the kernel booted.
> >
> > Signed-off-by: Encrow Thorne <jyc0019@gmail.com>
> > ---
> > Changes in v2:
> > - Replace reset property in dt-bindings.
>
> Replace with what? I don't see anything else there - you still have
> reset property.
It looks like a phrasing issue. By 'replace,' I guess, Encrow meant that
the resets property was moved (reordered, put into a different 'place')
within the file, not that it was swapped for a different property.
Encow,
Would you please correct your changelog description
in the next version with something like
'Reorder the placement of the resets property in the dt-binding file.'
BR,
Guodong
>
>
> Best regards,
> Krzysztof
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH v2 0/3] i2c: spacemit: add reset support
2025-12-27 23:53 ` Guodong Xu
@ 2025-12-30 13:56 ` Encrow Thorne
0 siblings, 0 replies; 16+ messages in thread
From: Encrow Thorne @ 2025-12-30 13:56 UTC (permalink / raw)
To: Guodong Xu
Cc: Krzysztof Kozlowski, Troy Mitchell, Andi Shyti, Rob Herring,
Krzysztof Kozlowski, Conor Dooley, Yixun Lan, Philipp Zabel,
Paul Walmsley, Palmer Dabbelt, Albert Ou, Alexandre Ghiti,
Troy Mitchell, linux-i2c, devicetree, linux-riscv, spacemit,
linux-kernel
On Sun, Dec 28, 2025 at 07:53:52AM +0800, Guodong Xu wrote:
> On Fri, Dec 19, 2025 at 4:03 PM Krzysztof Kozlowski <krzk@kernel.org> wrote:
> >
> > On 19/12/2025 08:42, Encrow Thorne wrote:
> > > Add reset support for the K1 I2C driver. A reset ensures that the
> > > controller starts in a clean and known state.
> > >
> > > Reset ensures that the I2C hardware is in a clean state. We cannot assume
> > > that no program used I2C before the kernel booted.
> > >
> > > Signed-off-by: Encrow Thorne <jyc0019@gmail.com>
> > > ---
> > > Changes in v2:
> > > - Replace reset property in dt-bindings.
> >
> > Replace with what? I don't see anything else there - you still have
> > reset property.
>
> It looks like a phrasing issue. By 'replace,' I guess, Encrow meant that
> the resets property was moved (reordered, put into a different 'place')
> within the file, not that it was swapped for a different property.
>
> Encow,
>
> Would you please correct your changelog description
> in the next version with something like
> 'Reorder the placement of the resets property in the dt-binding file.'
>
> BR,
> Guodong
>
Thank you for your suggestion, Guodong. I will modify it in the next version.
- Encrow
> >
> >
> > Best regards,
> > Krzysztof
^ permalink raw reply [flat|nested] 16+ messages in thread