2012-11-15 17:06:37

by Igor Mazanov

[permalink] [raw]
Subject: [PATCH] Remove inline from clock framework function definitions to build the kernel with GCC 4.7

Remove inline from clock framework function definitions to
build the kernel with GCC 4.7

Signed-off-by: Igor Mazanov <[email protected]>
---
include/linux/clk-provider.h | 4 ++--
1 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/include/linux/clk-provider.h b/include/linux/clk-provider.h
index c127315..f9f5e9e 100644
--- a/include/linux/clk-provider.h
+++ b/include/linux/clk-provider.h
@@ -335,8 +335,8 @@ const char *__clk_get_name(struct clk *clk);
struct clk_hw *__clk_get_hw(struct clk *clk);
u8 __clk_get_num_parents(struct clk *clk);
struct clk *__clk_get_parent(struct clk *clk);
-inline int __clk_get_enable_count(struct clk *clk);
-inline int __clk_get_prepare_count(struct clk *clk);
+int __clk_get_enable_count(struct clk *clk);
+int __clk_get_prepare_count(struct clk *clk);
unsigned long __clk_get_rate(struct clk *clk);
unsigned long __clk_get_flags(struct clk *clk);
int __clk_is_enabled(struct clk *clk);
--
1.7.4.4


2012-11-15 18:24:55

by Jon Hunter

[permalink] [raw]
Subject: Re: [PATCH] Remove inline from clock framework function definitions to build the kernel with GCC 4.7


On 11/15/2012 11:07 AM, Igor Mazanov wrote:
> Remove inline from clock framework function definitions to
> build the kernel with GCC 4.7

Adding Mike to the party ...

May be good to add some details about the exact problem seen.

I am seeing the same problem today with GCC 4.7 and Tony's master
branch. For a bit of background it seems that for 4.7 not having
the body of the inlined function available in the header is
causing this error. Another example here [1].

The actual compiler error seen for OMAP is ...

In file included from arch/arm/mach-omap2/clockdomain.c:25:0:
arch/arm/mach-omap2/clockdomain.c: In function ‘clkdm_clk_disable’:
include/linux/clk-provider.h:338:12: error: inlining failed in call to always_inline ‘__clk_get_enable_count’: function body not available
arch/arm/mach-omap2/clockdomain.c:1001:28: error: called from here
make[1]: *** [arch/arm/mach-omap2/clockdomain.o] Error 1
make: *** [arch/arm/mach-omap2] Error 2


> Signed-off-by: Igor Mazanov <[email protected]>
> ---
> include/linux/clk-provider.h | 4 ++--
> 1 files changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/include/linux/clk-provider.h b/include/linux/clk-provider.h
> index c127315..f9f5e9e 100644
> --- a/include/linux/clk-provider.h
> +++ b/include/linux/clk-provider.h
> @@ -335,8 +335,8 @@ const char *__clk_get_name(struct clk *clk);
> struct clk_hw *__clk_get_hw(struct clk *clk);
> u8 __clk_get_num_parents(struct clk *clk);
> struct clk *__clk_get_parent(struct clk *clk);
> -inline int __clk_get_enable_count(struct clk *clk);
> -inline int __clk_get_prepare_count(struct clk *clk);
> +int __clk_get_enable_count(struct clk *clk);
> +int __clk_get_prepare_count(struct clk *clk);
> unsigned long __clk_get_rate(struct clk *clk);
> unsigned long __clk_get_flags(struct clk *clk);
> int __clk_is_enabled(struct clk *clk);

Do we also need to remove the inline from the functions declared in
drivers/clk/clk.c too?

Cheers
Jon

[1] https://bugs.launchpad.net/linaro-android/+bug/983496

2012-11-15 18:45:06

by Paul Walmsley

[permalink] [raw]
Subject: Re: [PATCH] Remove inline from clock framework function definitions to build the kernel with GCC 4.7

On Thu, 15 Nov 2012, Jon Hunter wrote:

>
> On 11/15/2012 11:07 AM, Igor Mazanov wrote:
> > Remove inline from clock framework function definitions to
> > build the kernel with GCC 4.7
>
> Adding Mike to the party ...
>
> May be good to add some details about the exact problem seen.
>
> I am seeing the same problem today with GCC 4.7 and Tony's master
> branch. For a bit of background it seems that for 4.7 not having
> the body of the inlined function available in the header is
> causing this error. Another example here [1].
>
> The actual compiler error seen for OMAP is ...
>
> In file included from arch/arm/mach-omap2/clockdomain.c:25:0:
> arch/arm/mach-omap2/clockdomain.c: In function ‘clkdm_clk_disable’:
> include/linux/clk-provider.h:338:12: error: inlining failed in call to always_inline ‘__clk_get_enable_count’: function body not available
> arch/arm/mach-omap2/clockdomain.c:1001:28: error: called from here
> make[1]: *** [arch/arm/mach-omap2/clockdomain.o] Error 1
> make: *** [arch/arm/mach-omap2] Error 2

Yep this one is for Mike to fix in the main CCF code; it's not an
OMAP-specific issue. sparse warns about this too, so it's not just a gcc
4.7 problem.

> Do we also need to remove the inline from the functions declared in
> drivers/clk/clk.c too?

It's usually best to just let the compiler decide whether to inline
functions. For example, Documentation/CodingStyle Chapter 15.


- Paul

2012-11-15 18:46:17

by Paul Walmsley

[permalink] [raw]
Subject: Re: [PATCH] Remove inline from clock framework function definitions to build the kernel with GCC 4.7

+ Mike

