[PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ

Matti Vaittinen posted 1 patch 2 months ago
drivers/mfd/rohm-bd71828.c | 12 ++++++------
drivers/rtc/rtc-bd70528.c  |  5 +----
2 files changed, 7 insertions(+), 10 deletions(-)
[PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ
Posted by Matti Vaittinen 2 months ago
A few ROHM PMICs have an RTC block which can be controlled by the
rtc-bd70528 driver. The RTC driver needs the alarm interrupt information
from the parent MFD driver. The MFD driver provides the interrupt
information as a set of named interrupts, where the name is of form:
<PMIC model>-rtc-alm-<x>, where x is an alarm block number.

From the RTC driver point of view it is irrelevant what the PMIC name
is. It is sufficient to know this is alarm interrupt for a block X. The
PMIC model information is carried to RTC via the platform device ID.
Hence, having the PMIC model in the interrupt name is only making things
more complex because the RTC driver needs to request differently named
interrupts on different PMICs, making code unnecessary complicated.

Simplify this slightly by always using the RTC driver name 'bd70528' as
the prefix for alarm interrupts, no matter what the exact PMIC model is,
and always request the alarm interrupts of same name no matter what the
PMIC model is.

Signed-off-by: Matti Vaittinen <mazziesaccount@gmail.com>

---
This contains both the RTC and MFD changes in order to not break the
functionality between commits to different subsystems.

Changes are based to stuff being merged in for v6.12-rc1. I can rebase
and re-spin when 6.12-rc1 is out if needed.
---
 drivers/mfd/rohm-bd71828.c | 12 ++++++------
 drivers/rtc/rtc-bd70528.c  |  5 +----
 2 files changed, 7 insertions(+), 10 deletions(-)

diff --git a/drivers/mfd/rohm-bd71828.c b/drivers/mfd/rohm-bd71828.c
index 39f7514aa3d8..738d8b3b9ffe 100644
--- a/drivers/mfd/rohm-bd71828.c
+++ b/drivers/mfd/rohm-bd71828.c
@@ -32,15 +32,15 @@ static struct gpio_keys_platform_data bd71828_powerkey_data = {
 };
 
 static const struct resource bd71815_rtc_irqs[] = {
-	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC0, "bd71815-rtc-alm-0"),
-	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC1, "bd71815-rtc-alm-1"),
-	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC2, "bd71815-rtc-alm-2"),
+	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC0, "bd70528-rtc-alm-0"),
+	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC1, "bd70528-rtc-alm-1"),
+	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC2, "bd70528-rtc-alm-2"),
 };
 
 static const struct resource bd71828_rtc_irqs[] = {
-	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC0, "bd71828-rtc-alm-0"),
-	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC1, "bd71828-rtc-alm-1"),
-	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC2, "bd71828-rtc-alm-2"),
+	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC0, "bd70528-rtc-alm-0"),
+	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC1, "bd70528-rtc-alm-1"),
+	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC2, "bd70528-rtc-alm-2"),
 };
 
 static struct resource bd71815_power_irqs[] = {
diff --git a/drivers/rtc/rtc-bd70528.c b/drivers/rtc/rtc-bd70528.c
index 59b627fc1ecf..954ac4ef53e8 100644
--- a/drivers/rtc/rtc-bd70528.c
+++ b/drivers/rtc/rtc-bd70528.c
@@ -236,7 +236,6 @@ static int bd70528_probe(struct platform_device *pdev)
 {
 	struct bd70528_rtc *bd_rtc;
 	const struct rtc_class_ops *rtc_ops;
-	const char *irq_name;
 	int ret;
 	struct rtc_device *rtc;
 	int irq;
@@ -259,7 +258,6 @@ static int bd70528_probe(struct platform_device *pdev)
 
 	switch (chip) {
 	case ROHM_CHIP_TYPE_BD71815:
-		irq_name = "bd71815-rtc-alm-0";
 		bd_rtc->reg_time_start = BD71815_REG_RTC_START;
 
 		/*
@@ -276,7 +274,6 @@ static int bd70528_probe(struct platform_device *pdev)
 		hour_reg = BD71815_REG_HOUR;
 		break;
 	case ROHM_CHIP_TYPE_BD71828:
-		irq_name = "bd71828-rtc-alm-0";
 		bd_rtc->reg_time_start = BD71828_REG_RTC_START;
 		bd_rtc->bd718xx_alm_block_start = BD71828_REG_RTC_ALM_START;
 		hour_reg = BD71828_REG_RTC_HOUR;
@@ -286,7 +283,7 @@ static int bd70528_probe(struct platform_device *pdev)
 		return -ENOENT;
 	}
 
-	irq = platform_get_irq_byname(pdev, irq_name);
+	irq = platform_get_irq_byname(pdev, "bd70528-rtc-alm-0");
 
 	if (irq < 0)
 		return irq;

base-commit: abf2050f51fdca0fd146388f83cddd95a57a008d
-- 
2.45.2


-- 
Matti Vaittinen, Linux device drivers
ROHM Semiconductors, Finland SWDC
Kiviharjunlenkki 1E
90220 OULU
FINLAND

~~~ "I don't think so," said Rene Descartes. Just then he vanished ~~~
Simon says - in Latin please.
~~~ "non cogito me" dixit Rene Descarte, deinde evanescavit ~~~
Thanks to Simon Glass for the translation =] 
Re: (subset) [PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ
Posted by Lee Jones 3 weeks, 6 days ago
On Thu, 26 Sep 2024 15:01:13 +0300, Matti Vaittinen wrote:
> A few ROHM PMICs have an RTC block which can be controlled by the
> rtc-bd70528 driver. The RTC driver needs the alarm interrupt information
> from the parent MFD driver. The MFD driver provides the interrupt
> information as a set of named interrupts, where the name is of form:
> <PMIC model>-rtc-alm-<x>, where x is an alarm block number.
> 
> >From the RTC driver point of view it is irrelevant what the PMIC name
> is. It is sufficient to know this is alarm interrupt for a block X. The
> PMIC model information is carried to RTC via the platform device ID.
> Hence, having the PMIC model in the interrupt name is only making things
> more complex because the RTC driver needs to request differently named
> interrupts on different PMICs, making code unnecessary complicated.
> 
> [...]

Applied, thanks!

[1/1] mfd: rtc: bd7xxxx Drop IC name from IRQ
      commit: 9b15062cc05dbfec8092f5f08ac734fd29ed7b5a

--
Lee Jones [李琼斯]

Re: [PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ
Posted by Alexandre Belloni 4 weeks ago
On 26/09/2024 15:01:13+0300, Matti Vaittinen wrote:
> A few ROHM PMICs have an RTC block which can be controlled by the
> rtc-bd70528 driver. The RTC driver needs the alarm interrupt information
> from the parent MFD driver. The MFD driver provides the interrupt
> information as a set of named interrupts, where the name is of form:
> <PMIC model>-rtc-alm-<x>, where x is an alarm block number.
> 
> From the RTC driver point of view it is irrelevant what the PMIC name
> is. It is sufficient to know this is alarm interrupt for a block X. The
> PMIC model information is carried to RTC via the platform device ID.
> Hence, having the PMIC model in the interrupt name is only making things
> more complex because the RTC driver needs to request differently named
> interrupts on different PMICs, making code unnecessary complicated.
> 
> Simplify this slightly by always using the RTC driver name 'bd70528' as
> the prefix for alarm interrupts, no matter what the exact PMIC model is,
> and always request the alarm interrupts of same name no matter what the
> PMIC model is.
> 
> Signed-off-by: Matti Vaittinen <mazziesaccount@gmail.com>
Acked-by: Alexandre Belloni <alexandre.belloni@bootlin.com>

> 
> ---
> This contains both the RTC and MFD changes in order to not break the
> functionality between commits to different subsystems.
> 
> Changes are based to stuff being merged in for v6.12-rc1. I can rebase
> and re-spin when 6.12-rc1 is out if needed.
> ---
>  drivers/mfd/rohm-bd71828.c | 12 ++++++------
>  drivers/rtc/rtc-bd70528.c  |  5 +----
>  2 files changed, 7 insertions(+), 10 deletions(-)
> 
> diff --git a/drivers/mfd/rohm-bd71828.c b/drivers/mfd/rohm-bd71828.c
> index 39f7514aa3d8..738d8b3b9ffe 100644
> --- a/drivers/mfd/rohm-bd71828.c
> +++ b/drivers/mfd/rohm-bd71828.c
> @@ -32,15 +32,15 @@ static struct gpio_keys_platform_data bd71828_powerkey_data = {
>  };
>  
>  static const struct resource bd71815_rtc_irqs[] = {
> -	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC0, "bd71815-rtc-alm-0"),
> -	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC1, "bd71815-rtc-alm-1"),
> -	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC2, "bd71815-rtc-alm-2"),
> +	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC0, "bd70528-rtc-alm-0"),
> +	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC1, "bd70528-rtc-alm-1"),
> +	DEFINE_RES_IRQ_NAMED(BD71815_INT_RTC2, "bd70528-rtc-alm-2"),
>  };
>  
>  static const struct resource bd71828_rtc_irqs[] = {
> -	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC0, "bd71828-rtc-alm-0"),
> -	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC1, "bd71828-rtc-alm-1"),
> -	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC2, "bd71828-rtc-alm-2"),
> +	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC0, "bd70528-rtc-alm-0"),
> +	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC1, "bd70528-rtc-alm-1"),
> +	DEFINE_RES_IRQ_NAMED(BD71828_INT_RTC2, "bd70528-rtc-alm-2"),
>  };
>  
>  static struct resource bd71815_power_irqs[] = {
> diff --git a/drivers/rtc/rtc-bd70528.c b/drivers/rtc/rtc-bd70528.c
> index 59b627fc1ecf..954ac4ef53e8 100644
> --- a/drivers/rtc/rtc-bd70528.c
> +++ b/drivers/rtc/rtc-bd70528.c
> @@ -236,7 +236,6 @@ static int bd70528_probe(struct platform_device *pdev)
>  {
>  	struct bd70528_rtc *bd_rtc;
>  	const struct rtc_class_ops *rtc_ops;
> -	const char *irq_name;
>  	int ret;
>  	struct rtc_device *rtc;
>  	int irq;
> @@ -259,7 +258,6 @@ static int bd70528_probe(struct platform_device *pdev)
>  
>  	switch (chip) {
>  	case ROHM_CHIP_TYPE_BD71815:
> -		irq_name = "bd71815-rtc-alm-0";
>  		bd_rtc->reg_time_start = BD71815_REG_RTC_START;
>  
>  		/*
> @@ -276,7 +274,6 @@ static int bd70528_probe(struct platform_device *pdev)
>  		hour_reg = BD71815_REG_HOUR;
>  		break;
>  	case ROHM_CHIP_TYPE_BD71828:
> -		irq_name = "bd71828-rtc-alm-0";
>  		bd_rtc->reg_time_start = BD71828_REG_RTC_START;
>  		bd_rtc->bd718xx_alm_block_start = BD71828_REG_RTC_ALM_START;
>  		hour_reg = BD71828_REG_RTC_HOUR;
> @@ -286,7 +283,7 @@ static int bd70528_probe(struct platform_device *pdev)
>  		return -ENOENT;
>  	}
>  
> -	irq = platform_get_irq_byname(pdev, irq_name);
> +	irq = platform_get_irq_byname(pdev, "bd70528-rtc-alm-0");
>  
>  	if (irq < 0)
>  		return irq;
> 
> base-commit: abf2050f51fdca0fd146388f83cddd95a57a008d
> -- 
> 2.45.2
> 
> 
> -- 
> Matti Vaittinen, Linux device drivers
> ROHM Semiconductors, Finland SWDC
> Kiviharjunlenkki 1E
> 90220 OULU
> FINLAND
> 
> ~~~ "I don't think so," said Rene Descartes. Just then he vanished ~~~
> Simon says - in Latin please.
> ~~~ "non cogito me" dixit Rene Descarte, deinde evanescavit ~~~
> Thanks to Simon Glass for the translation =] 



-- 
Alexandre Belloni, co-owner and COO, Bootlin
Embedded Linux and Kernel engineering
https://bootlin.com
Re: (subset) [PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ
Posted by Lee Jones 1 month, 2 weeks ago
On Thu, 26 Sep 2024 15:01:13 +0300, Matti Vaittinen wrote:
> A few ROHM PMICs have an RTC block which can be controlled by the
> rtc-bd70528 driver. The RTC driver needs the alarm interrupt information
> from the parent MFD driver. The MFD driver provides the interrupt
> information as a set of named interrupts, where the name is of form:
> <PMIC model>-rtc-alm-<x>, where x is an alarm block number.
> 
> >From the RTC driver point of view it is irrelevant what the PMIC name
> is. It is sufficient to know this is alarm interrupt for a block X. The
> PMIC model information is carried to RTC via the platform device ID.
> Hence, having the PMIC model in the interrupt name is only making things
> more complex because the RTC driver needs to request differently named
> interrupts on different PMICs, making code unnecessary complicated.
> 
> [...]

Applied, thanks!

[1/1] mfd: rtc: bd7xxxx Drop IC name from IRQ
      commit: cd49b605779b4fea8224650eeba70b258c5cc8cc

--
Lee Jones [李琼斯]

Re: (subset) [PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ
Posted by Matti Vaittinen 1 month, 2 weeks ago
On 09/10/2024 17:29, Lee Jones wrote:
> On Thu, 26 Sep 2024 15:01:13 +0300, Matti Vaittinen wrote:
>> A few ROHM PMICs have an RTC block which can be controlled by the
>> rtc-bd70528 driver. The RTC driver needs the alarm interrupt information
>> from the parent MFD driver. The MFD driver provides the interrupt
>> information as a set of named interrupts, where the name is of form:
>> <PMIC model>-rtc-alm-<x>, where x is an alarm block number.
>>
>> >From the RTC driver point of view it is irrelevant what the PMIC name
>> is. It is sufficient to know this is alarm interrupt for a block X. The
>> PMIC model information is carried to RTC via the platform device ID.
>> Hence, having the PMIC model in the interrupt name is only making things
>> more complex because the RTC driver needs to request differently named
>> interrupts on different PMICs, making code unnecessary complicated.
>>
>> [...]
> 
> Applied, thanks!
> 
> [1/1] mfd: rtc: bd7xxxx Drop IC name from IRQ
>        commit: cd49b605779b4fea8224650eeba70b258c5cc8cc

Hello Lee, Alexandre,

Nothing pleases me more than having this quickly merged but...
... I don't think I saw ack from Alexandre yet. Furthermore, the 
(subset) makes me wonder because I sent RTC and MFD changes in a single 
patch - which might've been a mistake...

I tried finding the cd49b605779b4fea8224650eeba70b258c5cc8cc from MFD 
tree and failed. Hence I'm a bit unsure where we are going.

Yours,
	-- Matti
Re: (subset) [PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ
Posted by Lee Jones 1 month, 2 weeks ago
On Thu, 10 Oct 2024, Matti Vaittinen wrote:

> On 09/10/2024 17:29, Lee Jones wrote:
> > On Thu, 26 Sep 2024 15:01:13 +0300, Matti Vaittinen wrote:
> > > A few ROHM PMICs have an RTC block which can be controlled by the
> > > rtc-bd70528 driver. The RTC driver needs the alarm interrupt information
> > > from the parent MFD driver. The MFD driver provides the interrupt
> > > information as a set of named interrupts, where the name is of form:
> > > <PMIC model>-rtc-alm-<x>, where x is an alarm block number.
> > > 
> > > >From the RTC driver point of view it is irrelevant what the PMIC name
> > > is. It is sufficient to know this is alarm interrupt for a block X. The
> > > PMIC model information is carried to RTC via the platform device ID.
> > > Hence, having the PMIC model in the interrupt name is only making things
> > > more complex because the RTC driver needs to request differently named
> > > interrupts on different PMICs, making code unnecessary complicated.
> > > 
> > > [...]
> > 
> > Applied, thanks!
> > 
> > [1/1] mfd: rtc: bd7xxxx Drop IC name from IRQ
> >        commit: cd49b605779b4fea8224650eeba70b258c5cc8cc
> 
> Hello Lee, Alexandre,
> 
> Nothing pleases me more than having this quickly merged but...
> ... I don't think I saw ack from Alexandre yet. Furthermore, the (subset)
> makes me wonder because I sent RTC and MFD changes in a single patch - which
> might've been a mistake...
> 
> I tried finding the cd49b605779b4fea8224650eeba70b258c5cc8cc from MFD tree
> and failed. Hence I'm a bit unsure where we are going.

Applying this was a key-binding mistake.

This was my real intention:

  https://lore.kernel.org/all/20241009134416.GJ276481@google.com/

-- 
Lee Jones [李琼斯]
Re: (subset) [PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ
Posted by Lee Jones 1 month, 2 weeks ago
On Thu, 10 Oct 2024, Lee Jones wrote:

> On Thu, 10 Oct 2024, Matti Vaittinen wrote:
> 
> > On 09/10/2024 17:29, Lee Jones wrote:
> > > On Thu, 26 Sep 2024 15:01:13 +0300, Matti Vaittinen wrote:
> > > > A few ROHM PMICs have an RTC block which can be controlled by the
> > > > rtc-bd70528 driver. The RTC driver needs the alarm interrupt information
> > > > from the parent MFD driver. The MFD driver provides the interrupt
> > > > information as a set of named interrupts, where the name is of form:
> > > > <PMIC model>-rtc-alm-<x>, where x is an alarm block number.
> > > > 
> > > > >From the RTC driver point of view it is irrelevant what the PMIC name
> > > > is. It is sufficient to know this is alarm interrupt for a block X. The
> > > > PMIC model information is carried to RTC via the platform device ID.
> > > > Hence, having the PMIC model in the interrupt name is only making things
> > > > more complex because the RTC driver needs to request differently named
> > > > interrupts on different PMICs, making code unnecessary complicated.
> > > > 
> > > > [...]
> > > 
> > > Applied, thanks!

Unapplied.

-- 
Lee Jones [李琼斯]
Re: [PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ
Posted by Lee Jones 1 month, 2 weeks ago
On Thu, 26 Sep 2024, Matti Vaittinen wrote:

> A few ROHM PMICs have an RTC block which can be controlled by the
> rtc-bd70528 driver. The RTC driver needs the alarm interrupt information
> from the parent MFD driver. The MFD driver provides the interrupt
> information as a set of named interrupts, where the name is of form:
> <PMIC model>-rtc-alm-<x>, where x is an alarm block number.
> 
> From the RTC driver point of view it is irrelevant what the PMIC name
> is. It is sufficient to know this is alarm interrupt for a block X. The
> PMIC model information is carried to RTC via the platform device ID.
> Hence, having the PMIC model in the interrupt name is only making things
> more complex because the RTC driver needs to request differently named
> interrupts on different PMICs, making code unnecessary complicated.
> 
> Simplify this slightly by always using the RTC driver name 'bd70528' as
> the prefix for alarm interrupts, no matter what the exact PMIC model is,
> and always request the alarm interrupts of same name no matter what the
> PMIC model is.
> 
> Signed-off-by: Matti Vaittinen <mazziesaccount@gmail.com>
> 
> ---
> This contains both the RTC and MFD changes in order to not break the
> functionality between commits to different subsystems.

I can take it with an RTC Ack and an indication whether an immutable
branch should be created and shared.

-- 
Lee Jones [李琼斯]
Re: [PATCH] mfd: rtc: bd7xxxx Drop IC name from IRQ
Posted by Lee Jones 4 weeks ago
On Wed, 09 Oct 2024, Lee Jones wrote:

> On Thu, 26 Sep 2024, Matti Vaittinen wrote:
> 
> > A few ROHM PMICs have an RTC block which can be controlled by the
> > rtc-bd70528 driver. The RTC driver needs the alarm interrupt information
> > from the parent MFD driver. The MFD driver provides the interrupt
> > information as a set of named interrupts, where the name is of form:
> > <PMIC model>-rtc-alm-<x>, where x is an alarm block number.
> > 
> > From the RTC driver point of view it is irrelevant what the PMIC name
> > is. It is sufficient to know this is alarm interrupt for a block X. The
> > PMIC model information is carried to RTC via the platform device ID.
> > Hence, having the PMIC model in the interrupt name is only making things
> > more complex because the RTC driver needs to request differently named
> > interrupts on different PMICs, making code unnecessary complicated.
> > 
> > Simplify this slightly by always using the RTC driver name 'bd70528' as
> > the prefix for alarm interrupts, no matter what the exact PMIC model is,
> > and always request the alarm interrupts of same name no matter what the
> > PMIC model is.
> > 
> > Signed-off-by: Matti Vaittinen <mazziesaccount@gmail.com>
> > 
> > ---
> > This contains both the RTC and MFD changes in order to not break the
> > functionality between commits to different subsystems.
> 
> I can take it with an RTC Ack and an indication whether an immutable
> branch should be created and shared.

I fear this may have fallen from Alexandre's queue.

Please submit as a RESEND.

-- 
Lee Jones [李琼斯]