public inbox for linux-rtc@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH v1 0/2] RTC: Add Loongson-2K0300 support
@ 2025-12-23  6:42 Binbin Zhou
  2025-12-23  6:42 ` [PATCH v1 1/2] dt-binding: rtc: loongson: Document Loongson-2K0300 compatible Binbin Zhou
                   ` (2 more replies)
  0 siblings, 3 replies; 9+ messages in thread
From: Binbin Zhou @ 2025-12-23  6:42 UTC (permalink / raw)
  To: Binbin Zhou, Huacai Chen, Rob Herring, Krzysztof Kozlowski,
	Conor Dooley, Alexandre Belloni, linux-rtc
  Cc: Xiaochuang Mao, Huacai Chen, Xuerui Wang, loongarch, devicetree,
	linux-mips, Keguang Zhang, Binbin Zhou

Hi all:

This patch set introduces the Loongson-2K0300 RTC, which has a similar
hardware design to the Loongson-1B, but without the alarm feature.

To Keguang:
Would you have time to test the driver on a Loongson-1?

Thanks.
Binbin

Binbin Zhou (2):
  dt-binding: rtc: loongson: Document Loongson-2K0300 compatible
  rtc: loongson: Add Loongson-2K0300 support

 .../devicetree/bindings/rtc/loongson,rtc.yaml | 13 ++++
 drivers/rtc/rtc-loongson.c                    | 65 +++++++++++++------
 2 files changed, 57 insertions(+), 21 deletions(-)


base-commit: 16bd954c93360145bc77cc601e350913fc28182d
-- 
2.47.3


^ permalink raw reply	[flat|nested] 9+ messages in thread

* [PATCH v1 1/2] dt-binding: rtc: loongson: Document Loongson-2K0300 compatible
  2025-12-23  6:42 [PATCH v1 0/2] RTC: Add Loongson-2K0300 support Binbin Zhou
@ 2025-12-23  6:42 ` Binbin Zhou
  2025-12-30  2:15   ` Rob Herring
  2025-12-23  6:42 ` [PATCH v1 2/2] rtc: loongson: Add Loongson-2K0300 support Binbin Zhou
  2025-12-26 10:03 ` [PATCH v1 0/2] RTC: " Keguang Zhang
  2 siblings, 1 reply; 9+ messages in thread
From: Binbin Zhou @ 2025-12-23  6:42 UTC (permalink / raw)
  To: Binbin Zhou, Huacai Chen, Rob Herring, Krzysztof Kozlowski,
	Conor Dooley, Alexandre Belloni, linux-rtc
  Cc: Xiaochuang Mao, Huacai Chen, Xuerui Wang, loongarch, devicetree,
	linux-mips, Keguang Zhang, Binbin Zhou

Add "loongson,ls2k0300-rtc" dedicated compatible to represent the RTC
interface of the Loongson-2K0300 chip.

Its hardware design is similar to that of the Loongson-1B, but it does
not support the alarm feature.

Signed-off-by: Binbin Zhou <zhoubinbin@loongson.cn>
---
 .../devicetree/bindings/rtc/loongson,rtc.yaml       | 13 +++++++++++++
 1 file changed, 13 insertions(+)

diff --git a/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml b/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml
index f89c1f660aee..aac91c79ffdb 100644
--- a/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml
+++ b/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml
@@ -23,6 +23,7 @@ properties:
           - loongson,ls1b-rtc
           - loongson,ls1c-rtc
           - loongson,ls7a-rtc
+          - loongson,ls2k0300-rtc
           - loongson,ls2k1000-rtc
       - items:
           - enum:
@@ -42,6 +43,18 @@ required:
 
 unevaluatedProperties: false
 
+if:
+  properties:
+    compatible:
+      contains:
+        enum:
+          - loongson,ls1c-rtc
+          - loongson,ls2k0300-rtc
+
+then:
+  properties:
+    interrupts: false
+
 examples:
   - |
     #include <dt-bindings/interrupt-controller/irq.h>
-- 
2.47.3


^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH v1 2/2] rtc: loongson: Add Loongson-2K0300 support
  2025-12-23  6:42 [PATCH v1 0/2] RTC: Add Loongson-2K0300 support Binbin Zhou
  2025-12-23  6:42 ` [PATCH v1 1/2] dt-binding: rtc: loongson: Document Loongson-2K0300 compatible Binbin Zhou
@ 2025-12-23  6:42 ` Binbin Zhou
  2025-12-23  8:40   ` Huacai Chen
  2025-12-26 10:03 ` [PATCH v1 0/2] RTC: " Keguang Zhang
  2 siblings, 1 reply; 9+ messages in thread
From: Binbin Zhou @ 2025-12-23  6:42 UTC (permalink / raw)
  To: Binbin Zhou, Huacai Chen, Rob Herring, Krzysztof Kozlowski,
	Conor Dooley, Alexandre Belloni, linux-rtc
  Cc: Xiaochuang Mao, Huacai Chen, Xuerui Wang, loongarch, devicetree,
	linux-mips, Keguang Zhang, Binbin Zhou

The Loongson-2K0300's rtc hardware design is similar to that of the
Loongson-1B, but it does not support the alarm feature.

Introduce `LOONGSON_RTC_ALARM_WORKAROUND`, which indicates a chip that
does not support the alarm function, and rewritethe related logic in
`loongson_rtc_alarm_setting()`

