Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp3199686pxb; Sat, 26 Mar 2022 13:18:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy+VFwKSc7vtcf8w9QkUZi/pqrsLHO5zo4F+DKO8Gtp6Mx9btlRbhPJdLqXjGPryhKcVY4/ X-Received: by 2002:a17:907:3f18:b0:6e0:df2d:c76a with SMTP id hq24-20020a1709073f1800b006e0df2dc76amr3539041ejc.55.1648325939091; Sat, 26 Mar 2022 13:18:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1648325939; cv=none; d=google.com; s=arc-20160816; b=qAz8YczDCL/ug/ySnPOocv4MIUxmE5Zs9WQ3La4vbBfjve39GFLjYaS2m7Mi67nQFB NQw/btCqFcKpyl2EpH8Hc48eztgS+mH+omrP18cow9IolyMuidCXBQL+xuIFFJOnsC3v nW1PFzWXpUoUyEnQgm7B7fldeO7NYZzqO+eE/8oLu4caoDOKtRG6Q7hnT74SsWthc+aB TFJsFzFgsl34CCzYKV4q/zfdW13Ckj0hbEDzaoVT9aLReevuOyY6Sa7KtYvyKP9bEIQk USTTyWKoYlvPv9KMlakYpOM0ljtb9DuKooppoPcu34j+sIQsnJKVRjqRcXdqAn/DwbuV XiJA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:organization :from:references:cc:to:subject:dkim-filter; bh=tH18mNC7lMgGeNJsq5wUNdQSzOI2wRSaDhNscyMVCFg=; b=E2WePw3LKvBr81K/ROwn2tU5Rp2At9cWsjR/ZRfzYY18Ce0CQBOsIGdnWTyhQDzAvu l1qWN78b24tvwcSP80MrBiTpyyvJ0IclHg8JmfHrC3Wq/nsoRhXqkm/WDBiD71ZzSIHj ltUXL4JG798ewik1b0CnvVVJ+7uE23opnqU8TZJsRkGLDidpqgUJAT5p/dxyCXNblKRB Jj2AfEFNIH6T6JokYZ8VrtzK1jNMTVAHabWYR2iK+rgBx9JsOd4f8nm9ZflTmcbo7B8h ebrns7FBbyCCX1Wi++neHjAoiZ1HKZbOMQJbsCQLywxB1GpLHqJTQoYcYvftZud4d1qI 47DQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g1-20020a1709067c4100b006df76385b8bsi7445858ejp.43.2022.03.26.13.18.34; Sat, 26 Mar 2022 13:18:59 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232152AbiCZInR (ORCPT + 99 others); Sat, 26 Mar 2022 04:43:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42464 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229491AbiCZInQ (ORCPT ); Sat, 26 Mar 2022 04:43:16 -0400 Received: from mxout03.lancloud.ru (mxout03.lancloud.ru [45.84.86.113]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DC21DB6E7D; Sat, 26 Mar 2022 01:41:35 -0700 (PDT) Received: from LanCloud DKIM-Filter: OpenDKIM Filter v2.11.0 mxout03.lancloud.ru DA04E20A8247 Received: from LanCloud Received: from LanCloud Received: from LanCloud Subject: Re: [PATCH v1 5/5] pinctrl: armada-37xx: Replace custom code by gpiochip_count() call To: Andy Shevchenko , Gregory CLEMENT , Geert Uytterhoeven , Fabien Dessenne , Linus Walleij , , , , , , CC: Neil Armstrong , Kevin Hilman , Jerome Brunet , "Martin Blumenstingl" , Andrew Lunn , Sebastian Hesselbarth , Maxime Coquelin , Alexandre Torgue , Bartosz Golaszewski References: <20220325200338.54270-1-andriy.shevchenko@linux.intel.com> <20220325200338.54270-5-andriy.shevchenko@linux.intel.com> From: Sergey Shtylyov Organization: Open Mobile Platform Message-ID: <3415996d-e8b5-2416-fb66-e65779a9b507@omp.ru> Date: Sat, 26 Mar 2022 11:41:31 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.10.1 MIME-Version: 1.0 In-Reply-To: <20220325200338.54270-5-andriy.shevchenko@linux.intel.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [192.168.11.198] X-ClientProxiedBy: LFEXT01.lancloud.ru (fd00:f066::141) To LFEX1907.lancloud.ru (fd00:f066::207) X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,NICE_REPLY_A, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello! On 3/25/22 11:03 PM, Andy Shevchenko wrote: > Since we have generic function to count GPIO controller nodes > under given device, there is no need to open code it. Replace > custom code by gpiochip_count() call. > > Signed-off-by: Andy Shevchenko > --- > drivers/pinctrl/mvebu/pinctrl-armada-37xx.c | 24 +++++++++------------ > 1 file changed, 10 insertions(+), 14 deletions(-) > > diff --git a/drivers/pinctrl/mvebu/pinctrl-armada-37xx.c b/drivers/pinctrl/mvebu/pinctrl-armada-37xx.c > index 08cad14042e2..ba94125f6566 100644 > --- a/drivers/pinctrl/mvebu/pinctrl-armada-37xx.c > +++ b/drivers/pinctrl/mvebu/pinctrl-armada-37xx.c > @@ -728,22 +728,18 @@ static int armada_37xx_irqchip_register(struct platform_device *pdev, > struct gpio_irq_chip *girq = &gc->irq; > struct device *dev = &pdev->dev; > struct device_node *np; > - int ret = -ENODEV, i, nr_irq_parent; > + unsigned int nr_child_nodes, i; > + int ret; > > /* Check if we have at least one gpio-controller child node */ > - for_each_child_of_node(dev->of_node, np) { > - if (of_property_read_bool(np, "gpio-controller")) { > - ret = 0; > - break; > - } > - } > - if (ret) > - return dev_err_probe(dev, ret, "no gpio-controller child node\n"); > + nr_child_nodes = gpiochip_count(dev); > + if (!nr_child_nodes) > + return dev_err_probe(dev, -ENODEV, "no gpio-controller child node\n"); > > - nr_irq_parent = of_irq_count(np); > spin_lock_init(&info->irq_lock); > > - if (!nr_irq_parent) { > + nr_child_nodes = of_irq_count(np); Mhm, 'np' is no longer assigned to at this point... > + if (!nr_child_nodes) { > dev_err(dev, "invalid or no IRQ\n"); > return 0; > } [...] MBR, Sergey