* [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables
@ 2023-08-20 8:20 Biju Das
2023-08-21 12:19 ` Lee Jones
` (2 more replies)
0 siblings, 3 replies; 6+ messages in thread
From: Biju Das @ 2023-08-20 8:20 UTC (permalink / raw)
To: Pavel Machek, Lee Jones
Cc: Biju Das, linux-leds, Geert Uytterhoeven, Andy Shevchenko,
linux-renesas-soc
Convert enum->pointer for data in the match tables, so that
device_get_match_data() can do match against OF/ACPI/I2C tables, once i2c
bus type match support added to it.
Replace enum->struct *pca955x_chipdefs for data in the match table.
Simplify the probe() by replacing device_get_match_data() and ID lookup
for retrieving data by i2c_get_match_data().
While at it, add const definition to pca955x_chipdefs[].
Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>
---
Note:
This patch is only compile tested.
---
drivers/leds/leds-pca955x.c | 45 +++++++++++++------------------------
1 file changed, 16 insertions(+), 29 deletions(-)
diff --git a/drivers/leds/leds-pca955x.c b/drivers/leds/leds-pca955x.c
index b10e1ef38db0..e28fd205678e 100644
--- a/drivers/leds/leds-pca955x.c
+++ b/drivers/leds/leds-pca955x.c
@@ -76,7 +76,7 @@ struct pca955x_chipdef {
int slv_addr_shift; /* Number of bits to ignore */
};
-static struct pca955x_chipdef pca955x_chipdefs[] = {
+static const struct pca955x_chipdef pca955x_chipdefs[] = {
[pca9550] = {
.bits = 2,
.slv_addr = /* 110000x */ 0x60,
@@ -105,11 +105,11 @@ static struct pca955x_chipdef pca955x_chipdefs[] = {
};
static const struct i2c_device_id pca955x_id[] = {
- { "pca9550", pca9550 },
- { "pca9551", pca9551 },
- { "pca9552", pca9552 },
- { "ibm-pca9552", ibm_pca9552 },
- { "pca9553", pca9553 },
+ { "pca9550", (kernel_ulong_t)&pca955x_chipdefs[pca9550] },
+ { "pca9551", (kernel_ulong_t)&pca955x_chipdefs[pca9551] },
+ { "pca9552", (kernel_ulong_t)&pca955x_chipdefs[pca9552] },
+ { "ibm-pca9552", (kernel_ulong_t)&pca955x_chipdefs[ibm_pca9552] },
+ { "pca9553", (kernel_ulong_t)&pca955x_chipdefs[pca9553] },
{ }
};
MODULE_DEVICE_TABLE(i2c, pca955x_id);
@@ -458,11 +458,11 @@ pca955x_get_pdata(struct i2c_client *client, struct pca955x_chipdef *chip)
}
static const struct of_device_id of_pca955x_match[] = {
- { .compatible = "nxp,pca9550", .data = (void *)pca9550 },
- { .compatible = "nxp,pca9551", .data = (void *)pca9551 },
- { .compatible = "nxp,pca9552", .data = (void *)pca9552 },
- { .compatible = "ibm,pca9552", .data = (void *)ibm_pca9552 },
- { .compatible = "nxp,pca9553", .data = (void *)pca9553 },
+ { .compatible = "nxp,pca9550", .data = &pca955x_chipdefs[pca9550] },
+ { .compatible = "nxp,pca9551", .data = &pca955x_chipdefs[pca9551] },
+ { .compatible = "nxp,pca9552", .data = &pca955x_chipdefs[pca9552] },
+ { .compatible = "ibm,pca9552", .data = &pca955x_chipdefs[ibm_pca9552] },
+ { .compatible = "nxp,pca9553", .data = &pca955x_chipdefs[pca9553] },
{},
};
MODULE_DEVICE_TABLE(of, of_pca955x_match);
@@ -471,7 +471,7 @@ static int pca955x_probe(struct i2c_client *client)
{
struct pca955x *pca955x;
struct pca955x_led *pca955x_led;
- struct pca955x_chipdef *chip;
+ const struct pca955x_chipdef *chip;
struct led_classdev *led;
struct led_init_data init_data;
struct i2c_adapter *adapter;
@@ -480,24 +480,11 @@ static int pca955x_probe(struct i2c_client *client)
bool set_default_label = false;
bool keep_pwm = false;
char default_label[8];
- enum pca955x_type chip_type;
- const void *md = device_get_match_data(&client->dev);
-
- if (md) {
- chip_type = (enum pca955x_type)md;
- } else {
- const struct i2c_device_id *id = i2c_match_id(pca955x_id,
- client);
-
- if (id) {
- chip_type = (enum pca955x_type)id->driver_data;
- } else {
- dev_err(&client->dev, "unknown chip\n");
- return -ENODEV;
- }
- }
- chip = &pca955x_chipdefs[chip_type];
+ chip = i2c_get_match_data(&client->dev);
+ if (!chip)
+ return dev_err_probe(&client->dev, -ENODEV, "unknown chip\n");
+
adapter = client->adapter;
pdata = dev_get_platdata(&client->dev);
if (!pdata) {
--
2.25.1
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables
2023-08-20 8:20 [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables Biju Das
@ 2023-08-21 12:19 ` Lee Jones
2023-08-21 12:25 ` Biju Das
2023-09-19 15:00 ` Lee Jones
2023-09-28 13:44 ` (subset) " Lee Jones
2 siblings, 1 reply; 6+ messages in thread
From: Lee Jones @ 2023-08-21 12:19 UTC (permalink / raw)
To: Biju Das
Cc: Pavel Machek, linux-leds, Geert Uytterhoeven, Andy Shevchenko,
linux-renesas-soc
On Sun, 20 Aug 2023, Biju Das wrote:
> Convert enum->pointer for data in the match tables, so that
> device_get_match_data() can do match against OF/ACPI/I2C tables, once i2c
> bus type match support added to it.
>
> Replace enum->struct *pca955x_chipdefs for data in the match table.
> Simplify the probe() by replacing device_get_match_data() and ID lookup
> for retrieving data by i2c_get_match_data().
>
> While at it, add const definition to pca955x_chipdefs[].
>
> Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>
> ---
> Note:
> This patch is only compile tested.
> ---
> drivers/leds/leds-pca955x.c | 45 +++++++++++++------------------------
> 1 file changed, 16 insertions(+), 29 deletions(-)
This is too big of a change to be added this late in the cycle.
Especially since this is only compile tested.
Pushing review until after v6.5 is out.
--
Lee Jones [李琼斯]
^ permalink raw reply [flat|nested] 6+ messages in thread
* RE: [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables
2023-08-21 12:19 ` Lee Jones
@ 2023-08-21 12:25 ` Biju Das
0 siblings, 0 replies; 6+ messages in thread
From: Biju Das @ 2023-08-21 12:25 UTC (permalink / raw)
To: Lee Jones
Cc: Pavel Machek, linux-leds@vger.kernel.org, Geert Uytterhoeven,
Andy Shevchenko, linux-renesas-soc@vger.kernel.org
Hi Lee Jones,
> Subject: Re: [PATCH] leds: pca955x: Convert enum->pointer for data in the
> match tables
>
> On Sun, 20 Aug 2023, Biju Das wrote:
>
> > Convert enum->pointer for data in the match tables, so that
> > device_get_match_data() can do match against OF/ACPI/I2C tables, once
> > i2c bus type match support added to it.
> >
> > Replace enum->struct *pca955x_chipdefs for data in the match table.
> > Simplify the probe() by replacing device_get_match_data() and ID
> > lookup for retrieving data by i2c_get_match_data().
> >
> > While at it, add const definition to pca955x_chipdefs[].
> >
> > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>
> > ---
> > Note:
> > This patch is only compile tested.
> > ---
> > drivers/leds/leds-pca955x.c | 45
> > +++++++++++++------------------------
> > 1 file changed, 16 insertions(+), 29 deletions(-)
>
> This is too big of a change to be added this late in the cycle.
>
> Especially since this is only compile tested.
>
> Pushing review until after v6.5 is out.
Fine for me.
Cheers,
Biju
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables
2023-08-20 8:20 [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables Biju Das
2023-08-21 12:19 ` Lee Jones
@ 2023-09-19 15:00 ` Lee Jones
2023-09-20 6:20 ` Biju Das
2023-09-28 13:44 ` (subset) " Lee Jones
2 siblings, 1 reply; 6+ messages in thread
From: Lee Jones @ 2023-09-19 15:00 UTC (permalink / raw)
To: Biju Das
Cc: Pavel Machek, linux-leds, Geert Uytterhoeven, Andy Shevchenko,
linux-renesas-soc
On Sun, 20 Aug 2023, Biju Das wrote:
> Convert enum->pointer for data in the match tables, so that
> device_get_match_data() can do match against OF/ACPI/I2C tables, once i2c
> bus type match support added to it.
>
> Replace enum->struct *pca955x_chipdefs for data in the match table.
> Simplify the probe() by replacing device_get_match_data() and ID lookup
> for retrieving data by i2c_get_match_data().
>
> While at it, add const definition to pca955x_chipdefs[].
>
> Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>
> ---
> Note:
> This patch is only compile tested.
> ---
> drivers/leds/leds-pca955x.c | 45 +++++++++++++------------------------
> 1 file changed, 16 insertions(+), 29 deletions(-)
Reviewed-by: Lee Jones <lee@kernel.org>
Patch doesn't apply. Please rebase, add the tag above and resubmit.
--
Lee Jones [李琼斯]
^ permalink raw reply [flat|nested] 6+ messages in thread
* RE: [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables
2023-09-19 15:00 ` Lee Jones
@ 2023-09-20 6:20 ` Biju Das
0 siblings, 0 replies; 6+ messages in thread
From: Biju Das @ 2023-09-20 6:20 UTC (permalink / raw)
To: Lee Jones
Cc: Pavel Machek, linux-leds@vger.kernel.org, Geert Uytterhoeven,
Andy Shevchenko, linux-renesas-soc@vger.kernel.org
Hi Lee Jones,
Thanks for the feedback.
> Subject: Re: [PATCH] leds: pca955x: Convert enum->pointer for data in the
> match tables
>
> On Sun, 20 Aug 2023, Biju Das wrote:
>
> > Convert enum->pointer for data in the match tables, so that
> > device_get_match_data() can do match against OF/ACPI/I2C tables, once
> > i2c bus type match support added to it.
> >
> > Replace enum->struct *pca955x_chipdefs for data in the match table.
> > Simplify the probe() by replacing device_get_match_data() and ID
> > lookup for retrieving data by i2c_get_match_data().
> >
> > While at it, add const definition to pca955x_chipdefs[].
> >
> > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>
> > ---
> > Note:
> > This patch is only compile tested.
> > ---
> > drivers/leds/leds-pca955x.c | 45
> > +++++++++++++------------------------
> > 1 file changed, 16 insertions(+), 29 deletions(-)
>
> Reviewed-by: Lee Jones <lee@kernel.org>
>
> Patch doesn't apply. Please rebase, add the tag above and resubmit.
OK will rebase and resend with Rb tag.
Cheers,
Biju
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: (subset) [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables
2023-08-20 8:20 [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables Biju Das
2023-08-21 12:19 ` Lee Jones
2023-09-19 15:00 ` Lee Jones
@ 2023-09-28 13:44 ` Lee Jones
2 siblings, 0 replies; 6+ messages in thread
From: Lee Jones @ 2023-09-28 13:44 UTC (permalink / raw)
To: Pavel Machek, Lee Jones, Biju Das
Cc: linux-leds, Geert Uytterhoeven, Andy Shevchenko,
linux-renesas-soc
On Sun, 20 Aug 2023 09:20:05 +0100, Biju Das wrote:
> Convert enum->pointer for data in the match tables, so that
> device_get_match_data() can do match against OF/ACPI/I2C tables, once i2c
> bus type match support added to it.
>
> Replace enum->struct *pca955x_chipdefs for data in the match table.
> Simplify the probe() by replacing device_get_match_data() and ID lookup
> for retrieving data by i2c_get_match_data().
>
> [...]
Applied, thanks!
[1/1] leds: pca955x: Convert enum->pointer for data in the match tables
commit: 734adca71b2ccc6df12c244037e0b284aab7cf58
--
Lee Jones [李琼斯]
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2023-09-28 13:44 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-08-20 8:20 [PATCH] leds: pca955x: Convert enum->pointer for data in the match tables Biju Das
2023-08-21 12:19 ` Lee Jones
2023-08-21 12:25 ` Biju Das
2023-09-19 15:00 ` Lee Jones
2023-09-20 6:20 ` Biju Das
2023-09-28 13:44 ` (subset) " Lee Jones
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox