testsuite: Introduce be/le selectors
authorSegher Boessenkool <segher@kernel.crashing.org>
Wed, 23 May 2018 17:31:05 +0000 (19:31 +0200)
committerSegher Boessenkool <segher@gcc.gnu.org>
Wed, 23 May 2018 17:31:05 +0000 (19:31 +0200)
This patch creates "be" and "le" selectors, which can be used by all
architectures, similar to ilp32 and lp64.

* doc/sourcebuild.texi (Endianness): New subsubsection.

gcc/testsuite/
* lib/target-supports.exp (check_effective_target_be): New.
(check_effective_target_le): New.

From-SVN: r260623

gcc/ChangeLog
gcc/doc/sourcebuild.texi
gcc/testsuite/ChangeLog
gcc/testsuite/lib/target-supports.exp

index 38b26b1..555a0f7 100644 (file)
@@ -1,3 +1,7 @@
+2017-05-23  Segher Boessenkool  <segher@kernel.crashing.org>
+
+       * doc/sourcebuild.texi (Endianness): New subsubsection.
+
 2018-05-23  Luis Machado  <luis.machado@linaro.org>
 
        * config/aarch64/aarch64-protos.h (cpu_prefetch_tune)
index dfb0578..596007d 100644 (file)
@@ -1313,6 +1313,16 @@ By convention, keywords ending in @code{_nocache} can also include options
 specified for the particular test in an earlier @code{dg-options} or
 @code{dg-add-options} directive.
 
+@subsubsection Endianness
+
+@table @code
+@item be
+Target uses big-endian memory order for multi-byte and multi-word data.
+
+@item le
+Target uses little-endian memory order for multi-byte and multi-word data.
+@end table
+
 @subsubsection Data type sizes
 
 @table @code
index db9ae1d..e9b35d5 100644 (file)
@@ -1,3 +1,8 @@
+2017-05-23  Segher Boessenkool  <segher@kernel.crashing.org>
+
+       * lib/target-supports.exp (check_effective_target_be): New.
+       (check_effective_target_le): New.
+
 2018-05-23  Marek Polacek  <polacek@redhat.com>
 
        * g++.dg/cpp2a/range-for1.C: New test.
index aa1296e..0a53d7b 100644 (file)
@@ -2523,6 +2523,22 @@ proc check_effective_target_next_runtime { } {
     }]
 }
 
+# Return 1 if we're generating code for big-endian memory order.
+
+proc check_effective_target_be { } {
+    return [check_no_compiler_messages be object {
+       int dummy[__BYTE_ORDER__ == __ORDER_BIG_ENDIAN__ ? 1 : -1];
+    }]
+}
+
+# Return 1 if we're generating code for little-endian memory order.
+
+proc check_effective_target_le { } {
+    return [check_no_compiler_messages le object {
+       int dummy[__BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__ ? 1 : -1];
+    }]
+}
+
 # Return 1 if we're generating 32-bit code using default options, 0
 # otherwise.