* [PATCH] rs6000/test: Fix empty TU in some cases of effective targets
@ 2022-07-20 9:32 Kewen.Lin
2022-07-21 22:09 ` Segher Boessenkool
0 siblings, 1 reply; 5+ messages in thread
From: Kewen.Lin @ 2022-07-20 9:32 UTC (permalink / raw)
To: GCC Patches; +Cc: Segher Boessenkool, David Edelsohn, Peter Bergner
Hi,
As the failure of test case gcc.target/powerpc/pr92398.p9-.c in
PR106345 shows, some test sources for some powerpc effective
targets use empty translation unit wrongly. The test sources
could go with options like "-ansi -pedantic-errors", then those
effective target checkings will fail unexpectedly with the
error messages like:
error: ISO C forbids an empty translation unit [-Wpedantic]
This patch is to fix empty TUs with one dummy variable definition
accordingly.
Tested on powerpc64-linux-gnu P7 and P8 and
powerpc64le-linux-gnu P9 and P10. Excepting for the failures
on gcc.target/powerpc/pr92398.p9-.c fixed, I can see it helps to
bring back some testing coverage like:
NA->PASS: gcc.target/powerpc/pr92398.p9+.c
NA->PASS: gcc.target/powerpc/pr93453-1.c
I'll push this soon if no objections.
BR,
Kewen
-----
PR testsuite/106345
gcc/testsuite/ChangeLog:
* lib/target-supports.exp (check_effective_target_powerpc_sqrt): Add
a variable definition to avoid pedwarn about empty translation unit.
(check_effective_target_has_arch_pwr5): Likewise.
(check_effective_target_has_arch_pwr6): Likewise.
(check_effective_target_has_arch_pwr7): Likewise.
(check_effective_target_has_arch_pwr8): Likewise.
(check_effective_target_has_arch_pwr9): Likewise.
(check_effective_target_has_arch_pwr10): Likewise.
(check_effective_target_has_arch_ppc64): Likewise.
(check_effective_target_ppc_float128): Likewise.
(check_effective_target_ppc_float128_insns): Likewise.
(check_effective_target_powerpc_vsx): Likewise.
---
gcc/testsuite/lib/target-supports.exp | 11 +++++++++++
1 file changed, 11 insertions(+)
diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp
index 4ed7b25b9a4..aac2a557f5d 100644
--- a/gcc/testsuite/lib/target-supports.exp
+++ b/gcc/testsuite/lib/target-supports.exp
@@ -6262,6 +6262,7 @@ proc check_effective_target_powerpc_sqrt { } {
#ifndef _ARCH_PPCSQ
#error _ARCH_PPCSQ is not defined
#endif
+ int dummy;
} {}]
}
@@ -6373,6 +6374,7 @@ proc check_effective_target_has_arch_pwr5 { } {
#error does not have power5 support.
#else
/* "has power5 support" */
+ int dummy;
#endif
} [current_compiler_flags]]
}
@@ -6383,6 +6385,7 @@ proc check_effective_target_has_arch_pwr6 { } {
#error does not have power6 support.
#else
/* "has power6 support" */
+ int dummy;
#endif
} [current_compiler_flags]]
}
@@ -6393,6 +6396,7 @@ proc check_effective_target_has_arch_pwr7 { } {
#error does not have power7 support.
#else
/* "has power7 support" */
+ int dummy;
#endif
} [current_compiler_flags]]
}
@@ -6403,6 +6407,7 @@ proc check_effective_target_has_arch_pwr8 { } {
#error does not have power8 support.
#else
/* "has power8 support" */
+ int dummy;
#endif
} [current_compiler_flags]]
}
@@ -6413,6 +6418,7 @@ proc check_effective_target_has_arch_pwr9 { } {
#error does not have power9 support.
#else
/* "has power9 support" */
+ int dummy;
#endif
} [current_compiler_flags]]
}
@@ -6423,6 +6429,7 @@ proc check_effective_target_has_arch_pwr10 { } {
#error does not have power10 support.
#else
/* "has power10 support" */
+ int dummy;
#endif
} [current_compiler_flags]]
}
@@ -6433,6 +6440,7 @@ proc check_effective_target_has_arch_ppc64 { } {
#error does not have ppc64 support.
#else
/* "has ppc64 support" */
+ int dummy;
#endif
} [current_compiler_flags]]
}
@@ -6523,6 +6531,7 @@ proc check_effective_target_ppc_float128 { } {
#ifndef __FLOAT128__
nope no good
#endif
+ int dummy;
}]
}
@@ -6533,6 +6542,7 @@ proc check_effective_target_ppc_float128_insns { } {
#ifndef __FLOAT128_HARDWARE__
nope no good
#endif
+ int dummy;
}]
}
@@ -6543,6 +6553,7 @@ proc check_effective_target_powerpc_vsx { } {
#ifndef __VSX__
nope no vsx
#endif
+ int dummy;
}]
}
--
2.27.0
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] rs6000/test: Fix empty TU in some cases of effective targets
2022-07-20 9:32 [PATCH] rs6000/test: Fix empty TU in some cases of effective targets Kewen.Lin
@ 2022-07-21 22:09 ` Segher Boessenkool
2022-07-22 0:41 ` Kewen.Lin
0 siblings, 1 reply; 5+ messages in thread
From: Segher Boessenkool @ 2022-07-21 22:09 UTC (permalink / raw)
To: Kewen.Lin; +Cc: GCC Patches, David Edelsohn, Peter Bergner
On Wed, Jul 20, 2022 at 05:32:01PM +0800, Kewen.Lin wrote:
> As the failure of test case gcc.target/powerpc/pr92398.p9-.c in
> PR106345 shows, some test sources for some powerpc effective
> targets use empty translation unit wrongly. The test sources
> could go with options like "-ansi -pedantic-errors", then those
> effective target checkings will fail unexpectedly with the
> error messages like:
>
> error: ISO C forbids an empty translation unit [-Wpedantic]
>
> This patch is to fix empty TUs with one dummy variable definition
> accordingly.
You can also use
enum{a};
which is shorter, but more importantly does not generate any code.
You can also do
extern int dummy;
of course -- same idea, no definitions, only declarations.
> I'll push this soon if no objections.
> @@ -6523,6 +6531,7 @@ proc check_effective_target_ppc_float128 { } {
> #ifndef __FLOAT128__
> nope no good
> #endif
> + int dummy;
At least put it in #else then? Or just do things a bit more elegantly
(do a dummy function around this for example).
Segher
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] rs6000/test: Fix empty TU in some cases of effective targets
2022-07-21 22:09 ` Segher Boessenkool
@ 2022-07-22 0:41 ` Kewen.Lin
2022-07-22 1:02 ` Segher Boessenkool
0 siblings, 1 reply; 5+ messages in thread
From: Kewen.Lin @ 2022-07-22 0:41 UTC (permalink / raw)
To: Segher Boessenkool; +Cc: GCC Patches, David Edelsohn, Peter Bergner
Hi Segher,
Thanks for the comments!
on 2022/7/22 06:09, Segher Boessenkool wrote:
> On Wed, Jul 20, 2022 at 05:32:01PM +0800, Kewen.Lin wrote:
>> As the failure of test case gcc.target/powerpc/pr92398.p9-.c in
>> PR106345 shows, some test sources for some powerpc effective
>> targets use empty translation unit wrongly. The test sources
>> could go with options like "-ansi -pedantic-errors", then those
>> effective target checkings will fail unexpectedly with the
>> error messages like:
>>
>> error: ISO C forbids an empty translation unit [-Wpedantic]
>>
>> This patch is to fix empty TUs with one dummy variable definition
>> accordingly.
>
> You can also use
> enum{a};
> which is shorter, but more importantly does not generate any code.
> You can also do
> extern int dummy;
> of course -- same idea, no definitions, only declarations.
>
The used "int dummy" follows some existing practices, IMHO in this
context it doesn't matter that it will generate code or not, any of
these alternatives still generates an assembly or object file, but
the generated file gets removed after the checking.
May I still keep this "int dummy" to align with existing practices?
>> I'll push this soon if no objections.
>
>> @@ -6523,6 +6531,7 @@ proc check_effective_target_ppc_float128 { } {
>> #ifndef __FLOAT128__
>> nope no good
>> #endif
>> + int dummy;
>
> At least put it in #else then? Or just do things a bit more elegantly
> (do a dummy function around this for example).
>
OK, since it can still emit error even without "#else", I didn't bother
to add it. I will add it, and update the "nope no good" to "#error
doesn't have float128 support".
BR,
Kewen
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] rs6000/test: Fix empty TU in some cases of effective targets
2022-07-22 0:41 ` Kewen.Lin
@ 2022-07-22 1:02 ` Segher Boessenkool
2022-07-22 1:26 ` Kewen.Lin
0 siblings, 1 reply; 5+ messages in thread
From: Segher Boessenkool @ 2022-07-22 1:02 UTC (permalink / raw)
To: Kewen.Lin; +Cc: GCC Patches, David Edelsohn, Peter Bergner
Hi!
On Fri, Jul 22, 2022 at 08:41:43AM +0800, Kewen.Lin wrote:
> Hi Segher,
>
> Thanks for the comments!
Always.
> >> This patch is to fix empty TUs with one dummy variable definition
> >> accordingly.
> >
> > You can also use
> > enum{a};
> > which is shorter, but more importantly does not generate any code.
> > You can also do
> > extern int dummy;
> > of course -- same idea, no definitions, only declarations.
>
> The used "int dummy" follows some existing practices, IMHO in this
> context it doesn't matter that it will generate code or not, any of
> these alternatives still generates an assembly or object file, but
> the generated file gets removed after the checking.
It doesn't matter here, sure. But it is certainly simple enough to make
it "extern int dummy" instead, not giving a bad example for future cases
where it may matter :-)
> May I still keep this "int dummy" to align with existing practices?
Of course, it was just advice. If things are wrong (in my opinion that
is!), I'll say so.
> > At least put it in #else then? Or just do things a bit more elegantly
> > (do a dummy function around this for example).
>
> OK, since it can still emit error even without "#else", I didn't bother
> to add it. I will add it, and update the "nope no good" to "#error
> doesn't have float128 support".
Just say
===
void nope (void)
{
#ifndef __FLOAT128__
nope no good
#endif
}
===
which works in all cases?
Less maintenance is a good thing :-)
Segher
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] rs6000/test: Fix empty TU in some cases of effective targets
2022-07-22 1:02 ` Segher Boessenkool
@ 2022-07-22 1:26 ` Kewen.Lin
0 siblings, 0 replies; 5+ messages in thread
From: Kewen.Lin @ 2022-07-22 1:26 UTC (permalink / raw)
To: Segher Boessenkool; +Cc: GCC Patches, David Edelsohn, Peter Bergner
Hi!
on 2022/7/22 09:02, Segher Boessenkool wrote:
> Hi!
>
> On Fri, Jul 22, 2022 at 08:41:43AM +0800, Kewen.Lin wrote:
>> Hi Segher,
>>
>> Thanks for the comments!
>
> Always.
>
>>>> This patch is to fix empty TUs with one dummy variable definition
>>>> accordingly.
>>>
>>> You can also use
>>> enum{a};
>>> which is shorter, but more importantly does not generate any code.
>>> You can also do
>>> extern int dummy;
>>> of course -- same idea, no definitions, only declarations.
>>
>> The used "int dummy" follows some existing practices, IMHO in this
>> context it doesn't matter that it will generate code or not, any of
>> these alternatives still generates an assembly or object file, but
>> the generated file gets removed after the checking.
>
> It doesn't matter here, sure. But it is certainly simple enough to make
> it "extern int dummy" instead, not giving a bad example for future cases
> where it may matter :-)
>
OK.
>> May I still keep this "int dummy" to align with existing practices?
>
> Of course, it was just advice. If things are wrong (in my opinion that
> is!), I'll say so.
>
Got it, thanks! :)
>>> At least put it in #else then? Or just do things a bit more elegantly
>>> (do a dummy function around this for example).
>>
>> OK, since it can still emit error even without "#else", I didn't bother
>> to add it. I will add it, and update the "nope no good" to "#error
>> doesn't have float128 support".
>
> Just say
>
> ===
> void nope (void)
> {
> #ifndef __FLOAT128__
> nope no good
> #endif
> }
> ===
>
> which works in all cases?
Yeah, good idea, I'll make a new version of patch based on this.
Thanks again!
BR,
Kewen
>
> Less maintenance is a good thing :-)
>
>
> Segher
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2022-07-22 1:26 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-07-20 9:32 [PATCH] rs6000/test: Fix empty TU in some cases of effective targets Kewen.Lin
2022-07-21 22:09 ` Segher Boessenkool
2022-07-22 0:41 ` Kewen.Lin
2022-07-22 1:02 ` Segher Boessenkool
2022-07-22 1:26 ` Kewen.Lin
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).