From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754061AbbGAJoN (ORCPT ); Wed, 1 Jul 2015 05:44:13 -0400 Received: from mail-wi0-f181.google.com ([209.85.212.181]:36532 "EHLO mail-wi0-f181.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753633AbbGAJmi (ORCPT ); Wed, 1 Jul 2015 05:42:38 -0400 From: Tomeu Vizoso To: linux-kernel@vger.kernel.org Cc: Mark Brown , linux-acpi@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, linux-gpio@vger.kernel.org, devicetree@vger.kernel.org, linux-pwm@vger.kernel.org, "Rafael J. Wysocki" , alsa-devel@alsa-project.org, Tomeu Vizoso , Linus Walleij , Alexandre Courbot Subject: [PATCH v2 04/12] gpio: register dependency parser for firmware nodes Date: Wed, 1 Jul 2015 11:40:59 +0200 Message-Id: <1435743667-11987-5-git-send-email-tomeu.vizoso@collabora.com> X-Mailer: git-send-email 2.4.1 In-Reply-To: <1435743667-11987-1-git-send-email-tomeu.vizoso@collabora.com> References: <1435743667-11987-1-git-send-email-tomeu.vizoso@collabora.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org So the GPIO subsystem can be queried about the dependencies of nodes that consume GPIOs, as specified in bindings/gpio/gpio.txt. Signed-off-by: Tomeu Vizoso --- Changes in v2: None drivers/gpio/gpiolib.c | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c index bf4bd1d..6a3e83f 100644 --- a/drivers/gpio/gpiolib.c +++ b/drivers/gpio/gpiolib.c @@ -2388,4 +2388,58 @@ static int __init gpiolib_debugfs_init(void) } subsys_initcall(gpiolib_debugfs_init); +static void gpio_get_dependencies(struct fwnode_handle *fwnode, + struct list_head *deps) +{ + struct device_node *np; + struct property *pp; + struct of_phandle_args pspec; + int count, i, ret; + + np = to_of_node(fwnode); + if (!np) + return; + + for_each_property_of_node(np, pp) { + if (strcmp(pp->name, "gpio") && + strcmp(pp->name, "gpios") && + !strends(pp->name, "-gpios") && + !strends(pp->name, "-gpio")) + continue; + + count = of_count_phandle_with_args(np, pp->name, + "#gpio-cells"); + for (i = 0; i < count; i++) { + ret = of_parse_phandle_with_args(np, pp->name, + "#gpio-cells", i, + &pspec); + if (ret || !pspec.np) + continue; + + fwnode_add_dependency(&pspec.np->fwnode, deps); + + of_node_put(pspec.np); + } + } + + for (i = 0;; i++) { + ret = of_parse_phandle_with_fixed_args(np, "gpio-ranges", 3, + i, &pspec); + if (ret) + break; + + fwnode_add_dependency(&pspec.np->fwnode, deps); + + of_node_put(pspec.np); + } +} + +static int __init gpiolib_init(void) +{ + fwnode_add_dependency_parser(gpio_get_dependencies); + + return 0; +} +device_initcall(gpiolib_init); + #endif /* DEBUG_FS */ -- 2.4.1 From mboxrd@z Thu Jan 1 00:00:00 1970 From: Tomeu Vizoso Subject: [PATCH v2 04/12] gpio: register dependency parser for firmware nodes Date: Wed, 1 Jul 2015 11:40:59 +0200 Message-ID: <1435743667-11987-5-git-send-email-tomeu.vizoso@collabora.com> References: <1435743667-11987-1-git-send-email-tomeu.vizoso@collabora.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: In-Reply-To: <1435743667-11987-1-git-send-email-tomeu.vizoso@collabora.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: linux-kernel@vger.kernel.org Cc: devicetree@vger.kernel.org, linux-fbdev@vger.kernel.org, Tomeu Vizoso , linux-gpio@vger.kernel.org, "Rafael J. Wysocki" , alsa-devel@alsa-project.org, dri-devel@lists.freedesktop.org, linux-acpi@vger.kernel.org, Mark Brown , linux-pwm@vger.kernel.org, Alexandre Courbot List-Id: linux-acpi@vger.kernel.org U28gdGhlIEdQSU8gc3Vic3lzdGVtIGNhbiBiZSBxdWVyaWVkIGFib3V0IHRoZSBkZXBlbmRlbmNp ZXMgb2Ygbm9kZXMKdGhhdCBjb25zdW1lIEdQSU9zLCBhcyBzcGVjaWZpZWQgaW4gYmluZGluZ3Mv Z3Bpby9ncGlvLnR4dC4KClNpZ25lZC1vZmYtYnk6IFRvbWV1IFZpem9zbyA8dG9tZXUudml6b3Nv QGNvbGxhYm9yYS5jb20+Ci0tLQoKQ2hhbmdlcyBpbiB2MjogTm9uZQoKIGRyaXZlcnMvZ3Bpby9n cGlvbGliLmMgfCA1NCArKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysr KysrKysrKwogMSBmaWxlIGNoYW5nZWQsIDU0IGluc2VydGlvbnMoKykKCmRpZmYgLS1naXQgYS9k cml2ZXJzL2dwaW8vZ3Bpb2xpYi5jIGIvZHJpdmVycy9ncGlvL2dwaW9saWIuYwppbmRleCBiZjRi ZDFkLi42YTNlODNmIDEwMDY0NAotLS0gYS9kcml2ZXJzL2dwaW8vZ3Bpb2xpYi5jCisrKyBiL2Ry aXZlcnMvZ3Bpby9ncGlvbGliLmMKQEAgLTIzODgsNCArMjM4OCw1OCBAQCBzdGF0aWMgaW50IF9f aW5pdCBncGlvbGliX2RlYnVnZnNfaW5pdCh2b2lkKQogfQogc3Vic3lzX2luaXRjYWxsKGdwaW9s aWJfZGVidWdmc19pbml0KTsKIAorc3RhdGljIHZvaWQgZ3Bpb19nZXRfZGVwZW5kZW5jaWVzKHN0 cnVjdCBmd25vZGVfaGFuZGxlICpmd25vZGUsCisJCQkJICBzdHJ1Y3QgbGlzdF9oZWFkICpkZXBz KQoreworCXN0cnVjdCBkZXZpY2Vfbm9kZSAqbnA7CisJc3RydWN0IHByb3BlcnR5ICpwcDsKKwlz dHJ1Y3Qgb2ZfcGhhbmRsZV9hcmdzIHBzcGVjOworCWludCBjb3VudCwgaSwgcmV0OworCisJbnAg PSB0b19vZl9ub2RlKGZ3bm9kZSk7CisJaWYgKCFucCkKKwkJcmV0dXJuOworCisJZm9yX2VhY2hf cHJvcGVydHlfb2Zfbm9kZShucCwgcHApIHsKKwkJaWYgKHN0cmNtcChwcC0+bmFtZSwgImdwaW8i KSAmJgorCQkgICAgc3RyY21wKHBwLT5uYW1lLCAiZ3Bpb3MiKSAmJgorCQkgICAgIXN0cmVuZHMo cHAtPm5hbWUsICItZ3Bpb3MiKSAmJgorCQkgICAgIXN0cmVuZHMocHAtPm5hbWUsICItZ3BpbyIp KQorCQkJY29udGludWU7CisKKwkJY291bnQgPSBvZl9jb3VudF9waGFuZGxlX3dpdGhfYXJncyhu cCwgcHAtPm5hbWUsCisJCQkJCQkgICAiI2dwaW8tY2VsbHMiKTsKKwkJZm9yIChpID0gMDsgaSA8 IGNvdW50OyBpKyspIHsKKwkJCXJldCA9IG9mX3BhcnNlX3BoYW5kbGVfd2l0aF9hcmdzKG5wLCBw cC0+bmFtZSwKKwkJCQkJCQkgIiNncGlvLWNlbGxzIiwgaSwKKwkJCQkJCQkgJnBzcGVjKTsKKwkJ CWlmIChyZXQgfHwgIXBzcGVjLm5wKQorCQkJCWNvbnRpbnVlOworCisJCQlmd25vZGVfYWRkX2Rl cGVuZGVuY3koJnBzcGVjLm5wLT5md25vZGUsIGRlcHMpOworCisJCQlvZl9ub2RlX3B1dChwc3Bl Yy5ucCk7CisJCX0KKwl9CisKKwlmb3IgKGkgPSAwOzsgaSsrKSB7CisJCXJldCA9IG9mX3BhcnNl X3BoYW5kbGVfd2l0aF9maXhlZF9hcmdzKG5wLCAiZ3Bpby1yYW5nZXMiLCAzLAorCQkJCQkJICAg ICAgIGksICZwc3BlYyk7CisJCWlmIChyZXQpCisJCQlicmVhazsKKworCQlmd25vZGVfYWRkX2Rl cGVuZGVuY3koJnBzcGVjLm5wLT5md25vZGUsIGRlcHMpOworCisJCW9mX25vZGVfcHV0KHBzcGVj Lm5wKTsKKwl9Cit9CisKK3N0YXRpYyBpbnQgX19pbml0IGdwaW9saWJfaW5pdCh2b2lkKQorewor CWZ3bm9kZV9hZGRfZGVwZW5kZW5jeV9wYXJzZXIoZ3Bpb19nZXRfZGVwZW5kZW5jaWVzKTsKKwor CXJldHVybiAwOworfQorZGV2aWNlX2luaXRjYWxsKGdwaW9saWJfaW5pdCk7CisKICNlbmRpZgkv KiBERUJVR19GUyAqLwotLSAKMi40LjEKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fCmRyaS1kZXZlbCBtYWlsaW5nIGxpc3QKZHJpLWRldmVsQGxpc3RzLmZy ZWVkZXNrdG9wLm9yZwpodHRwOi8vbGlzdHMuZnJlZWRlc2t0b3Aub3JnL21haWxtYW4vbGlzdGlu Zm8vZHJpLWRldmVsCg== From mboxrd@z Thu Jan 1 00:00:00 1970 From: Tomeu Vizoso Date: Wed, 01 Jul 2015 09:40:59 +0000 Subject: [PATCH v2 04/12] gpio: register dependency parser for firmware nodes Message-Id: <1435743667-11987-5-git-send-email-tomeu.vizoso@collabora.com> List-Id: References: <1435743667-11987-1-git-send-email-tomeu.vizoso@collabora.com> In-Reply-To: <1435743667-11987-1-git-send-email-tomeu.vizoso@collabora.com> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: linux-kernel@vger.kernel.org Cc: devicetree@vger.kernel.org, linux-fbdev@vger.kernel.org, Tomeu Vizoso , linux-gpio@vger.kernel.org, "Rafael J. Wysocki" , alsa-devel@alsa-project.org, dri-devel@lists.freedesktop.org, linux-acpi@vger.kernel.org, Mark Brown , linux-pwm@vger.kernel.org, Alexandre Courbot So the GPIO subsystem can be queried about the dependencies of nodes that consume GPIOs, as specified in bindings/gpio/gpio.txt. Signed-off-by: Tomeu Vizoso --- Changes in v2: None drivers/gpio/gpiolib.c | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c index bf4bd1d..6a3e83f 100644 --- a/drivers/gpio/gpiolib.c +++ b/drivers/gpio/gpiolib.c @@ -2388,4 +2388,58 @@ static int __init gpiolib_debugfs_init(void) } subsys_initcall(gpiolib_debugfs_init); +static void gpio_get_dependencies(struct fwnode_handle *fwnode, + struct list_head *deps) +{ + struct device_node *np; + struct property *pp; + struct of_phandle_args pspec; + int count, i, ret; + + np = to_of_node(fwnode); + if (!np) + return; + + for_each_property_of_node(np, pp) { + if (strcmp(pp->name, "gpio") && + strcmp(pp->name, "gpios") && + !strends(pp->name, "-gpios") && + !strends(pp->name, "-gpio")) + continue; + + count = of_count_phandle_with_args(np, pp->name, + "#gpio-cells"); + for (i = 0; i < count; i++) { + ret = of_parse_phandle_with_args(np, pp->name, + "#gpio-cells", i, + &pspec); + if (ret || !pspec.np) + continue; + + fwnode_add_dependency(&pspec.np->fwnode, deps); + + of_node_put(pspec.np); + } + } + + for (i = 0;; i++) { + ret = of_parse_phandle_with_fixed_args(np, "gpio-ranges", 3, + i, &pspec); + if (ret) + break; + + fwnode_add_dependency(&pspec.np->fwnode, deps); + + of_node_put(pspec.np); + } +} + +static int __init gpiolib_init(void) +{ + fwnode_add_dependency_parser(gpio_get_dependencies); + + return 0; +} +device_initcall(gpiolib_init); + #endif /* DEBUG_FS */ -- 2.4.1