On pią, 2015-01-23 at 20:10 +0900, Beomho Seo wrote: > On 01/23/2015 04:16 PM, Krzysztof Kozlowski wrote: > > On pią, 2015-01-23 at 15:41 +0900, Beomho Seo wrote: > >> On 01/23/2015 03:32 PM, Krzysztof Kozlowski wrote: > >>> 2015-01-23 6:02 GMT+01:00 Jaewon Kim <jaewon02.kim@xxxxxxxxxxx>: > >>>> This patch adds MAX77843 core/irq driver to support PMIC, > >>>> MUIC(Micro USB Interface Controller), Charger, Fuel Gauge, > >>>> LED and Haptic device. > >>>> > >>>> Cc: Lee Jones <lee.jones@xxxxxxxxxx> > >>>> Signed-off-by: Beomho Seo <beomho.seo@xxxxxxxxxxx> > >>>> Signed-off-by: Jaewon Kim <jaewon02.kim@xxxxxxxxxxx> > >>>> --- > >>>> drivers/mfd/Kconfig | 14 ++ > >>>> drivers/mfd/Makefile | 1 + > >>>> drivers/mfd/max77843.c | 241 ++++++++++++++++++++ > >>>> include/linux/mfd/max77843-private.h | 410 ++++++++++++++++++++++++++++++++++ > >>>> 4 files changed, 666 insertions(+) > >>>> create mode 100644 drivers/mfd/max77843.c > >>>> create mode 100644 include/linux/mfd/max77843-private.h > >>>> > >>>> diff --git a/drivers/mfd/Kconfig b/drivers/mfd/Kconfig > >>>> index 2e6b731..0c67c79 100644 > >>>> --- a/drivers/mfd/Kconfig > >>>> +++ b/drivers/mfd/Kconfig > >>>> @@ -442,6 +442,20 @@ config MFD_MAX77693 > >>>> additional drivers must be enabled in order to use the functionality > >>>> of the device. > >>>> > >>>> +config MFD_MAX77843 > >>>> + bool "Maxim Semiconductor MAX77843 PMIC Support" > >>>> + depends on I2C=y > >>>> + select MFD_CORE > >>>> + select REGMAP_I2C > >>>> + select REGMAP_IRQ > >>>> + help > >>>> + Say yes here to add support for Maxim Semiconductor MAX77843. > >>>> + This is companion Power Management IC with LEDs, Haptic, Charger, > >>>> + Fuel Gauge, MUIC(Micro USB Interface Controller) controls on chip. > >>>> + This driver provides common support for accessing the device; > >>>> + additional drivers must be enabled in order to use the functionality > >>>> + of the device. > >>>> + > >>>> config MFD_MAX8907 > >>>> tristate "Maxim Semiconductor MAX8907 PMIC Support" > >>>> select MFD_CORE > >>>> diff --git a/drivers/mfd/Makefile b/drivers/mfd/Makefile > >>>> index 53467e2..fe4f75c 100644 > >>>> --- a/drivers/mfd/Makefile > >>>> +++ b/drivers/mfd/Makefile > >>>> @@ -117,6 +117,7 @@ obj-$(CONFIG_MFD_DA9063) += da9063.o > >>>> obj-$(CONFIG_MFD_MAX14577) += max14577.o > >>>> obj-$(CONFIG_MFD_MAX77686) += max77686.o > >>>> obj-$(CONFIG_MFD_MAX77693) += max77693.o > >>>> +obj-$(CONFIG_MFD_MAX77843) += max77843.o > >>>> obj-$(CONFIG_MFD_MAX8907) += max8907.o > >>>> max8925-objs := max8925-core.o max8925-i2c.o > >>>> obj-$(CONFIG_MFD_MAX8925) += max8925.o > >>>> diff --git a/drivers/mfd/max77843.c b/drivers/mfd/max77843.c > >>>> new file mode 100644 > >>>> index 0000000..d7f8b76 > >>>> --- /dev/null > >>>> +++ b/drivers/mfd/max77843.c > >>>> @@ -0,0 +1,241 @@ > >>>> +/* > >>>> + * max77843.c - MFD core driver for the Maxim MAX77843 > >>>> + * > >>>> + * Copyright (C) 2014 Samsung Electrnoics > >>>> + * Author: Jaewon Kim <jaewon02.kim@xxxxxxxxxxx> > >>>> + * > >>>> + * This program is free software; you can redistribute it and/or modify > >>>> + * it under the terms of the GNU General Public License as published by > >>>> + * the Free Software Foundation; either version 2 of the License, or > >>>> + * (at your option) any later version. > >>>> + */ > >>>> + > >>>> +#include <linux/err.h> > >>>> +#include <linux/i2c.h> > >>>> +#include <linux/init.h> > >>>> +#include <linux/interrupt.h> > >>>> +#include <linux/module.h> > >>>> +#include <linux/mfd/core.h> > >>>> +#include <linux/mfd/max77843-private.h> > >>>> +#include <linux/of_device.h> > >>>> +#include <linux/platform_device.h> > >>>> + > >>>> +static const struct mfd_cell max77843_devs[] = { > >>>> + { > >>>> + .name = "max77843-muic", > >>>> + .of_compatible = "maxim,max77843-muic", > >>>> + }, { > >>>> + .name = "max77843-regulator", > >>>> + .of_compatible = "maxim,max77843-regulator", > >>>> + }, { > >>>> + .name = "max77843-charger", > >>>> + .of_compatible = "maxim,max77843-charger" > >>>> + }, { > >>>> + .name = "max77843-fuelgauge", > >>>> + .of_compatible = "maxim,max77843-fuelgauge", > >>>> + }, > >>>> +}; > >>>> + > >>>> +static const struct regmap_config max77843_charger_regmap_config = { > >>>> + .reg_bits = 8, > >>>> + .val_bits = 8, > >>>> + .max_register = MAX77843_CHG_REG_END, > >>>> +}; > >>>> + > >>>> +static const struct regmap_config max77843_regmap_config = { > >>>> + .reg_bits = 8, > >>>> + .val_bits = 8, > >>>> + .max_register = MAX77843_SYS_REG_END, > >>>> +}; > >>>> + > >>>> +static const struct regmap_irq max77843_irqs[] = { > >>>> + /* TOPSYS interrupts */ > >>>> + { .reg_offset = 0, .mask = MAX77843_SYS_IRQ_SYSUVLO_INT, }, > >>>> + { .reg_offset = 0, .mask = MAX77843_SYS_IRQ_SYSOVLO_INT, }, > >>>> + { .reg_offset = 0, .mask = MAX77843_SYS_IRQ_TSHDN_INT, }, > >>>> + { .reg_offset = 0, .mask = MAX77843_SYS_IRQ_TM_INT, }, > >>>> +}; > >>>> + > >>>> +static const struct regmap_irq_chip max77843_irq_chip = { > >>>> + .name = "max77843", > >>>> + .status_base = MAX77843_SYS_REG_SYSINTSRC, > >>>> + .mask_base = MAX77843_SYS_REG_SYSINTMASK, > >>>> + .mask_invert = false, > >>>> + .num_regs = 1, > >>>> + .irqs = max77843_irqs, > >>>> + .num_irqs = ARRAY_SIZE(max77843_irqs), > >>>> +}; > >>>> + > >>>> +static int max77843_chg_init(struct max77843 *max77843) > >>>> +{ > >>> > >>> Could this function be moved to the charger driver? This way the > >>> driver will manage its own resources instead of depending on parent > >>> MFD driver. > >>> > >> > >> Charger regulator and Charger share same resources. > >> So I include this function core driver. > > > > OK, I see... Could you describe it in comments somewhere? For example in > > comment above the function. Currently this looks like only as regmap for > > charger. > > > > Charger regulator and Charger use same regmap. OK, just put it in a comment around that function. > > > Unfortunately current solution imposes problem with releasing resources. > > Who is the owner of i2c dummy device? > > > > Core driver owner of i2c dummy device. OK, good idea. So the core driver should be the only place to unregister it. So needed changes are: 1. Remove the i2c_unregister_device() call from max77843_charger_probe(). 2. Add i2c_unregister_device(max77843->i2c_chg) in max77843_remove(). The MFD core driver will handle it. > > > 1. The charger driver will unregister it if max77843_charger_probe() > > fails. What will happen with regulator driver in such case? > > > > Charger is enabled/disabled by Charger regulator. > Currently, If charger probe fails, charger regulator failed to read regmap and occur panic(It have to fix.) > > > > 2. Who will release this i2c dummy device in normal unbind? Currently it > > leaks. > > > > I think core driver release i2c dummy device in normal unbind. > We need to more discussion about this problem. > If you have any idea, I hope tell me. Again, Thank you for your advice. I think handling the ownership in core driver could solve this. Best regards, Krzysztof -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html