From: Alexandre Oliva Date: Wed, 24 Mar 2021 08:50:37 +0000 (-0300) Subject: run sysconf-requiring test on systems that support it X-Git-Tag: basepoints/gcc-12~444 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=65cfa2fed39c76498e7c3dfe138bddb049d60dd7;p=thirdparty%2Fgcc.git run sysconf-requiring test on systems that support it Some gcc.target/i386 tests requires the mmap feature, but that's not enough for the test to be able to call sysconf. This patch introduces a sysconf feature, analogous to mmap, and adds it to tests in gcc.target/i386 that call sysconf. There are other tests within gcc.dg and g++.dg that call sysconf, but I haven't added the tag to them, because they already cover it with target triplets. I was a little nervous about dropping the triplets, and saw how they implied sysconf, so I left those alone. for gcc/ChangeLog * doc/sourcebuild.texi (sysconf): New effective target. for gcc/testsuite/ChangeLog * lib/target-supports.exp (check_effective_target_sysconf): New. * gcc.target/i386/pr95443-1.c: Require it. * gcc.target/i386/pr95443-2.c: Likewise. * gcc.target/i386/sse2-mmx-maskmovq.c: Likewise. * gcc.target/i386/strncmp-1.c: Likewise. --- diff --git a/gcc/doc/sourcebuild.texi b/gcc/doc/sourcebuild.texi index 2bc362be4495..0104916e6603 100644 --- a/gcc/doc/sourcebuild.texi +++ b/gcc/doc/sourcebuild.texi @@ -2450,6 +2450,9 @@ all targets. @item stpcpy Target provides @code{stpcpy} function. +@item sysconf +Target supports @code{sysconf}. + @item trampolines Target supports trampolines. diff --git a/gcc/testsuite/gcc.target/i386/pr95443-1.c b/gcc/testsuite/gcc.target/i386/pr95443-1.c index 698dfa021896..d846fcbda0a2 100644 --- a/gcc/testsuite/gcc.target/i386/pr95443-1.c +++ b/gcc/testsuite/gcc.target/i386/pr95443-1.c @@ -1,4 +1,4 @@ -/* { dg-do run { target mmap } } */ +/* { dg-do run { target { sysconf && mmap } } } */ /* { dg-options "-O2 -minline-all-stringops" } */ #include diff --git a/gcc/testsuite/gcc.target/i386/pr95443-2.c b/gcc/testsuite/gcc.target/i386/pr95443-2.c index 23bb13ab7ff1..2ab260608bc2 100644 --- a/gcc/testsuite/gcc.target/i386/pr95443-2.c +++ b/gcc/testsuite/gcc.target/i386/pr95443-2.c @@ -1,4 +1,4 @@ -/* { dg-do run { target mmap } } */ +/* { dg-do run { target { sysconf && mmap } } } */ /* { dg-options "-O2 -minline-all-stringops" } */ #include diff --git a/gcc/testsuite/gcc.target/i386/sse2-mmx-maskmovq.c b/gcc/testsuite/gcc.target/i386/sse2-mmx-maskmovq.c index 037f665f1178..87705be3f70d 100644 --- a/gcc/testsuite/gcc.target/i386/sse2-mmx-maskmovq.c +++ b/gcc/testsuite/gcc.target/i386/sse2-mmx-maskmovq.c @@ -1,4 +1,4 @@ -/* { dg-do run { target mmap } } */ +/* { dg-do run { target { sysconf && mmap } } } */ /* { dg-options "-O2 -fno-strict-aliasing -msse2" } */ /* { dg-additional-options "-mno-mmx" { target { ! ia32 } } } */ diff --git a/gcc/testsuite/gcc.target/i386/strncmp-1.c b/gcc/testsuite/gcc.target/i386/strncmp-1.c index 044fc5cc5fa1..1ea3e0a57c1d 100644 --- a/gcc/testsuite/gcc.target/i386/strncmp-1.c +++ b/gcc/testsuite/gcc.target/i386/strncmp-1.c @@ -1,4 +1,4 @@ -/* { dg-do run { target mmap } } */ +/* { dg-do run { target { sysconf && mmap } } } */ /* { dg-options "-O2" } */ #include diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp index 733b6c845185..1230d1942154 100644 --- a/gcc/testsuite/lib/target-supports.exp +++ b/gcc/testsuite/lib/target-supports.exp @@ -1067,6 +1067,12 @@ proc check_effective_target_mmap {} { return [check_function_available "mmap"] } +# Return 1 if the target supports sysconf, 0 otherwise. + +proc check_effective_target_sysconf {} { + return [check_function_available "sysconf"] +} + # Return 1 if the target supports dlopen, 0 otherwise. proc check_effective_target_dlopen {} { return [check_no_compiler_messages dlopen executable {