Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S935115AbcCJHUf (ORCPT ); Thu, 10 Mar 2016 02:20:35 -0500 Received: from hqemgate16.nvidia.com ([216.228.121.65]:14439 "EHLO hqemgate16.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753878AbcCJHUd (ORCPT ); Thu, 10 Mar 2016 02:20:33 -0500 X-PGP-Universal: processed; by hqnvupgp07.nvidia.com on Wed, 09 Mar 2016 23:19:11 -0800 Message-ID: <56E11D34.60401@nvidia.com> Date: Thu, 10 Mar 2016 12:37:32 +0530 From: Laxman Dewangan User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.4.0 MIME-Version: 1.0 To: Stephen Warren CC: Markus Pargmann , , , , , , , , , Benoit Parrot , Alexandre Courbot Subject: Re: [PATCH 4/5] gpio: of: Add support to have multiple gpios in gpio-hog References: <1457438528-29054-1-git-send-email-ldewangan@nvidia.com> <1457438528-29054-5-git-send-email-ldewangan@nvidia.com> <20160309062849.GB10454@pengutronix.de> <56E02335.6020901@nvidia.com> <56E05AA9.8000503@wwwdotorg.org> In-Reply-To: <56E05AA9.8000503@wwwdotorg.org> X-Originating-IP: [10.19.65.30] X-ClientProxiedBy: DRUKMAIL102.nvidia.com (10.25.59.20) To bgmail102.nvidia.com (10.25.59.11) Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3386 Lines: 85 On Wednesday 09 March 2016 10:47 PM, Stephen Warren wrote: > On 03/09/2016 06:20 AM, Laxman Dewangan wrote: >> >> On Wednesday 09 March 2016 11:58 AM, Markus Pargmann wrote: >>> * PGP Signed by an unknown key >>> >>> Hi, >>> >>> On Tue, Mar 08, 2016 at 05:32:07PM +0530, Laxman Dewangan wrote: >>>> The child node for gpio hogs under gpio controller's node >>>> provide the mechanism to automatic GPIO request and >>>> configuration as part of the gpio-controller's driver >>>> probe function. >>>> >>>> Currently, property "gpio" takes one gpios for such >>>> configuration. Add support to have multiple GPIOs in >>>> this property so that multiple GPIOs of gpio-controller >>>> can be configured by this mechanism with one child node. >>> So if I read this correctly you want to have multiple GPIOs with the >>> same line name? Why don't you use multiple child nodes with individual >>> line names? >>> >> There is cases on which particular functional configuration needs sets >> of GPIO to set. On this case, making sub node for each GPIOs creates >> lots of sub-nodes and add complexity on readability, usability and >> maintainability. >> Example: for my board, I wanted to set GPIO H2 to input and H0 and H1 to >> be output high. >> Instead of three nodes, I can have two here: >> gpio@0,6000d000 { >> wlan_input { >> gpio-hog; >> gpios = ; >> input; >> }; >> >> wlan_output { >> gpio-hog; >> gpios = ; >> output-high; >> }; >> }; > > >> So here I am grouping the multiple output GPIO together. >> >> This looks much similar if we have many GPIOs for one type of >> configurations. >> >> Even it looks better if we have something: >> gpio@0,6000d000 { >> wlan_control { >> gpio-hog; >> gpios-input = ; >> gpios-output-high = > TEGRA_GPIO(H, 1) 0>; >> }; >> }; > > The problem with that is the description used when acquiring the GPIO > is just "wlan_input", "wlan_output", or "wlan_control". There's > nothing to indicate what those individual pins do (perhaps one is a > reset signal, one is a regulator enable, etc.?) By requiring separate > nodes for each GPIO, then the node name can provide a meaningful > semantic name/description for each GPIO, which provides much more > information. > On this case, we have already property "line-name" and passed the name of the gpio via this property. The property names is "line-name" which is good for one string. We can support other property "line-names" with multiple string per GPIO index. line-names = "wlan-reset", "wlan-enable"; > If the approach in this patch is acceptable though, I think you want > to update the description of "gpios" (in the GPIO hog definition > section) in Documentation/devicetree/bindings/gpio/gpio.txt to mention > that multiple GPIO entries are legal. Right now it says that property > much contain exactly #gpio-cells, not a multiple of #gpio-cells. I have 5th patch for this and will rearrange series as you suggested on 5th patch.