[PATCH 1/3] mfd: support 88pm80x in 80x driver
Qiao Zhou
zhouqiao at marvell.com
Thu Jun 28 22:56:45 EDT 2012
On 06/28/2012 07:21 PM, Arnd Bergmann wrote:
> On Thursday 28 June 2012, Qiao Zhou wrote:
>> 88PM800 and 88PM805 are two discrete chips used for power management.
>> Hardware designer can use them together or only one of them according to
>> requirement.
>>
>
> This looks much better than the first version, great work!
>
> However, there are a few things that you have not addressed from my review
> and that you did not explain either. Most importantly, you said that you'd
> add support for DT based booting, which is not in this version.
>
> What platform is this driver for?
> - If it's for an existing platform that does not have DT support, please
> include the platform changes for that platform so we can see what gets
> done in there.
> - If it's for a new platform, you should not have any platform data in
> this patch, just device tree based probing because that platform will
> also have to use DT probing in order to get merged. The tree that
> carries such a platform out of the kernel can add back the platform
> data parsing, just don't submit it upstream with the main driver.
it's for a new platform as Haojian has commented. currently we can't
only support DT for verifying issue.
>
>> due to hardware design, there are some registers used by pm805, but actually
>> defined in pm800 chip. so pm805 needs to access pm800 register in some
>> occasion. A workaround is used in driver to solve such issue and would be
>> removed when it's fixed in latter new chip version.
>
> I don't see from the code what this is referring to. Can you be a little
> more specific? Ideally you would have one patch that adds the driver
> without this workaround, followed by a patch that just adds that workaround
> with an explanation why it's needed, and then you can later just revert
> that patch once it's no longer required.
would update and give details to explain.
>
>> All I2C operations are accessed by 80x-i2c driver, and register access is via
>> regmap interface.
>>
>> The benefit is that client drivers only need one kind of read/write API. I2C
>> and MFD driver can be shared in both 800 and 805.
>
> I'm not sure what the purpose of this split is. Usually you only separate out
> the i2c parts if the same driver has multiple host-side interfaces, e.g. i2c
> and spi. If your driver only has one of them, it's easier to just have one
> file. Using regmap however seems to be a good idea nonetheless.
>
> I would also suggest you consider splitting the driver into three separate
> parts after moving the i2c file into the core file:
>
> a) one "library" that contains the common code and exports symbols
> b) one driver for 805 that contains just the 805 specific parts and
> registers the i2c driver for 805
> c) one driver for 800 that contains just the 800 specific parts and
> registers the i2c driver for 800
>
> Does that sound reasonable?
>
> There is very little common that is actually part of the 88pm80x_common
> file, everything else is specific to just one of the variants. The only common
> parts I found are device_irq_init_80x and device_irq_exit_80x, and
> even for those I'm not sure if it wouldn't be easier to just
> have separate functions.
>
> The common parts seem to be mostly in your current _i2c.c file, so that could
> instead become the common file when you split 805 from 800. You basically
> just export the pm_ops and the probe/remove functions and let that be called
> from the individual drivers.
Arnd, the comments is inaccurate for I2C operations. actually all I2C
operations are handled by regmap in the new driver. and no more API
needs to be exported by 88pm80x-i2c driver. driver which needs to access
registers only uses uses regmap handle via dev_get_regmap, only i2c
client needed. actually there is no split in I2C operations. please let
me know if I miss your meaning.
in the 88pm80x_core.c, actually it only has five functions,
irq_init_80x, irq_exit_80x, dev_init_800, dev_init_805, dev_exit_80x.
there is indeed few common part. so I assume your meaning is that:
creating 88pm800_core.c and 88pm805_core.c separtely, which implement
irq_init, irq_exit, dev_init, dev_exit for its own chip. is that correct?
>
>> + if (pdata->pm80x_plat_config)
>> + pdata->pm80x_plat_config(chip, pdata);
>
> You should definitely remove these callbacks, as I pointed out in the
> initial review.
would remove it.
>
>> +int __devinit pm80x_device_init(struct pm80x_chip *chip,
>> + struct pm80x_platform_data *pdata)
>> +{
>> + int ret = 0;
>> +
>> + switch (chip->id) {
>> + case CHIP_PM800:
>> + ret = device_800_init(chip, chip->client, pdata);
>> + break;
>> + case CHIP_PM805:
>> + ret = device_805_init(chip, chip->client, pdata);
>> + break;
>> + default:
>> + dev_err(chip->dev, "%s incorrect chip id!\n", __func__);
>> + return -EINVAL;
>> + }
>
> It seems strange that you access the i2c_client in the common file,
> rather than just working with the regmap.
would remove it.
>
>
>> diff --git a/include/linux/mfd/88pm80x.h b/include/linux/mfd/88pm80x.h
>> new file mode 100644
>> index 0000000..9e2e11d
>> --- /dev/null
>
> A lot of the contents of this file should not really be globally visible.
> Most of the register definitions are just used by the common mfd driver,
> so I would put them in a header file in the mfd directory or (even better)
> just into the .c file that uses them.
yes, would category these registers. some registers which is used by
regulator/rtc/onkey/codec/headset det/MISC would be kept in this header
file, while others would be removed from globally visibility.
>
>
> Arnd
>
Arnd,
thanks for your review & good suggestions!
--
Best Regards
Qiao
More information about the linux-arm-kernel
mailing list