On Thu, 15 Nov 2012, Igor Mazanov wrote:

> Remove inline from clock framework function definitions to
> build the kernel with GCC 4.7

sparse warns about this also.

> Signed-off-by: Igor Mazanov <[email protected]>

This one is for Mike to deal with as CCF maintainer; it's out of the hands
of the OMAP folks.

Acked-by: Paul Walmsley <[email protected]>


> ---
> include/linux/clk-provider.h | 4 ++--
> 1 files changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/include/linux/clk-provider.h b/include/linux/clk-provider.h
> index c127315..f9f5e9e 100644
> --- a/include/linux/clk-provider.h
> +++ b/include/linux/clk-provider.h
> @@ -335,8 +335,8 @@ const char *__clk_get_name(struct clk *clk);
> struct clk_hw *__clk_get_hw(struct clk *clk);
> u8 __clk_get_num_parents(struct clk *clk);
> struct clk *__clk_get_parent(struct clk *clk);
> -inline int __clk_get_enable_count(struct clk *clk);
> -inline int __clk_get_prepare_count(struct clk *clk);
> +int __clk_get_enable_count(struct clk *clk);
> +int __clk_get_prepare_count(struct clk *clk);
> unsigned long __clk_get_rate(struct clk *clk);
> unsigned long __clk_get_flags(struct clk *clk);
> int __clk_is_enabled(struct clk *clk);
> --
> 1.7.4.4
>


- Paul

2012-11-16 17:15:29

by Igor Mazanov

[permalink] [raw]
Subject: Re: [PATCH] Remove inline from clock framework function definitions to build the kernel with GCC 4.7

Paul Walmsley wrote:
> + Mike
>
> On Thu, 15 Nov 2012, Igor Mazanov wrote:
>
>> Remove inline from clock framework function definitions to
>> build the kernel with GCC 4.7
>
> sparse warns about this also.
>
>> Signed-off-by: Igor Mazanov <[email protected]>
>
> This one is for Mike to deal with as CCF maintainer; it's out of the hands
> of the OMAP folks.

Thanks for comments, I'll bear in mind it for the future.

>
> Acked-by: Paul Walmsley <[email protected]>
>
>
>> ---
>> include/linux/clk-provider.h | 4 ++--
>> 1 files changed, 2 insertions(+), 2 deletions(-)
>>
>> diff --git a/include/linux/clk-provider.h b/include/linux/clk-provider.h
>> index c127315..f9f5e9e 100644
>> --- a/include/linux/clk-provider.h
>> +++ b/include/linux/clk-provider.h
>> @@ -335,8 +335,8 @@ const char *__clk_get_name(struct clk *clk);
>> struct clk_hw *__clk_get_hw(struct clk *clk);
>> u8 __clk_get_num_parents(struct clk *clk);
>> struct clk *__clk_get_parent(struct clk *clk);
>> -inline int __clk_get_enable_count(struct clk *clk);
>> -inline int __clk_get_prepare_count(struct clk *clk);
>> +int __clk_get_enable_count(struct clk *clk);
>> +int __clk_get_prepare_count(struct clk *clk);
>> unsigned long __clk_get_rate(struct clk *clk);
>> unsigned long __clk_get_flags(struct clk *clk);
>> int __clk_is_enabled(struct clk *clk);
>> --
>> 1.7.4.4
>>
>
>
> - Paul

2012-11-16 17:39:12

by Mike Turquette

[permalink] [raw]
Subject: Re: [PATCH] Remove inline from clock framework function definitions to build the kernel with GCC 4.7

Quoting Igor Mazanov (2012-11-16 09:16:02)
> Paul Walmsley wrote:
> > + Mike
> >
> > On Thu, 15 Nov 2012, Igor Mazanov wrote:
> >
> >> Remove inline from clock framework function definitions to
> >> build the kernel with GCC 4.7
> >
> > sparse warns about this also.
> >
> >> Signed-off-by: Igor Mazanov <[email protected]>
> >
> > This one is for Mike to deal with as CCF maintainer; it's out of the hands
> > of the OMAP folks.
>
> Thanks for comments, I'll bear in mind it for the future.
>

I forgot to reply to this thread yesterday. A fixes request has been
sent out, hopefully will be picked up for 3.7-rc6.

Thanks all,
Mike

> >
> > Acked-by: Paul Walmsley <[email protected]>
> >
> >
> >> ---
> >> include/linux/clk-provider.h | 4 ++--
> >> 1 files changed, 2 insertions(+), 2 deletions(-)
> >>
> >> diff --git a/include/linux/clk-provider.h b/include/linux/clk-provider.h
> >> index c127315..f9f5e9e 100644
> >> --- a/include/linux/clk-provider.h
> >> +++ b/include/linux/clk-provider.h
> >> @@ -335,8 +335,8 @@ const char *__clk_get_name(struct clk *clk);
> >> struct clk_hw *__clk_get_hw(struct clk *clk);
> >> u8 __clk_get_num_parents(struct clk *clk);
> >> struct clk *__clk_get_parent(struct clk *clk);
> >> -inline int __clk_get_enable_count(struct clk *clk);
> >> -inline int __clk_get_prepare_count(struct clk *clk);
> >> +int __clk_get_enable_count(struct clk *clk);
> >> +int __clk_get_prepare_count(struct clk *clk);
> >> unsigned long __clk_get_rate(struct clk *clk);
> >> unsigned long __clk_get_flags(struct clk *clk);
> >> int __clk_is_enabled(struct clk *clk);
> >> --
> >> 1.7.4.4
> >>
> >
> >
> > - Paul