From: Lee Jones <lee@kernel.org>
To: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Cc: "Nuno Sá" <noname.nuno@gmail.com>,
nuno.sa@analog.com, linux-gpio@vger.kernel.org,
linux-pwm@vger.kernel.org, devicetree@vger.kernel.org,
linux-input@vger.kernel.org, "Rob Herring" <robh@kernel.org>,
"Krzysztof Kozlowski" <krzk+dt@kernel.org>,
"Conor Dooley" <conor+dt@kernel.org>,
"Uwe Kleine-König" <ukleinek@kernel.org>,
"Linus Walleij" <linus.walleij@linaro.org>,
"Bartosz Golaszewski" <brgl@bgdev.pl>,
"Dmitry Torokhov" <dmitry.torokhov@gmail.com>,
"Liu Ying" <victor.liu@nxp.com>
Subject: Re: [PATCH v3 07/22] mfd: adp5585: refactor how regmap defaults are handled
Date: Tue, 13 May 2025 17:03:31 +0100 [thread overview]
Message-ID: <20250513160331.GR2936510@google.com> (raw)
In-Reply-To: <20250513153646.GE23592@pendragon.ideasonboard.com>
On Tue, 13 May 2025, Laurent Pinchart wrote:
> On Tue, May 13, 2025 at 04:32:39PM +0100, Nuno Sá wrote:
> > On Tue, 2025-05-13 at 16:00 +0100, Lee Jones wrote:
> > > On Mon, 12 May 2025, Nuno Sá via B4 Relay wrote:
> > >
> > > > From: Nuno Sá <nuno.sa@analog.com>
> > > >
> > > > The only thing changing between variants is the regmap default
> > > > registers. Hence, instead of having a regmap condig for every variant
> > > > (duplicating lots of fields), add a chip info type of structure with a
> > > > regmap id to identify which defaults to use and populate regmap_config
> > > > at runtime given a template plus the id. Also note that between
> > > > variants, the defaults can be the same which means the chip info
> > > > structure can be used in more than one compatible.
> > > >
> > > > This will also make it simpler adding new chips with more variants.
> > > >
> > > > Also note that the chip info structures are deliberately not const as
> > > > they will also contain lots of members that are the same between the
> > > > different devices variants and so we will fill those at runtime.
> > > >
> > > > Signed-off-by: Nuno Sá <nuno.sa@analog.com>
> > > > ---
> > > > drivers/mfd/adp5585.c | 94 +++++++++++++++++++++++++-----------------
> > > > ---
> > > > include/linux/mfd/adp5585.h | 11 ++++++
> > > > 2 files changed, 64 insertions(+), 41 deletions(-)
> > > >
> > > > diff --git a/drivers/mfd/adp5585.c b/drivers/mfd/adp5585.c
> > > > index
> > > > 19d4a0ab1bb4c261e82559630624059529765fbd..874aed7d7cfe052587720d899096c995c1
> > > > 9667af 100644
> > > > --- a/drivers/mfd/adp5585.c
> > > > +++ b/drivers/mfd/adp5585.c
> > > > @@ -81,41 +81,34 @@ static const u8
> > > > adp5585_regmap_defaults_04[ADP5585_MAX_REG + 1] = {
> > > > /* 0x38 */ 0x00, 0x00, 0x00, 0x00, 0x00,
> > > > };
> > > >
> > > > -enum adp5585_regmap_type {
> > > > - ADP5585_REGMAP_00,
> > > > - ADP5585_REGMAP_02,
> > > > - ADP5585_REGMAP_04,
> > > > +static const struct regmap_config adp5585_regmap_config_template = {
> > > > + .reg_bits = 8,
> > > > + .val_bits = 8,
> > > > + .max_register = ADP5585_MAX_REG,
> > > > + .volatile_table = &adp5585_volatile_regs,
> > > > + .cache_type = REGCACHE_MAPLE,
> > > > + .num_reg_defaults_raw = ADP5585_MAX_REG + 1,
> > > > };
> > > >
> > > > -static const struct regmap_config adp5585_regmap_configs[] = {
> > > > - [ADP5585_REGMAP_00] = {
> > > > - .reg_bits = 8,
> > > > - .val_bits = 8,
> > > > - .max_register = ADP5585_MAX_REG,
> > > > - .volatile_table = &adp5585_volatile_regs,
> > > > - .cache_type = REGCACHE_MAPLE,
> > > > - .reg_defaults_raw = adp5585_regmap_defaults_00,
> > > > - .num_reg_defaults_raw = sizeof(adp5585_regmap_defaults_00),
> > > > - },
> > > > - [ADP5585_REGMAP_02] = {
> > > > - .reg_bits = 8,
> > > > - .val_bits = 8,
> > > > - .max_register = ADP5585_MAX_REG,
> > > > - .volatile_table = &adp5585_volatile_regs,
> > > > - .cache_type = REGCACHE_MAPLE,
> > > > - .reg_defaults_raw = adp5585_regmap_defaults_02,
> > > > - .num_reg_defaults_raw = sizeof(adp5585_regmap_defaults_02),
> > > > - },
> > > > - [ADP5585_REGMAP_04] = {
> > > > - .reg_bits = 8,
> > > > - .val_bits = 8,
> > > > - .max_register = ADP5585_MAX_REG,
> > > > - .volatile_table = &adp5585_volatile_regs,
> > > > - .cache_type = REGCACHE_MAPLE,
> > > > - .reg_defaults_raw = adp5585_regmap_defaults_04,
> > > > - .num_reg_defaults_raw = sizeof(adp5585_regmap_defaults_04),
> > > > - },
> > > > -};
> > > > +static int adp5585_fill_regmap_config(const struct adp5585_dev *adp5585,
> > > > + struct regmap_config *regmap_config)
> > >
> > > I like the general idea. This is much more scaleable than before.
> > >
> > > > +{
> > > > + *regmap_config = adp5585_regmap_config_template;
> > > > +
> > > > + switch (adp5585->info->regmap_type) {
> > > > + case ADP5585_REGMAP_00:
> > > > + regmap_config->reg_defaults_raw =
> > > > adp5585_regmap_defaults_00;
> > > > + return 0;
> > > > + case ADP5585_REGMAP_02:
> > > > + regmap_config->reg_defaults_raw =
> > > > adp5585_regmap_defaults_02;
> > > > + return 0;
> > > > + case ADP5585_REGMAP_04:
> > > > + regmap_config->reg_defaults_raw =
> > > > adp5585_regmap_defaults_04;
> > >
> > > You could make this read a tiny bit nicer (as you do with the adp5585->info
> > > in a later patch) and make reg_defaults_raw a local variable.
> >
> > I'm probably missing your point but what would be the benefit? The info is done
> > like that because I wanted the pointer to be 'const'. Here I do not think the
> > same applies...
> >
> > >
> > > > + return 0;
> > > > + default:
> > > > + return -ENODEV;
> > > > + }
> > > > +}
> > > >
> > > > static int adp5585_parse_fw(struct device *dev, struct adp5585_dev
> > > > *adp5585,
> > > > struct mfd_cell **devs)
> > > > @@ -153,7 +146,7 @@ static void adp5585_osc_disable(void *data)
> > > >
> > > > static int adp5585_i2c_probe(struct i2c_client *i2c)
> > > > {
> > > > - const struct regmap_config *regmap_config;
> > > > + struct regmap_config regmap_config;
> > > > struct adp5585_dev *adp5585;
> > > > struct mfd_cell *devs;
> > > > unsigned int id;
> > > > @@ -165,8 +158,15 @@ static int adp5585_i2c_probe(struct i2c_client *i2c)
> > > >
> > > > i2c_set_clientdata(i2c, adp5585);
> > > >
> > > > - regmap_config = i2c_get_match_data(i2c);
> > > > - adp5585->regmap = devm_regmap_init_i2c(i2c, regmap_config);
> > > > + adp5585->info = i2c_get_match_data(i2c);
> > > > + if (!adp5585->info)
> > > > + return -ENODEV;
> > > > +
> > > > + ret = adp5585_fill_regmap_config(adp5585, ®map_config);
> > > > + if (ret)
> > > > + return ret;
> > > > +
> > > > + adp5585->regmap = devm_regmap_init_i2c(i2c, ®map_config);
> > > > if (IS_ERR(adp5585->regmap))
> > > > return dev_err_probe(&i2c->dev, PTR_ERR(adp5585->regmap),
> > > > "Failed to initialize register
> > > > map\n");
> > > > @@ -223,22 +223,34 @@ static int adp5585_resume(struct device *dev)
> > > >
> > > > static DEFINE_SIMPLE_DEV_PM_OPS(adp5585_pm, adp5585_suspend,
> > > > adp5585_resume);
> > > >
> > > > +static struct adp5585_info adp5585_info = {
> > > > + .regmap_type = ADP5585_REGMAP_00,
> > >
> > > Instead of providing this enum, then later another one (id) which is a
> > > subset of the same thing, why not pass just ADP5585_REGMAP_00, etc
> > > through the DT .data attribute then match on those? It will add a
> > > couple of lines to the switch(info->id) statement, but will save on a
> > > boat load of static structs and other complexity.
> > >
> > > For instance:
> > >
> > > switch (info->id) {
> > > case ADP5585_MAN_ID_VALUE:
> > >
> > > Would simply become:
> > >
> > > switch (info->id) {
> > > case ADP5585_REGMAP_00:
> > > case ADP5585_REGMAP_02:
> > > case ADP5585_REGMAP_04:
> > >
> > > And that's it.
> >
> > I get the general idea... We will also have to pack the regmap defaults into an
> > array so that we can easily reference it with 'info->id' which I don't like too
> > much tbh (but I do see that adp5585_fill_chip_configs() will become simpler) . I
> > guess I can also just move everything into the "main" struct as we will fill
> > everything during probe (no real reason for struct adp5585_info)
> >
> > Anyways, If you prefer the above I'm not going to argue against it...
> >
> > >
> > > > +};
> > > > +
> > > > +static struct adp5585_info adp5585_02_info = {
> > > > + .regmap_type = ADP5585_REGMAP_02,
> > > > +};
> > > > +
> > > > +static struct adp5585_info adp5585_04_info = {
> > > > + .regmap_type = ADP5585_REGMAP_04,
> > > > +};
> > > > +
> > > > static const struct of_device_id adp5585_of_match[] = {
> > > > {
> > > > .compatible = "adi,adp5585-00",
> > > > - .data = &adp5585_regmap_configs[ADP5585_REGMAP_00],
> > > > + .data = &adp5585_info,
> > >
> > > .data = ADP5585_REGMAP_00,
> >
> > I see, needs a cast but should work. I personally prefer valid pointers than
> > "encoding" integers in here. I know we can start the enum at 1 so that we can
> > still look for 0 for any possible issue but...
>
> I also prefer pointers to structures, but won't fight for it.
They can be nice to avoid any switch() matching, but here we have both
anyway so it improves very little.
--
Lee Jones [李琼斯]
next prev parent reply other threads:[~2025-05-13 16:03 UTC|newest]
Thread overview: 86+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-05-12 12:38 [PATCH v3 00/22] mfd: adp5585: support keymap events and drop legacy Input driver Nuno Sá
2025-05-12 12:38 ` Nuno Sá via B4 Relay
2025-05-12 12:38 ` [PATCH v3 01/22] dt-bindings: mfd: adp5585: ease on the required properties Nuno Sá
2025-05-12 12:38 ` Nuno Sá via B4 Relay
2025-05-12 12:38 ` [PATCH v3 02/22] mfd: adp5585: only add devices given in FW Nuno Sá
2025-05-12 12:38 ` Nuno Sá via B4 Relay
2025-05-13 14:34 ` Lee Jones
2025-05-13 15:02 ` Nuno Sá
2025-05-13 15:19 ` Laurent Pinchart
2025-05-13 15:37 ` Nuno Sá
2025-05-13 16:12 ` Lee Jones
2025-05-12 12:38 ` [PATCH v3 03/22] mfd: adp5585: enable oscilator during probe Nuno Sá
2025-05-12 12:38 ` Nuno Sá via B4 Relay
2025-05-13 14:26 ` Lee Jones
2025-05-13 14:52 ` Nuno Sá
2025-05-13 16:07 ` Lee Jones
2025-05-13 15:24 ` Laurent Pinchart
2025-05-13 15:38 ` Nuno Sá
2025-05-12 12:38 ` [PATCH v3 04/22] pwm: adp5585: don't control OSC_EN in the pwm driver Nuno Sá
2025-05-12 12:38 ` Nuno Sá via B4 Relay
2025-05-13 15:26 ` Laurent Pinchart
2025-05-13 15:39 ` Nuno Sá
2025-05-13 16:04 ` Lee Jones
2025-05-12 12:38 ` [PATCH v3 05/22] mfd: adp5585: make use of MFD_CELL_NAME() Nuno Sá
2025-05-12 12:38 ` Nuno Sá via B4 Relay
2025-05-13 14:39 ` Lee Jones
2025-05-13 14:50 ` Nuno Sá
2025-05-12 12:38 ` [PATCH v3 06/22] dt-bindings: mfd: adp5585: document adp5589 I/O expander Nuno Sá
2025-05-12 12:38 ` Nuno Sá via B4 Relay
2025-05-12 12:38 ` [PATCH v3 07/22] mfd: adp5585: refactor how regmap defaults are handled Nuno Sá
2025-05-12 12:38 ` Nuno Sá via B4 Relay
2025-05-13 15:00 ` Lee Jones
2025-05-13 15:02 ` Lee Jones
2025-05-13 15:32 ` Nuno Sá
2025-05-13 15:36 ` Laurent Pinchart
2025-05-13 16:03 ` Lee Jones [this message]
2025-05-13 15:35 ` Laurent Pinchart
2025-05-13 15:41 ` Nuno Sá
2025-05-12 12:39 ` [PATCH v3 08/22] mfd: adp5585: add support for adp5589 Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 09/22] mfd: adp5585: add a per chip reg struture Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 10/22] gpio: adp5585: add support for the adp5589 expander Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 11/22] pwm: adp5585: add support for adp5589 Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 12/22] dt-bindings: mfd: adp5585: add properties for input events Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 13/22] mfd: adp5585: add support for event handling Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-13 15:59 ` Lee Jones
2025-05-15 5:56 ` Nuno Sá
2025-05-15 6:14 ` Nuno Sá
2025-05-12 12:39 ` [PATCH v3 14/22] mfd: adp5585: support reset and unlock events Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-13 16:22 ` Lee Jones
2025-05-14 8:35 ` Laurent Pinchart
2025-05-14 8:46 ` Lee Jones
2025-05-15 5:46 ` Nuno Sá
2025-05-12 12:39 ` [PATCH v3 15/22] mfd: adp5585: add support for input devices Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 16/22] gpio: adp5585: support gpi events Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 17/22] Input: adp5585: Add Analog Devices ADP5585/89 support Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-19 22:29 ` Dmitry Torokhov
2025-05-20 8:32 ` Nuno Sá
2025-05-20 18:33 ` Dmitry Torokhov
2025-05-21 10:06 ` Nuno Sá
2025-05-12 12:39 ` [PATCH v3 18/22] Input: adp5589: remove the driver Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 19/22] mfd: adp5585: support getting vdd regulator Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 20/22] dt-bindings: mfd: adp5585: document reset gpio Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-12 12:39 ` [PATCH v3 21/22] mfd: adp5585: add support for a reset pin Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-13 16:26 ` Lee Jones
2025-05-15 5:39 ` Nuno Sá
2025-05-12 12:39 ` [PATCH v3 22/22] pwm: adp5585: make sure to include mod_devicetable.h Nuno Sá
2025-05-12 12:39 ` Nuno Sá via B4 Relay
2025-05-19 16:11 ` Uwe Kleine-König
2025-05-19 16:19 ` Nuno Sá
2025-05-14 8:25 ` [PATCH v3 00/22] mfd: adp5585: support keymap events and drop legacy Input driver Lee Jones
2025-05-14 11:04 ` Nuno Sá
2025-07-02 13:34 ` Lee Jones
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250513160331.GR2936510@google.com \
--to=lee@kernel.org \
--cc=brgl@bgdev.pl \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=dmitry.torokhov@gmail.com \
--cc=krzk+dt@kernel.org \
--cc=laurent.pinchart@ideasonboard.com \
--cc=linus.walleij@linaro.org \
--cc=linux-gpio@vger.kernel.org \
--cc=linux-input@vger.kernel.org \
--cc=linux-pwm@vger.kernel.org \
--cc=noname.nuno@gmail.com \
--cc=nuno.sa@analog.com \
--cc=robh@kernel.org \
--cc=ukleinek@kernel.org \
--cc=victor.liu@nxp.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.