]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
testsuite: Use -fno-ipa-icf in gcc.dg/stack-check-2.c
authorJoseph Myers <josmyers@redhat.com>
Thu, 24 Oct 2024 19:41:26 +0000 (19:41 +0000)
committerJoseph Myers <josmyers@redhat.com>
Thu, 24 Oct 2024 19:41:26 +0000 (19:41 +0000)
One test failing with a -std=gnu23 default that I wanted to
investigate further is gcc.dg/stack-check-2.c.  The failures are

FAIL: gcc.dg/stack-check-2.c scan-tree-dump-not optimized "tail call"
FAIL: gcc.dg/stack-check-2.c scan-tree-dump-not tailc "tail call"

but it turns out the tail calls in question are not the ones that test
is actually checking for.  Rather, when () is interpreted as (void) in
C23 mode, ICF notices that certain functions are identical and so
turns test_indirect_2 into a tail call to text_indirect_1 and
test_indirect_casted_2 into a tail call to test_indirect_casted_1
(which it didn't do previously when one function used () and one used
(void)).

To avoid these spurious failures, make the test use -fno-ipa-icf
rather than relying on () and (void) giving different function types
to avoid ICF.

Tested for x86_64-pc-linux-gnu.

* gcc.dg/stack-check-2.c: Use -fno-ipa-icf.

gcc/testsuite/gcc.dg/stack-check-2.c

index 196c4bbfbdda19ff40030e1283cb02b75d3e2b06..a821c0ef8657e0c21399b43413fee12323a37056 100644 (file)
@@ -12,7 +12,7 @@
    depend on to elide stack probes.  */
 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fstack-clash-protection -fdump-tree-tailc -fdump-tree-optimized" } */
+/* { dg-options "-O2 -fstack-clash-protection -fdump-tree-tailc -fdump-tree-optimized -fno-ipa-icf" } */
 /* { dg-require-effective-target supports_stack_clash_protection } */
 
 extern void foo (void) __attribute__ ((__noreturn__));