From: Chen Gang <gang.chen@asianux.com>
To: Linus Walleij <linus.walleij@linaro.org>
Cc: Grant Likely <grant.likely@linaro.org>,
Russell King - ARM Linux <linux@arm.linux.org.uk>,
Arnd Bergmann <arnd@arndb.de>,
"linux-gpio@vger.kernel.org" <linux-gpio@vger.kernel.org>,
Linux-Arch <linux-arch@vger.kernel.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
Geert Uytterhoeven <geert@linux-m68k.org>
Subject: Re: [PATCH] include/asm-generic/gpio.h: remove the call for __gpio_get_value() and __gpio_set_value() when GPIOLIB disabled
Date: Fri, 30 Aug 2013 09:50:54 +0800 [thread overview]
Message-ID: <521FFA7E.5090106@asianux.com> (raw)
In-Reply-To: <CACRpkdazBtZfWdGA71WV20oZn2NYXDGExDmDkrv_TrRnhOmxQg@mail.gmail.com>
On 08/29/2013 08:08 PM, Linus Walleij wrote:
> On Mon, Aug 26, 2013 at 12:08 PM, Chen Gang <gang.chen@asianux.com> wrote:
>
>> When GPIOLIB disabled, __gpio_get_value() and __gpio_set_value() will
>> not implement, so need remove them, or compiling fails.
>>
>> e.g. (allmodconfig for h8300)
>>
>> CC arch/h8300/kernel/h8300_ksyms.o
>> In file included from arch/h8300/include/generated/asm/gpio.h:1:0,
>> from arch/h8300/kernel/h8300_ksyms.c:17:
>> include/asm-generic/gpio.h: In function 'gpio_get_value_cansleep':
>> include/asm-generic/gpio.h:270:2: error: implicit declaration of function '__gpio_get_value' [-Werror=implicit-function-declaration]
>> return __gpio_get_value(gpio);
>> ^
>>
>> For __gpio_get_value(), according to its implementation, it is enough
>> to use "return 0" instead of, and for __gpio_set_value(), just remove
>> directly.
>>
>>
>> Signed-off-by: Chen Gang <gang.chen@asianux.com>
>
> NAK, this is not how you do it. This fallback path is for GENERIC_GPIO
> without GPIOLIB. Including it from a file indicates that you *are*
> using GENERIC_GPIO when GPIOLIB is not activated. It can not be
> used to stub out gpiolib.
>
Hmm... what you said above sounds reasonable to me (at least, it can be
acceptable).
> This is a better alternative: let h8300 select
> ARCH_HAVE_CUSTOM_GPIO_H
>
> This is quite common:
> $ git grep ARCH_HAVE_CUSTOM_GPIO_H
> arch/arm/Kconfig: select ARCH_HAVE_CUSTOM_GPIO_H
> arch/avr32/Kconfig: select ARCH_HAVE_CUSTOM_GPIO_H
> arch/blackfin/Kconfig: select ARCH_HAVE_CUSTOM_GPIO_H
> arch/m68k/Kconfig.cpu: select ARCH_HAVE_CUSTOM_GPIO_H
> arch/mips/Kconfig: select ARCH_HAVE_CUSTOM_GPIO_H
> arch/sh/Kconfig: select ARCH_HAVE_CUSTOM_GPIO_H
> arch/unicore32/Kconfig: select ARCH_HAVE_CUSTOM_GPIO_H
>
> Then put your stubs for __gpio_get_value() etc in
> arch/h8300/include/asm/gpio.h
>
> This way the h8300 will have a stub implementation if GPIOLIB
> is not selected.
>
> Be sure to put a comment about this in that file.
>
That sounds a standard way for it, thanks.
Hmm... but for h8300, it seems it may not include "gpio.h" which is just
discussing about it with Geert in another thread (it seems what he said
is correct, and now I am just proving it).
Thanks.
> Note: I'm still a bit rookie as GPIO maintainer so if Grant or
> Russell tells me I'm telling you wrong things: listen to them.
>
Thank you for your modesty and honesty.
And welcome other members' suggestions or completions.
Thanks.
> Yours,
> Linus Walleij
>
>
--
Chen Gang
prev parent reply other threads:[~2013-08-30 1:52 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-08-26 10:08 [PATCH] include/asm-generic/gpio.h: remove the call for __gpio_get_value() and __gpio_set_value() when GPIOLIB disabled Chen Gang
2013-08-29 12:08 ` Linus Walleij
2013-08-30 1:50 ` Chen Gang [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=521FFA7E.5090106@asianux.com \
--to=gang.chen@asianux.com \
--cc=arnd@arndb.de \
--cc=geert@linux-m68k.org \
--cc=grant.likely@linaro.org \
--cc=linus.walleij@linaro.org \
--cc=linux-arch@vger.kernel.org \
--cc=linux-gpio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux@arm.linux.org.uk \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox