From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753537AbbJPGmD (ORCPT ); Fri, 16 Oct 2015 02:42:03 -0400 Received: from down.free-electrons.com ([37.187.137.238]:53852 "EHLO mail.free-electrons.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751578AbbJPGmA (ORCPT ); Fri, 16 Oct 2015 02:42:00 -0400 Date: Fri, 16 Oct 2015 08:41:59 +0200 From: Maxime Ripard To: Chen-Yu Tsai Cc: Samuel Ortiz , Lee Jones , Liam Girdwood , Mark Brown , Rob Herring , Pawel Moll , Mark Rutland , Ian Campbell , Kumar Gala , Hans de Goede , linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-sunxi@googlegroups.com Subject: Re: [PATCH 3/6] mfd: axp20x: Add support for RSB based AXP223 PMIC Message-ID: <20151016064159.GG2711@lukather> References: <1444840342-9233-1-git-send-email-wens@csie.org> <1444840342-9233-4-git-send-email-wens@csie.org> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="TmwHKJoIRFM7Mu/A" Content-Disposition: inline In-Reply-To: <1444840342-9233-4-git-send-email-wens@csie.org> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --TmwHKJoIRFM7Mu/A Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Thu, Oct 15, 2015 at 12:32:19AM +0800, Chen-Yu Tsai wrote: > The AXP223 is a new PMIC commonly paired with Allwinner A23/A33 SoCs. > It is functionally identical to AXP221; only the regulator default > voltage/status and the external host interface are different. >=20 > Signed-off-by: Chen-Yu Tsai > --- > drivers/mfd/Kconfig | 12 ++++++ > drivers/mfd/Makefile | 1 + > drivers/mfd/axp20x-core.c | 2 + > drivers/mfd/axp20x-rsb.c | 93 ++++++++++++++++++++++++++++++++++++++++= ++++++ > include/linux/mfd/axp20x.h | 1 + > 5 files changed, 109 insertions(+) > create mode 100644 drivers/mfd/axp20x-rsb.c >=20 > diff --git a/drivers/mfd/Kconfig b/drivers/mfd/Kconfig > index 9ba3feb3f2fc..6e5edb61d42e 100644 > --- a/drivers/mfd/Kconfig > +++ b/drivers/mfd/Kconfig > @@ -84,6 +84,7 @@ config MFD_BCM590XX > config MFD_AXP20X > bool "X-Powers AXP series PMICs" > select MFD_AXP20X_I2C > + select MFD_AXP20X_RSB > =20 > config MFD_AXP20X_CORE > bool > @@ -102,6 +103,17 @@ config MFD_AXP20X_I2C > components like regulators or the PEK (Power Enable Key) under the > corresponding menus. > =20 > +config MFD_AXP20X_RSB > + bool "X-Powers AXP series RSB PMICs" > + select MFD_AXP20X_CORE > + depends on SUNXI_RSB=3Dy Do we need that? Even if the bus is compiled as a module, the driver will not be probed before that, will it? > + help > + If you say Y here you get support for the X-Powers AXP series RSB > + based power management ICs (PMICs). > + This driver include only the core APIs. You have to select individual > + components like regulators or the PEK (Power Enable Key) under the > + corresponding menus. > + > config MFD_CROS_EC > tristate "ChromeOS Embedded Controller" > select MFD_CORE > diff --git a/drivers/mfd/Makefile b/drivers/mfd/Makefile > index ce3ad5fd4e2f..1eb278619dd6 100644 > --- a/drivers/mfd/Makefile > +++ b/drivers/mfd/Makefile > @@ -108,6 +108,7 @@ obj-$(CONFIG_MFD_DA9052_SPI) +=3D da9052-spi.o > obj-$(CONFIG_MFD_DA9052_I2C) +=3D da9052-i2c.o > obj-$(CONFIG_MFD_AXP20X_CORE) +=3D axp20x-core.o > obj-$(CONFIG_MFD_AXP20X_I2C) +=3D axp20x-i2c.o > +obj-$(CONFIG_MFD_AXP20X_RSB) +=3D axp20x-rsb.o > =20 > obj-$(CONFIG_MFD_LP3943) +=3D lp3943.o > obj-$(CONFIG_MFD_LP8788) +=3D lp8788.o lp8788-irq.o > diff --git a/drivers/mfd/axp20x-core.c b/drivers/mfd/axp20x-core.c > index dd33548d93c4..baecccb6d400 100644 > --- a/drivers/mfd/axp20x-core.c > +++ b/drivers/mfd/axp20x-core.c > @@ -32,6 +32,7 @@ static const char * const axp20x_model_names[] =3D { > "AXP202", > "AXP209", > "AXP221", > + "AXP223", > "AXP288", > }; > =20 > @@ -575,6 +576,7 @@ int axp20x_match_device(struct axp20x_dev *axp20x, st= ruct device *dev) > axp20x->regmap_irq_chip =3D &axp20x_regmap_irq_chip; > break; > case AXP221_ID: > + case AXP223_ID: > axp20x->nr_cells =3D ARRAY_SIZE(axp22x_cells); > axp20x->cells =3D axp22x_cells; > axp20x->regmap_cfg =3D &axp22x_regmap_config; > diff --git a/drivers/mfd/axp20x-rsb.c b/drivers/mfd/axp20x-rsb.c > new file mode 100644 > index 000000000000..5d053d177717 > --- /dev/null > +++ b/drivers/mfd/axp20x-rsb.c > @@ -0,0 +1,93 @@ > +/* > + * axp20x-rsb.c - RSB driver for the X-Powers' Power Management ICs > + * > + * AXP20x typically comprises an adaptive USB-Compatible PWM charger, BU= CK DC-DC > + * converters, LDOs, multiple 12-bit ADCs of voltage, current and temper= ature > + * as well as configurable GPIOs. > + * > + * This driver supports the RSB variants. > + * > + * Author: Chen-Yu Tsai > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License version 2 as > + * published by the Free Software Foundation. > + */ > + > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > + > +static const struct of_device_id axp20x_sunxi_rsb_of_match[] =3D { > + { .compatible =3D "x-powers,axp223", .data =3D (void *) AXP223_ID }, > + { }, > +}; > +MODULE_DEVICE_TABLE(of, axp20x_sunxi_rsb_of_match); > + > +static int axp20x_sunxi_rsb_match_device(struct axp20x_dev *axp20x, > + struct device *dev) > +{ > + const struct of_device_id *of_id; > + > + of_id =3D of_match_device(axp20x_sunxi_rsb_of_match, dev); > + if (!of_id) { > + dev_err(dev, "Unable to match OF ID\n"); > + return -ENODEV; > + } > + axp20x->variant =3D (long) of_id->data; > + > + return axp20x_match_device(axp20x, dev); > +} > + > +static int axp20x_sunxi_rsb_probe(struct sunxi_rsb_device *rdev) > +{ > + struct axp20x_dev *axp20x; > + int ret; > + > + axp20x =3D devm_kzalloc(&rdev->dev, sizeof(*axp20x), GFP_KERNEL); > + if (!axp20x) > + return -ENOMEM; > + > + ret =3D axp20x_sunxi_rsb_match_device(axp20x, &rdev->dev); > + if (ret) > + return ret; > + > + axp20x->dev =3D &rdev->dev; > + axp20x->irq =3D rdev->irq; > + sunxi_rsb_device_set_drvdata(rdev, axp20x); > + > + axp20x->regmap =3D devm_regmap_init_sunxi_rsb(rdev, axp20x->regmap_cfg); > + if (IS_ERR(axp20x->regmap)) { > + ret =3D PTR_ERR(axp20x->regmap); > + dev_err(&rdev->dev, "regmap init failed: %d\n", ret); > + return ret; > + } > + > + return axp20x_device_probe(axp20x); > +} > + > +static int axp20x_sunxi_rsb_remove(struct sunxi_rsb_device *rdev) > +{ > + struct axp20x_dev *axp20x =3D sunxi_rsb_device_get_drvdata(rdev); > + > + return axp20x_device_remove(axp20x); > +} > + > +static struct sunxi_rsb_driver axp20x_sunxi_rsb_driver =3D { > + .driver =3D { > + .name =3D "axp20x-sunxi-rsb", Do we need to be that verbose in the name of the driver? axp20x-rsb should be enough, especially since it's also the name of your file. Looks good otherwise, thanks! Maxime --=20 Maxime Ripard, Free Electrons Embedded Linux, Kernel and Android engineering http://free-electrons.com --TmwHKJoIRFM7Mu/A Content-Type: application/pgp-signature; name="signature.asc" Content-Description: Digital signature -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAEBAgAGBQJWIJw3AAoJEBx+YmzsjxAgOdwP/i9VMikjXgVeLzBsZOrC9HsU spnKtHWy75+XdIh0GIbdhIghdfrBYrZgOBAqHS/kkREgdftPtPWN7O1R65dDWgb1 PF3SWyMoJq8U9RDec5P+CTBzvXODa2x5T/QMgOMfQYjWSlbczx/Q9mPaw3BKTwNQ Y0ouf46JBzHfTLUKtR9yY+VMvWV1DOI9z9jPQb+mqjSm6FzfMSLmi2fib9oIUuwB 0gxj4Ej2+rSOIDyliNuFCXZFANgkhhOZfQS5gKXXJ4DL5qY2zKrOFXS3vtRba5h1 jRMz0i/XjPxEmlht7Bbu5xLdPdWh+fUumYWH6HNHWdIX+X6lRcI2gNLvRdjhdJDd gogKlzz31G4AXv72zq/mnXayNTxllAH/v61+jc/Hflqvg1g1c02jqVQahulBeXJY lWkPrzNMUkTiK1DsvibTwpjAEdnODw/pHF++q+I40IXfiii+Dfh8ftgRkOB1JTC/ /nfouv1+90ByT1C16DfFCG2Ju+CSlpefZOESmz4/WZGrpvEo9g+aZOT0cQ7ep+dQ bIHmQFN8btWci9BrB7PVpcs0RzcOX1GOjun4GjUN5RtQunb93wT9ZpLtYcUp+0zo 9APGD7tW0iXqAIPQBs0auLrjOESyqdo7XX/BNpF1BaZ7Hev5r60yq2THW47U+XOc fygr6qR+U8kAHhzdXJ3R =IBcw -----END PGP SIGNATURE----- --TmwHKJoIRFM7Mu/A--