Signed-off-by: Binbin Zhou <zhoubinbin@loongson.cn>
---
 drivers/rtc/rtc-loongson.c | 65 ++++++++++++++++++++++++++------------
 1 file changed, 44 insertions(+), 21 deletions(-)

diff --git a/drivers/rtc/rtc-loongson.c b/drivers/rtc/rtc-loongson.c
index 2ca7ffd5d7a9..6b076bd4e24e 100644
--- a/drivers/rtc/rtc-loongson.c
+++ b/drivers/rtc/rtc-loongson.c
@@ -67,6 +67,7 @@
  * Accessing the relevant registers will cause the system to hang.
  */
 #define LS1C_RTC_CTRL_WORKAROUND	BIT(0)
+#define LOONGSON_RTC_ALARM_WORKAROUND	BIT(1)
 
 struct loongson_rtc_config {
 	u32 pm_offset;	/* Offset of PM domain, for RTC alarm wakeup */
@@ -89,7 +90,7 @@ static const struct loongson_rtc_config ls1b_rtc_config = {
 
 static const struct loongson_rtc_config ls1c_rtc_config = {
 	.pm_offset = 0,
-	.flags = LS1C_RTC_CTRL_WORKAROUND,
+	.flags = LS1C_RTC_CTRL_WORKAROUND | LOONGSON_RTC_ALARM_WORKAROUND,
 };
 
 static const struct loongson_rtc_config generic_rtc_config = {
@@ -97,6 +98,11 @@ static const struct loongson_rtc_config generic_rtc_config = {
 	.flags = 0,
 };
 
+static const struct loongson_rtc_config ls2k0300_rtc_config = {
+	.pm_offset = 0x0,
+	.flags = LOONGSON_RTC_ALARM_WORKAROUND,
+};
+
 static const struct loongson_rtc_config ls2k1000_rtc_config = {
 	.pm_offset = 0x800,
 	.flags = 0,
@@ -299,9 +305,41 @@ static const struct rtc_class_ops loongson_rtc_ops = {
 	.alarm_irq_enable = loongson_rtc_alarm_irq_enable,
 };
 
+static int loongson_rtc_alarm_setting(struct platform_device *pdev, void __iomem *regs)
+{
+	int ret = 0, alarm_irq;
+	struct device *dev = &pdev->dev;
+	struct loongson_rtc_priv *priv = dev_get_drvdata(dev);
+
+	if (priv->config->flags & LOONGSON_RTC_ALARM_WORKAROUND) {
+		/* Loongson-1C/Loongson-2K0300 RTC does not support alarm */
+		clear_bit(RTC_FEATURE_ALARM, priv->rtcdev->features);
+		return 0;
+	}
+
+	/* Get RTC alarm irq */
+	alarm_irq = platform_get_irq(pdev, 0);
+	if (alarm_irq < 0)
+		return alarm_irq;
+
+	ret = devm_request_irq(dev, alarm_irq, loongson_rtc_isr, 0, "loongson-alarm",
+			       priv);
+	if (ret < 0)
+		return ret;
+
+	priv->pm_base = regs - priv->config->pm_offset;
+	device_init_wakeup(dev, true);
+
+	if (has_acpi_companion(dev))
+		acpi_install_fixed_event_handler(ACPI_EVENT_RTC,
+						 loongson_rtc_handler, priv);
+
+	return ret;
+}
+
 static int loongson_rtc_probe(struct platform_device *pdev)
 {
-	int ret, alarm_irq;
+	int ret;
 	void __iomem *regs;
 	struct loongson_rtc_priv *priv;
 	struct device *dev = &pdev->dev;
@@ -330,25 +368,9 @@ static int loongson_rtc_probe(struct platform_device *pdev)
 		return dev_err_probe(dev, PTR_ERR(priv->rtcdev),
 				     "devm_rtc_allocate_device failed\n");
 
-	/* Get RTC alarm irq */
-	alarm_irq = platform_get_irq(pdev, 0);
-	if (alarm_irq > 0) {
-		ret = devm_request_irq(dev, alarm_irq, loongson_rtc_isr,
-				       0, "loongson-alarm", priv);
-		if (ret < 0)
-			return dev_err_probe(dev, ret, "Unable to request irq %d\n",
-					     alarm_irq);
-
-		priv->pm_base = regs - priv->config->pm_offset;
-		device_init_wakeup(dev, true);
-
-		if (has_acpi_companion(dev))
-			acpi_install_fixed_event_handler(ACPI_EVENT_RTC,
-							 loongson_rtc_handler, priv);
-	} else {
-		/* Loongson-1C RTC does not support alarm */
-		clear_bit(RTC_FEATURE_ALARM, priv->rtcdev->features);
-	}
+	ret = loongson_rtc_alarm_setting(pdev, regs);
+	if (ret)
+		return ret;
 
 	/* Loongson RTC does not support UIE */
 	clear_bit(RTC_FEATURE_UPDATE_INTERRUPT, priv->rtcdev->features);
@@ -379,6 +401,7 @@ static const struct of_device_id loongson_rtc_of_match[] = {
 	{ .compatible = "loongson,ls1b-rtc", .data = &ls1b_rtc_config },
 	{ .compatible = "loongson,ls1c-rtc", .data = &ls1c_rtc_config },
 	{ .compatible = "loongson,ls7a-rtc", .data = &generic_rtc_config },
+	{ .compatible = "loongson,ls2k0300-rtc", .data = &ls2k0300_rtc_config },
 	{ .compatible = "loongson,ls2k1000-rtc", .data = &ls2k1000_rtc_config },
 	{ /* sentinel */ }
 };
-- 
2.47.3


^ permalink raw reply related	[flat|nested] 9+ messages in thread

* Re: [PATCH v1 2/2] rtc: loongson: Add Loongson-2K0300 support
  2025-12-23  6:42 ` [PATCH v1 2/2] rtc: loongson: Add Loongson-2K0300 support Binbin Zhou
@ 2025-12-23  8:40   ` Huacai Chen
  2025-12-23  9:06     ` Binbin Zhou
  0 siblings, 1 reply; 9+ messages in thread
From: Huacai Chen @ 2025-12-23  8:40 UTC (permalink / raw)
  To: Binbin Zhou
  Cc: Binbin Zhou, Huacai Chen, Rob Herring, Krzysztof Kozlowski,
	Conor Dooley, Alexandre Belloni, linux-rtc, Xiaochuang Mao,
	Xuerui Wang, loongarch, devicetree, linux-mips, Keguang Zhang

Hi, Binbin,

On Tue, Dec 23, 2025 at 2:42 PM Binbin Zhou <zhoubinbin@loongson.cn> wrote:
>
> The Loongson-2K0300's rtc hardware design is similar to that of the
> Loongson-1B, but it does not support the alarm feature.
>
> Introduce `LOONGSON_RTC_ALARM_WORKAROUND`, which indicates a chip that
> does not support the alarm function, and rewritethe related logic in
> `loongson_rtc_alarm_setting()`
>
> Signed-off-by: Binbin Zhou <zhoubinbin@loongson.cn>
> ---
>  drivers/rtc/rtc-loongson.c | 65 ++++++++++++++++++++++++++------------
>  1 file changed, 44 insertions(+), 21 deletions(-)
>
> diff --git a/drivers/rtc/rtc-loongson.c b/drivers/rtc/rtc-loongson.c
> index 2ca7ffd5d7a9..6b076bd4e24e 100644
> --- a/drivers/rtc/rtc-loongson.c
> +++ b/drivers/rtc/rtc-loongson.c
> @@ -67,6 +67,7 @@
>   * Accessing the relevant registers will cause the system to hang.
>   */
>  #define LS1C_RTC_CTRL_WORKAROUND       BIT(0)
> +#define LOONGSON_RTC_ALARM_WORKAROUND  BIT(1)
Can we reuse existing logic, which means "alarm_irq =
platform_get_irq(pdev, 0)" return 0 for LS2K0300?

Huacai

>
>  struct loongson_rtc_config {
>         u32 pm_offset;  /* Offset of PM domain, for RTC alarm wakeup */
> @@ -89,7 +90,7 @@ static const struct loongson_rtc_config ls1b_rtc_config = {
>
>  static const struct loongson_rtc_config ls1c_rtc_config = {
>         .pm_offset = 0,
> -       .flags = LS1C_RTC_CTRL_WORKAROUND,
> +       .flags = LS1C_RTC_CTRL_WORKAROUND | LOONGSON_RTC_ALARM_WORKAROUND,
>  };
>
>  static const struct loongson_rtc_config generic_rtc_config = {
> @@ -97,6 +98,11 @@ static const struct loongson_rtc_config generic_rtc_config = {
>         .flags = 0,
>  };
>
> +static const struct loongson_rtc_config ls2k0300_rtc_config = {
> +       .pm_offset = 0x0,
> +       .flags = LOONGSON_RTC_ALARM_WORKAROUND,
> +};
> +
>  static const struct loongson_rtc_config ls2k1000_rtc_config = {
>         .pm_offset = 0x800,
>         .flags = 0,
> @@ -299,9 +305,41 @@ static const struct rtc_class_ops loongson_rtc_ops = {
>         .alarm_irq_enable = loongson_rtc_alarm_irq_enable,
>  };
>
> +static int loongson_rtc_alarm_setting(struct platform_device *pdev, void __iomem *regs)
> +{
> +       int ret = 0, alarm_irq;
> +       struct device *dev = &pdev->dev;
> +       struct loongson_rtc_priv *priv = dev_get_drvdata(dev);
> +
> +       if (priv->config->flags & LOONGSON_RTC_ALARM_WORKAROUND) {
> +               /* Loongson-1C/Loongson-2K0300 RTC does not support alarm */
> +               clear_bit(RTC_FEATURE_ALARM, priv->rtcdev->features);
> +               return 0;
> +       }
> +
> +       /* Get RTC alarm irq */
> +       alarm_irq = platform_get_irq(pdev, 0);
> +       if (alarm_irq < 0)
> +               return alarm_irq;
> +
> +       ret = devm_request_irq(dev, alarm_irq, loongson_rtc_isr, 0, "loongson-alarm",
> +                              priv);
> +       if (ret < 0)
> +               return ret;
> +
> +       priv->pm_base = regs - priv->config->pm_offset;
> +       device_init_wakeup(dev, true);
> +
> +       if (has_acpi_companion(dev))
> +               acpi_install_fixed_event_handler(ACPI_EVENT_RTC,
> +                                                loongson_rtc_handler, priv);
> +
> +       return ret;
> +}
> +
>  static int loongson_rtc_probe(struct platform_device *pdev)
>  {
> -       int ret, alarm_irq;
> +       int ret;
>         void __iomem *regs;
>         struct loongson_rtc_priv *priv;
>         struct device *dev = &pdev->dev;
> @@ -330,25 +368,9 @@ static int loongson_rtc_probe(struct platform_device *pdev)
>                 return dev_err_probe(dev, PTR_ERR(priv->rtcdev),
>                                      "devm_rtc_allocate_device failed\n");
>
> -       /* Get RTC alarm irq */
> -       alarm_irq = platform_get_irq(pdev, 0);
> -       if (alarm_irq > 0) {
> -               ret = devm_request_irq(dev, alarm_irq, loongson_rtc_isr,
> -                                      0, "loongson-alarm", priv);
> -               if (ret < 0)
> -                       return dev_err_probe(dev, ret, "Unable to request irq %d\n",
> -                                            alarm_irq);
> -
> -               priv->pm_base = regs - priv->config->pm_offset;
> -               device_init_wakeup(dev, true);
> -
> -               if (has_acpi_companion(dev))
> -                       acpi_install_fixed_event_handler(ACPI_EVENT_RTC,
> -                                                        loongson_rtc_handler, priv);
> -       } else {
> -               /* Loongson-1C RTC does not support alarm */
> -               clear_bit(RTC_FEATURE_ALARM, priv->rtcdev->features);
> -       }
> +       ret = loongson_rtc_alarm_setting(pdev, regs);
> +       if (ret)
> +               return ret;
>
>         /* Loongson RTC does not support UIE */
>         clear_bit(RTC_FEATURE_UPDATE_INTERRUPT, priv->rtcdev->features);
> @@ -379,6 +401,7 @@ static const struct of_device_id loongson_rtc_of_match[] = {
>         { .compatible = "loongson,ls1b-rtc", .data = &ls1b_rtc_config },
>         { .compatible = "loongson,ls1c-rtc", .data = &ls1c_rtc_config },
>         { .compatible = "loongson,ls7a-rtc", .data = &generic_rtc_config },
> +       { .compatible = "loongson,ls2k0300-rtc", .data = &ls2k0300_rtc_config },
>         { .compatible = "loongson,ls2k1000-rtc", .data = &ls2k1000_rtc_config },
>         { /* sentinel */ }
>  };
> --
> 2.47.3
>
>

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH v1 2/2] rtc: loongson: Add Loongson-2K0300 support
  2025-12-23  8:40   ` Huacai Chen
@ 2025-12-23  9:06     ` Binbin Zhou
  2025-12-23  9:09       ` Huacai Chen
  0 siblings, 1 reply; 9+ messages in thread
From: Binbin Zhou @ 2025-12-23  9:06 UTC (permalink / raw)
  To: Huacai Chen
  Cc: Binbin Zhou, Huacai Chen, Rob Herring, Krzysztof Kozlowski,
	Conor Dooley, Alexandre Belloni, linux-rtc, Xiaochuang Mao,
	Xuerui Wang, loongarch, devicetree, linux-mips, Keguang Zhang

Hi:


On Tue, Dec 23, 2025 at 4:40 PM Huacai Chen <chenhuacai@kernel.org> wrote:
>
> Hi, Binbin,
>
> On Tue, Dec 23, 2025 at 2:42 PM Binbin Zhou <zhoubinbin@loongson.cn> wrote:
> >
> > The Loongson-2K0300's rtc hardware design is similar to that of the
> > Loongson-1B, but it does not support the alarm feature.
> >
> > Introduce `LOONGSON_RTC_ALARM_WORKAROUND`, which indicates a chip that
> > does not support the alarm function, and rewritethe related logic in
> > `loongson_rtc_alarm_setting()`
> >
> > Signed-off-by: Binbin Zhou <zhoubinbin@loongson.cn>
> > ---
> >  drivers/rtc/rtc-loongson.c | 65 ++++++++++++++++++++++++++------------
> >  1 file changed, 44 insertions(+), 21 deletions(-)
> >
> > diff --git a/drivers/rtc/rtc-loongson.c b/drivers/rtc/rtc-loongson.c
> > index 2ca7ffd5d7a9..6b076bd4e24e 100644
> > --- a/drivers/rtc/rtc-loongson.c
> > +++ b/drivers/rtc/rtc-loongson.c
> > @@ -67,6 +67,7 @@
> >   * Accessing the relevant registers will cause the system to hang.
> >   */
> >  #define LS1C_RTC_CTRL_WORKAROUND       BIT(0)
> > +#define LOONGSON_RTC_ALARM_WORKAROUND  BIT(1)
> Can we reuse existing logic, which means "alarm_irq =
> platform_get_irq(pdev, 0)" return 0 for LS2K0300?

First of all, as I understand it, platform_get_irq() doesn't normally
return 0 unless interrupt 0 is configured in the DTS, which doesn't
seem appropriate.

Also, the return value of platform_get_irq() was previously used to
determine if the alarm feature was supported, which is not
particularly accurate. It should be an inherent feature of the chip,
and I think it would be more appropriate to define it in
loongson_rtc_config.
>
> Huacai
>
> >
> >  struct loongson_rtc_config {
> >         u32 pm_offset;  /* Offset of PM domain, for RTC alarm wakeup */
> > @@ -89,7 +90,7 @@ static const struct loongson_rtc_config ls1b_rtc_config = {
> >
> >  static const struct loongson_rtc_config ls1c_rtc_config = {
> >         .pm_offset = 0,
> > -       .flags = LS1C_RTC_CTRL_WORKAROUND,
> > +       .flags = LS1C_RTC_CTRL_WORKAROUND | LOONGSON_RTC_ALARM_WORKAROUND,
> >  };
> >
> >  static const struct loongson_rtc_config generic_rtc_config = {
> > @@ -97,6 +98,11 @@ static const struct loongson_rtc_config generic_rtc_config = {
> >         .flags = 0,
> >  };
> >
> > +static const struct loongson_rtc_config ls2k0300_rtc_config = {
> > +       .pm_offset = 0x0,
> > +       .flags = LOONGSON_RTC_ALARM_WORKAROUND,
> > +};
> > +
> >  static const struct loongson_rtc_config ls2k1000_rtc_config = {
> >         .pm_offset = 0x800,
> >         .flags = 0,
> > @@ -299,9 +305,41 @@ static const struct rtc_class_ops loongson_rtc_ops = {
> >         .alarm_irq_enable = loongson_rtc_alarm_irq_enable,
> >  };
> >
> > +static int loongson_rtc_alarm_setting(struct platform_device *pdev, void __iomem *regs)
> > +{
> > +       int ret = 0, alarm_irq;
> > +       struct device *dev = &pdev->dev;
> > +       struct loongson_rtc_priv *priv = dev_get_drvdata(dev);
> > +
> > +       if (priv->config->flags & LOONGSON_RTC_ALARM_WORKAROUND) {
> > +               /* Loongson-1C/Loongson-2K0300 RTC does not support alarm */
> > +               clear_bit(RTC_FEATURE_ALARM, priv->rtcdev->features);
> > +               return 0;
> > +       }
> > +
> > +       /* Get RTC alarm irq */
> > +       alarm_irq = platform_get_irq(pdev, 0);
> > +       if (alarm_irq < 0)
> > +               return alarm_irq;
> > +
> > +       ret = devm_request_irq(dev, alarm_irq, loongson_rtc_isr, 0, "loongson-alarm",
> > +                              priv);
> > +       if (ret < 0)
> > +               return ret;
> > +
> > +       priv->pm_base = regs - priv->config->pm_offset;
> > +       device_init_wakeup(dev, true);
> > +
> > +       if (has_acpi_companion(dev))
> > +               acpi_install_fixed_event_handler(ACPI_EVENT_RTC,
> > +                                                loongson_rtc_handler, priv);
> > +
> > +       return ret;
> > +}
> > +
> >  static int loongson_rtc_probe(struct platform_device *pdev)
> >  {
> > -       int ret, alarm_irq;
> > +       int ret;
> >         void __iomem *regs;
> >         struct loongson_rtc_priv *priv;
> >         struct device *dev = &pdev->dev;
> > @@ -330,25 +368,9 @@ static int loongson_rtc_probe(struct platform_device *pdev)
> >                 return dev_err_probe(dev, PTR_ERR(priv->rtcdev),
> >                                      "devm_rtc_allocate_device failed\n");
> >
> > -       /* Get RTC alarm irq */
> > -       alarm_irq = platform_get_irq(pdev, 0);
> > -       if (alarm_irq > 0) {
> > -               ret = devm_request_irq(dev, alarm_irq, loongson_rtc_isr,
> > -                                      0, "loongson-alarm", priv);
> > -               if (ret < 0)
> > -                       return dev_err_probe(dev, ret, "Unable to request irq %d\n",
> > -                                            alarm_irq);
> > -
> > -               priv->pm_base = regs - priv->config->pm_offset;
> > -               device_init_wakeup(dev, true);
> > -
> > -               if (has_acpi_companion(dev))
> > -                       acpi_install_fixed_event_handler(ACPI_EVENT_RTC,
> > -                                                        loongson_rtc_handler, priv);
> > -       } else {
> > -               /* Loongson-1C RTC does not support alarm */
> > -               clear_bit(RTC_FEATURE_ALARM, priv->rtcdev->features);
> > -       }
> > +       ret = loongson_rtc_alarm_setting(pdev, regs);
> > +       if (ret)
> > +               return ret;
> >
> >         /* Loongson RTC does not support UIE */
> >         clear_bit(RTC_FEATURE_UPDATE_INTERRUPT, priv->rtcdev->features);
> > @@ -379,6 +401,7 @@ static const struct of_device_id loongson_rtc_of_match[] = {
> >         { .compatible = "loongson,ls1b-rtc", .data = &ls1b_rtc_config },
> >         { .compatible = "loongson,ls1c-rtc", .data = &ls1c_rtc_config },
> >         { .compatible = "loongson,ls7a-rtc", .data = &generic_rtc_config },
> > +       { .compatible = "loongson,ls2k0300-rtc", .data = &ls2k0300_rtc_config },
> >         { .compatible = "loongson,ls2k1000-rtc", .data = &ls2k1000_rtc_config },
> >         { /* sentinel */ }
> >  };
> > --
> > 2.47.3
> >
> >

--
Thanks.
Binbin

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH v1 2/2] rtc: loongson: Add Loongson-2K0300 support
  2025-12-23  9:06     ` Binbin Zhou
@ 2025-12-23  9:09       ` Huacai Chen
  0 siblings, 0 replies; 9+ messages in thread
From: Huacai Chen @ 2025-12-23  9:09 UTC (permalink / raw)
  To: Binbin Zhou
  Cc: Binbin Zhou, Huacai Chen, Rob Herring, Krzysztof Kozlowski,
	Conor Dooley, Alexandre Belloni, linux-rtc, Xiaochuang Mao,
	Xuerui Wang, loongarch, devicetree, linux-mips, Keguang Zhang

On Tue, Dec 23, 2025 at 5:06 PM Binbin Zhou <zhoubb.aaron@gmail.com> wrote:
>
> Hi:
>
>
> On Tue, Dec 23, 2025 at 4:40 PM Huacai Chen <chenhuacai@kernel.org> wrote:
> >
> > Hi, Binbin,
> >
> > On Tue, Dec 23, 2025 at 2:42 PM Binbin Zhou <zhoubinbin@loongson.cn> wrote:
> > >
> > > The Loongson-2K0300's rtc hardware design is similar to that of the
> > > Loongson-1B, but it does not support the alarm feature.
> > >
> > > Introduce `LOONGSON_RTC_ALARM_WORKAROUND`, which indicates a chip that
> > > does not support the alarm function, and rewritethe related logic in
> > > `loongson_rtc_alarm_setting()`
> > >
> > > Signed-off-by: Binbin Zhou <zhoubinbin@loongson.cn>
> > > ---
> > >  drivers/rtc/rtc-loongson.c | 65 ++++++++++++++++++++++++++------------
> > >  1 file changed, 44 insertions(+), 21 deletions(-)
> > >
> > > diff --git a/drivers/rtc/rtc-loongson.c b/drivers/rtc/rtc-loongson.c
> > > index 2ca7ffd5d7a9..6b076bd4e24e 100644
> > > --- a/drivers/rtc/rtc-loongson.c
> > > +++ b/drivers/rtc/rtc-loongson.c
> > > @@ -67,6 +67,7 @@
> > >   * Accessing the relevant registers will cause the system to hang.
> > >   */
> > >  #define LS1C_RTC_CTRL_WORKAROUND       BIT(0)
> > > +#define LOONGSON_RTC_ALARM_WORKAROUND  BIT(1)
> > Can we reuse existing logic, which means "alarm_irq =
> > platform_get_irq(pdev, 0)" return 0 for LS2K0300?
>
> First of all, as I understand it, platform_get_irq() doesn't normally
> return 0 unless interrupt 0 is configured in the DTS, which doesn't
> seem appropriate.
>
> Also, the return value of platform_get_irq() was previously used to
> determine if the alarm feature was supported, which is not
> particularly accurate. It should be an inherent feature of the chip,
> and I think it would be more appropriate to define it in
> loongson_rtc_config.
OK, then I think it is better to rename LS1C_RTC_CTRL_WORKAROUND to
LOONGSON_RTC_CTRL_WORKAROUND for consistency.

Huacai

> >
> > Huacai
> >
> > >
> > >  struct loongson_rtc_config {
> > >         u32 pm_offset;  /* Offset of PM domain, for RTC alarm wakeup */
> > > @@ -89,7 +90,7 @@ static const struct loongson_rtc_config ls1b_rtc_config = {
> > >
> > >  static const struct loongson_rtc_config ls1c_rtc_config = {
> > >         .pm_offset = 0,
> > > -       .flags = LS1C_RTC_CTRL_WORKAROUND,
> > > +       .flags = LS1C_RTC_CTRL_WORKAROUND | LOONGSON_RTC_ALARM_WORKAROUND,
> > >  };
> > >
> > >  static const struct loongson_rtc_config generic_rtc_config = {
> > > @@ -97,6 +98,11 @@ static const struct loongson_rtc_config generic_rtc_config = {
> > >         .flags = 0,
> > >  };
> > >
> > > +static const struct loongson_rtc_config ls2k0300_rtc_config = {
> > > +       .pm_offset = 0x0,
> > > +       .flags = LOONGSON_RTC_ALARM_WORKAROUND,
> > > +};
> > > +
> > >  static const struct loongson_rtc_config ls2k1000_rtc_config = {
> > >         .pm_offset = 0x800,
> > >         .flags = 0,
> > > @@ -299,9 +305,41 @@ static const struct rtc_class_ops loongson_rtc_ops = {
> > >         .alarm_irq_enable = loongson_rtc_alarm_irq_enable,
> > >  };
> > >
> > > +static int loongson_rtc_alarm_setting(struct platform_device *pdev, void __iomem *regs)
> > > +{
> > > +       int ret = 0, alarm_irq;
> > > +       struct device *dev = &pdev->dev;
> > > +       struct loongson_rtc_priv *priv = dev_get_drvdata(dev);
> > > +
> > > +       if (priv->config->flags & LOONGSON_RTC_ALARM_WORKAROUND) {
> > > +               /* Loongson-1C/Loongson-2K0300 RTC does not support alarm */
> > > +               clear_bit(RTC_FEATURE_ALARM, priv->rtcdev->features);
> > > +               return 0;
> > > +       }
> > > +
> > > +       /* Get RTC alarm irq */
> > > +       alarm_irq = platform_get_irq(pdev, 0);
> > > +       if (alarm_irq < 0)
> > > +               return alarm_irq;
> > > +
> > > +       ret = devm_request_irq(dev, alarm_irq, loongson_rtc_isr, 0, "loongson-alarm",
> > > +                              priv);
> > > +       if (ret < 0)
> > > +               return ret;
> > > +
> > > +       priv->pm_base = regs - priv->config->pm_offset;
> > > +       device_init_wakeup(dev, true);
> > > +
> > > +       if (has_acpi_companion(dev))
> > > +               acpi_install_fixed_event_handler(ACPI_EVENT_RTC,
> > > +                                                loongson_rtc_handler, priv);
> > > +
> > > +       return ret;
> > > +}
> > > +
> > >  static int loongson_rtc_probe(struct platform_device *pdev)
> > >  {
> > > -       int ret, alarm_irq;
> > > +       int ret;
> > >         void __iomem *regs;
> > >         struct loongson_rtc_priv *priv;
> > >         struct device *dev = &pdev->dev;
> > > @@ -330,25 +368,9 @@ static int loongson_rtc_probe(struct platform_device *pdev)
> > >                 return dev_err_probe(dev, PTR_ERR(priv->rtcdev),
> > >                                      "devm_rtc_allocate_device failed\n");
> > >
> > > -       /* Get RTC alarm irq */
> > > -       alarm_irq = platform_get_irq(pdev, 0);
> > > -       if (alarm_irq > 0) {
> > > -               ret = devm_request_irq(dev, alarm_irq, loongson_rtc_isr,
> > > -                                      0, "loongson-alarm", priv);
> > > -               if (ret < 0)
> > > -                       return dev_err_probe(dev, ret, "Unable to request irq %d\n",
> > > -                                            alarm_irq);
> > > -
> > > -               priv->pm_base = regs - priv->config->pm_offset;
> > > -               device_init_wakeup(dev, true);
> > > -
> > > -               if (has_acpi_companion(dev))
> > > -                       acpi_install_fixed_event_handler(ACPI_EVENT_RTC,
> > > -                                                        loongson_rtc_handler, priv);
> > > -       } else {
> > > -               /* Loongson-1C RTC does not support alarm */
> > > -               clear_bit(RTC_FEATURE_ALARM, priv->rtcdev->features);
> > > -       }
> > > +       ret = loongson_rtc_alarm_setting(pdev, regs);
> > > +       if (ret)
> > > +               return ret;
> > >
> > >         /* Loongson RTC does not support UIE */
> > >         clear_bit(RTC_FEATURE_UPDATE_INTERRUPT, priv->rtcdev->features);
> > > @@ -379,6 +401,7 @@ static const struct of_device_id loongson_rtc_of_match[] = {
> > >         { .compatible = "loongson,ls1b-rtc", .data = &ls1b_rtc_config },
> > >         { .compatible = "loongson,ls1c-rtc", .data = &ls1c_rtc_config },
> > >         { .compatible = "loongson,ls7a-rtc", .data = &generic_rtc_config },
> > > +       { .compatible = "loongson,ls2k0300-rtc", .data = &ls2k0300_rtc_config },
> > >         { .compatible = "loongson,ls2k1000-rtc", .data = &ls2k1000_rtc_config },
> > >         { /* sentinel */ }
> > >  };
> > > --
> > > 2.47.3
> > >
> > >
>
> --
> Thanks.
> Binbin

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH v1 0/2] RTC: Add Loongson-2K0300 support
  2025-12-23  6:42 [PATCH v1 0/2] RTC: Add Loongson-2K0300 support Binbin Zhou
  2025-12-23  6:42 ` [PATCH v1 1/2] dt-binding: rtc: loongson: Document Loongson-2K0300 compatible Binbin Zhou
  2025-12-23  6:42 ` [PATCH v1 2/2] rtc: loongson: Add Loongson-2K0300 support Binbin Zhou
@ 2025-12-26 10:03 ` Keguang Zhang
  2 siblings, 0 replies; 9+ messages in thread
From: Keguang Zhang @ 2025-12-26 10:03 UTC (permalink / raw)
  To: Binbin Zhou
  Cc: Binbin Zhou, Huacai Chen, Rob Herring, Krzysztof Kozlowski,
	Conor Dooley, Alexandre Belloni, linux-rtc, Xiaochuang Mao,
	Huacai Chen, Xuerui Wang, loongarch, devicetree, linux-mips

For the whole series:

Reviewed-by: Keguang Zhang <keguang.zhang@gmail.com>
Tested-by: Keguang Zhang <keguang.zhang@gmail.com> # on LS1B & LS1C

On Tue, Dec 23, 2025 at 2:42 PM Binbin Zhou <zhoubinbin@loongson.cn> wrote:
>
> Hi all:
>
> This patch set introduces the Loongson-2K0300 RTC, which has a similar
> hardware design to the Loongson-1B, but without the alarm feature.
>
> To Keguang:
> Would you have time to test the driver on a Loongson-1?
>
> Thanks.
> Binbin
>
> Binbin Zhou (2):
>   dt-binding: rtc: loongson: Document Loongson-2K0300 compatible
>   rtc: loongson: Add Loongson-2K0300 support
>
>  .../devicetree/bindings/rtc/loongson,rtc.yaml | 13 ++++
>  drivers/rtc/rtc-loongson.c                    | 65 +++++++++++++------
>  2 files changed, 57 insertions(+), 21 deletions(-)
>
>
> base-commit: 16bd954c93360145bc77cc601e350913fc28182d
> --
> 2.47.3
>


-- 
Best regards,

Keguang Zhang

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH v1 1/2] dt-binding: rtc: loongson: Document Loongson-2K0300 compatible
  2025-12-23  6:42 ` [PATCH v1 1/2] dt-binding: rtc: loongson: Document Loongson-2K0300 compatible Binbin Zhou
@ 2025-12-30  2:15   ` Rob Herring
  2025-12-30  2:31     ` Binbin Zhou
  0 siblings, 1 reply; 9+ messages in thread
From: Rob Herring @ 2025-12-30  2:15 UTC (permalink / raw)
  To: Binbin Zhou
  Cc: Binbin Zhou, Huacai Chen, Krzysztof Kozlowski, Conor Dooley,
	Alexandre Belloni, linux-rtc, Xiaochuang Mao, Huacai Chen,
	Xuerui Wang, loongarch, devicetree, linux-mips, Keguang Zhang

On Tue, Dec 23, 2025 at 02:42:12PM +0800, Binbin Zhou wrote:
> Add "loongson,ls2k0300-rtc" dedicated compatible to represent the RTC
> interface of the Loongson-2K0300 chip.
> 
> Its hardware design is similar to that of the Loongson-1B, but it does
> not support the alarm feature.
> 
> Signed-off-by: Binbin Zhou <zhoubinbin@loongson.cn>
> ---
>  .../devicetree/bindings/rtc/loongson,rtc.yaml       | 13 +++++++++++++
>  1 file changed, 13 insertions(+)
> 
> diff --git a/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml b/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml
> index f89c1f660aee..aac91c79ffdb 100644
> --- a/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml
> +++ b/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml
> @@ -23,6 +23,7 @@ properties:
>            - loongson,ls1b-rtc
>            - loongson,ls1c-rtc
>            - loongson,ls7a-rtc
> +          - loongson,ls2k0300-rtc
>            - loongson,ls2k1000-rtc
>        - items:
>            - enum:
> @@ -42,6 +43,18 @@ required:
>  
>  unevaluatedProperties: false
>  
> +if:
> +  properties:
> +    compatible:
> +      contains:
> +        enum:
> +          - loongson,ls1c-rtc

This seems unrelated?

> +          - loongson,ls2k0300-rtc
> +
> +then:
> +  properties:
> +    interrupts: false
> +
>  examples:
>    - |
>      #include <dt-bindings/interrupt-controller/irq.h>
> -- 
> 2.47.3
> 

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH v1 1/2] dt-binding: rtc: loongson: Document Loongson-2K0300 compatible
  2025-12-30  2:15   ` Rob Herring
@ 2025-12-30  2:31     ` Binbin Zhou
  0 siblings, 0 replies; 9+ messages in thread
From: Binbin Zhou @ 2025-12-30  2:31 UTC (permalink / raw)
  To: Rob Herring
  Cc: Binbin Zhou, Huacai Chen, Krzysztof Kozlowski, Conor Dooley,
	Alexandre Belloni, linux-rtc, Xiaochuang Mao, Huacai Chen,
	Xuerui Wang, loongarch, devicetree, linux-mips, Keguang Zhang

Hi Rob:

Thanks for your review.

On Tue, Dec 30, 2025 at 10:15 AM Rob Herring <robh@kernel.org> wrote:
>
> On Tue, Dec 23, 2025 at 02:42:12PM +0800, Binbin Zhou wrote:
> > Add "loongson,ls2k0300-rtc" dedicated compatible to represent the RTC
> > interface of the Loongson-2K0300 chip.
> >
> > Its hardware design is similar to that of the Loongson-1B, but it does
> > not support the alarm feature.
> >
> > Signed-off-by: Binbin Zhou <zhoubinbin@loongson.cn>
> > ---
> >  .../devicetree/bindings/rtc/loongson,rtc.yaml       | 13 +++++++++++++
> >  1 file changed, 13 insertions(+)
> >
> > diff --git a/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml b/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml
> > index f89c1f660aee..aac91c79ffdb 100644
> > --- a/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml
> > +++ b/Documentation/devicetree/bindings/rtc/loongson,rtc.yaml
> > @@ -23,6 +23,7 @@ properties:
> >            - loongson,ls1b-rtc
> >            - loongson,ls1c-rtc
> >            - loongson,ls7a-rtc
> > +          - loongson,ls2k0300-rtc
> >            - loongson,ls2k1000-rtc
> >        - items:
> >            - enum:
> > @@ -42,6 +43,18 @@ required:
> >
> >  unevaluatedProperties: false
> >
> > +if:
> > +  properties:
> > +    compatible:
> > +      contains:
> > +        enum:
> > +          - loongson,ls1c-rtc
>
> This seems unrelated?

Loongson-1C does not support the alarm feature, so the `interrupts`
property is not needed.

Technically, this is my fault and should have been described in the
binding before, just correcting it now.
Perhaps I should have mentioned this in the commit message.
>
> > +          - loongson,ls2k0300-rtc
> > +
> > +then:
> > +  properties:
> > +    interrupts: false
> > +
> >  examples:
> >    - |
> >      #include <dt-bindings/interrupt-controller/irq.h>
> > --
> > 2.47.3
> >

-- 
Thanks.
Binbin

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2025-12-30  2:32 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-12-23  6:42 [PATCH v1 0/2] RTC: Add Loongson-2K0300 support Binbin Zhou
2025-12-23  6:42 ` [PATCH v1 1/2] dt-binding: rtc: loongson: Document Loongson-2K0300 compatible Binbin Zhou
2025-12-30  2:15   ` Rob Herring
2025-12-30  2:31     ` Binbin Zhou
2025-12-23  6:42 ` [PATCH v1 2/2] rtc: loongson: Add Loongson-2K0300 support Binbin Zhou
2025-12-23  8:40   ` Huacai Chen
2025-12-23  9:06     ` Binbin Zhou
2025-12-23  9:09       ` Huacai Chen
2025-12-26 10:03 ` [PATCH v1 0/2] RTC: " Keguang Zhang

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox