From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932812AbcFHOa5 (ORCPT ); Wed, 8 Jun 2016 10:30:57 -0400 Received: from mail-wm0-f46.google.com ([74.125.82.46]:36544 "EHLO mail-wm0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932667AbcFHOaz (ORCPT ); Wed, 8 Jun 2016 10:30:55 -0400 Date: Wed, 8 Jun 2016 15:31:24 +0100 From: Lee Jones To: John Stultz Cc: lkml , Dmitry Torokhov , Rob Herring , Pawel Moll , Mark Rutland , Ian Campbell , Kumar Gala , Jorge Ramirez-Ortiz , Wei Xu , Guodong Xu Subject: Re: [RFC][PATCH 2/5] hi655x-pmic: Make hi655x pmic logic probe child nodes in the dt Message-ID: <20160608143124.GI14888@dell> References: <1464816460-18750-1-git-send-email-john.stultz@linaro.org> <1464816460-18750-3-git-send-email-john.stultz@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <1464816460-18750-3-git-send-email-john.stultz@linaro.org> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Subject should indicate "mfd". `git log --oneline -- drivers/mfd` > In trying to wire up the powerkey driver, I found I > needed to add this to get the pmic logic to probe PMIC > child nodes in the dt data. DT. Please use full buffer width. Wrapping at 50 chars is not necessary. > With this patch, child nodes get properly probed. > > Cc: Dmitry Torokhov > Cc: Rob Herring > Cc: Pawel Moll > Cc: Mark Rutland > Cc: Ian Campbell > Cc: Kumar Gala > Cc: Lee Jones > Cc: Jorge Ramirez-Ortiz > Cc: Wei Xu > Cc: Guodong Xu > Signed-off-by: John Stultz > --- > drivers/mfd/hi655x-pmic.c | 8 ++++++++ > 1 file changed, 8 insertions(+) > > diff --git a/drivers/mfd/hi655x-pmic.c b/drivers/mfd/hi655x-pmic.c > index 05ddc78..3511035 100644 > --- a/drivers/mfd/hi655x-pmic.c > +++ b/drivers/mfd/hi655x-pmic.c > @@ -39,6 +39,11 @@ static const struct regmap_irq hi655x_irqs[] = { > { .reg_offset = 0, .mask = RESERVE_INT }, > }; > > +static const struct of_device_id of_hi655x_pmic_child_match_tbl[] = { > + { .compatible = "hisilicon,hi6552-powerkey", }, > + { /* end */ } > +}; > + > static const struct regmap_irq_chip hi655x_irq_chip = { > .name = "hi655x-pmic", > .irqs = hi655x_irqs, > @@ -122,6 +127,9 @@ static int hi655x_pmic_probe(struct platform_device *pdev) > > platform_set_drvdata(pdev, pmic); > > + /* populate sub nodes */ > + of_platform_populate(np, of_hi655x_pmic_child_match_tbl, NULL, dev); > + Oh, holey poop, no! Please don't mix DT and MFD registration like this. Drivers should contain either of_platform_populate() or mfd_add_devices(), but never both. > ret = mfd_add_devices(dev, PLATFORM_DEVID_AUTO, hi655x_pmic_devs, > ARRAY_SIZE(hi655x_pmic_devs), NULL, 0, NULL); > if (ret) { -- Lee Jones Linaro STMicroelectronics Landing Team Lead Linaro.org │ Open source software for ARM SoCs Follow Linaro: Facebook | Twitter | Blog