On Mar 24, 2021, Uros Bizjak <ubiz...@gmail.com> wrote:

> Other than above, can you please introduce
> check_effectve_target_sysconf to lib/target-supports.exp (similar to
> existing check_effective_target_mmap) and use it instead of target
> selectors?

Here it is.  I've tested the affected tests with it.  I'll give it a
full regstrap cycle, along with other patches.  Ok to install if it
passes?


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/testsuite/ChangeLog

        * lib/target-supports.exp (check_effective_target_sysconf): New.
        * gcc/doc/sourcebuild.texi (syconf): Document it.
        * 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.
---
 gcc/doc/sourcebuild.texi                          |    3 +++
 gcc/testsuite/gcc.target/i386/pr95443-1.c         |    2 +-
 gcc/testsuite/gcc.target/i386/pr95443-2.c         |    2 +-
 gcc/testsuite/gcc.target/i386/sse2-mmx-maskmovq.c |    2 +-
 gcc/testsuite/gcc.target/i386/strncmp-1.c         |    2 +-
 gcc/testsuite/lib/target-supports.exp             |    6 ++++++
 6 files changed, 13 insertions(+), 4 deletions(-)

diff --git a/gcc/doc/sourcebuild.texi b/gcc/doc/sourcebuild.texi
index 2bc362be4495d..0104916e66031 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 698dfa0218968..d846fcbda0a2e 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 <stdint.h>
diff --git a/gcc/testsuite/gcc.target/i386/pr95443-2.c 
b/gcc/testsuite/gcc.target/i386/pr95443-2.c
index 23bb13ab7ff11..2ab260608bc26 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 <stdint.h>
diff --git a/gcc/testsuite/gcc.target/i386/sse2-mmx-maskmovq.c 
b/gcc/testsuite/gcc.target/i386/sse2-mmx-maskmovq.c
index 037f665f1178a..87705be3f70d7 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 044fc5cc5fa1b..1ea3e0a57c1de 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 <stdio.h>
diff --git a/gcc/testsuite/lib/target-supports.exp 
b/gcc/testsuite/lib/target-supports.exp
index 733b6c8451851..1230d19421544 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 {


-- 
Alexandre Oliva, happy hacker  https://FSFLA.org/blogs/lxo/
   Free Software Activist         GNU Toolchain Engineer
        Vim, Vi, Voltei pro Emacs -- GNUlius Caesar

Reply via email to