Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp2240982pxb; Fri, 25 Mar 2022 13:43:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJybeo/p5+Y/96ClHZvz1rbho78GuKPGPeQX/s3VyDChyT9Z8OQSl3crh3wNE9EZ86YcLWek X-Received: by 2002:a17:902:c40e:b0:154:80a7:95c9 with SMTP id k14-20020a170902c40e00b0015480a795c9mr14101476plk.28.1648240999550; Fri, 25 Mar 2022 13:43:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1648240999; cv=none; d=google.com; s=arc-20160816; b=xy05u4TnkQz0oF/2Ht7pezBgNZv6OlGXMqM7ajRU9W3e/LHswVW7qPwFwpl9fC0+KK oVYw4ZilfIpc6f5owqFQU7aBSANTUMimkXqrfCpGco9+gc2J1uDEaSCZAxjo6eijAatb W0RIiXF8N4vrLi+Gi2AAQgA/QJHE8L1HNkCc6F3M05hjebBNTtww7A1j9JZhQ/XpICOr /tL8QU14s8ANgt5iJ7vIFMyuJqz0wwrjBtOGE6+PGXtf1utAR5cDTvYakqzxFA4fYvAm DvkAOczWhIBqmsrrl6hkemnRBd47WNM1TySScjgHad/6Wrc6JpZxLuD71U0NbY67lNmQ 5sbA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=jkn8OuuEdVEvDXy238o2YyE4+3F6e2PXfn66FXT26DA=; b=mBX86XuR3nEI3HFshxNbF7J1JrtB0/25ZwM1Eg+4yRZqtstm51aUKoGP/cUIIpn0Ze Qs4gkYjL9O8gOqahrhdKG4T3FV3akS/Gg/5z33G1uCuuuXcqVRpt1pMJXlttbciENvMu OCWxnz79j+6ZHUzizv8iqPqQRqfzt5Nhc66u1sQ56gJROfoNP1HoYYxE9i87vhMT2VvG zobaBcCLvqqJ05uWrMN2Ee+tZLY2+uKlc1XJO6ZckgWGiylPxO7QcQ+w2elN9yATyEEL KSzJKg/fbPaXoaPkjXJdwp9edaabgYGcEyLTGjVJG0fsnYA48qH3+pbYpZqAseya3Ds2 /hKg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b="O+/skQHC"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id cb15-20020a056a00430f00b004fa3a8e008esi3289674pfb.325.2022.03.25.13.43.19 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 25 Mar 2022 13:43:19 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b="O+/skQHC"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 69D3F2FE43; Fri, 25 Mar 2022 13:07:09 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232295AbiCYUIc (ORCPT + 99 others); Fri, 25 Mar 2022 16:08:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43374 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232349AbiCYUH5 (ORCPT ); Fri, 25 Mar 2022 16:07:57 -0400 Received: from mga14.intel.com (mga14.intel.com [192.55.52.115]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 770F62BB28; Fri, 25 Mar 2022 13:04:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1648238655; x=1679774655; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=I9qL3XzxipS1lgo6CpdL7eX6zDMQG8eU8y3dPwQxX+Y=; b=O+/skQHCsifZ14BSN7Uy15tbo5g4s/Jyvg4DN2Z3oEBfFPA63/Sa0G6e 5j7oEQHcpr+3/1+Et3CTNe9E/QrIPTmutCaTZJwJ+acrzc6RNZcceZ9Fa v304SzwzTIc+T/bzw5HpqgGpSOsbteO8Ou0zcN6n4dAuX7b419nPH54GX jgWNC7pfPca6++ufBqCBz9co6nlLE/ysluceDU2w6vriXUlBxlTJCmpgp G0ttNksdCJ3Gdt5ei/lGehDJ9+czS2qRTXqfmoM7v/XmBEGAcd5ZCfuWR WjndAspSjBYZRaKm2Beucg6It3nEAza4BTFQBQ5Bj29aGiHYS285GB+fJ A==; X-IronPort-AV: E=McAfee;i="6200,9189,10297"; a="258900034" X-IronPort-AV: E=Sophos;i="5.90,211,1643702400"; d="scan'208";a="258900034" Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 25 Mar 2022 13:04:14 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.90,211,1643702400"; d="scan'208";a="501886245" Received: from black.fi.intel.com ([10.237.72.28]) by orsmga003.jf.intel.com with ESMTP; 25 Mar 2022 13:04:09 -0700 Received: by black.fi.intel.com (Postfix, from userid 1003) id 75E9F11E; Fri, 25 Mar 2022 22:04:30 +0200 (EET) From: Andy Shevchenko To: Andy Shevchenko , Gregory CLEMENT , Geert Uytterhoeven , Fabien Dessenne , Linus Walleij , linux-gpio@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-amlogic@lists.infradead.org, linux-kernel@vger.kernel.org, linux-renesas-soc@vger.kernel.org, linux-stm32@st-md-mailman.stormreply.com Cc: Neil Armstrong , Kevin Hilman , Jerome Brunet , Martin Blumenstingl , Andrew Lunn , Sebastian Hesselbarth , Maxime Coquelin , Alexandre Torgue , Bartosz Golaszewski Subject: [PATCH v1 1/5] gpiolib: Introduce gpiochip_count() helper Date: Fri, 25 Mar 2022 22:03:34 +0200 Message-Id: <20220325200338.54270-1-andriy.shevchenko@linux.intel.com> X-Mailer: git-send-email 2.35.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable 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 The gpiochip_count() helper iterates over the device child nodes that have the "gpio-controller" property set. It returns the number of such nodes under given device. Signed-off-by: Andy Shevchenko --- include/linux/gpio/driver.h | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/include/linux/gpio/driver.h b/include/linux/gpio/driver.h index 894eab753fdf..52918ef5d288 100644 --- a/include/linux/gpio/driver.h +++ b/include/linux/gpio/driver.h @@ -9,6 +9,7 @@ #include #include #include +#include #include struct gpio_desc; @@ -750,4 +751,17 @@ static inline void gpiochip_unlock_as_irq(struct gpio_chip *gc, } #endif /* CONFIG_GPIOLIB */ +static inline unsigned int gpiochip_count(struct device *dev) +{ + struct fwnode_handle *child; + unsigned int count = 0; + + device_for_each_child_node(dev, child) { + if (device_property_read_bool(child, "gpio-controller")) + count++; + } + + return count; +} + #endif /* __LINUX_GPIO_DRIVER_H */ -- 2.35.1