Various C++ tests added in the gcc-15 cycle require features that are
only available when libstdc++-v3 is built in hosted mode, so they fail
when this is not the case. Skip them if ! hostedlib.
Regstrapped on x86_64-linux-gnu. Also tested with aarch64-elf and
arm-eabi with gcc-15. Ok to install?
for gcc/testsuite/ChangeLog
* g++.dg/DRs/dr2836.C: Skip if ! hostedlib.
* g++.dg/alias-checks.C: Likewise.
* g++.dg/contracts/pr116490.C: Likewise.
* g++.dg/coroutines/torture/pr121219.C: Likewise.
* g++.dg/cpp2a/constexpr-vector1.C: Likewise.
* g++.dg/ext/is_virtual_base_of.C: Likewise.
* g++.dg/modules/contracts-5_b.C: Likewise.
* g++.dg/modules/gmf-xtreme.C: Likewise.
* g++.dg/modules/lto-3_a.H: Likewise.
* g++.dg/modules/lto-3_b.C: Likewise.
* g++.dg/modules/xtreme-header-8.C: Likewise.
* g++.dg/opt/pr119274.C: Likewise.
* g++.dg/pr117222.C: Likewise.
* g++.dg/torture/pr105769-1.C: Likewise.
* g++.dg/torture/pr118521.C: Likewise.
* g++.dg/tree-ssa/deque-1.C: Likewise.
* g++.dg/tree-ssa/deque-2.C: Likewise.
* g++.dg/tree-ssa/pr109442.C: Likewise.
* g++.dg/tree-ssa/pr110819.C: Likewise.
* g++.dg/tree-ssa/pr116868.C: Likewise.
* g++.dg/tree-ssa/pr58483.C: Likewise.
* g++.dg/tree-ssa/pr80331.C: Likewise.
* g++.dg/tree-ssa/pr87502.C: Likewise.
* g++.dg/tree-ssa/pr96945.C: Likewise.
* g++.dg/tree-ssa/string-1.C: Likewise.
---
gcc/testsuite/g++.dg/DRs/dr2836.C | 1 +
gcc/testsuite/g++.dg/alias-checks.C | 1 +
gcc/testsuite/g++.dg/contracts/pr116490.C | 1 +
gcc/testsuite/g++.dg/coroutines/torture/pr121219.C | 1 +
gcc/testsuite/g++.dg/cpp2a/constexpr-vector1.C | 1 +
gcc/testsuite/g++.dg/ext/is_virtual_base_of.C | 2 ++
gcc/testsuite/g++.dg/modules/contracts-5_b.C | 1 +
gcc/testsuite/g++.dg/modules/gmf-xtreme.C | 1 +
gcc/testsuite/g++.dg/modules/lto-3_a.H | 1 +
gcc/testsuite/g++.dg/modules/lto-3_b.C | 1 +
gcc/testsuite/g++.dg/modules/xtreme-header-8.C | 1 +
gcc/testsuite/g++.dg/opt/pr119274.C | 1 +
gcc/testsuite/g++.dg/pr117222.C | 1 +
gcc/testsuite/g++.dg/torture/pr105769-1.C | 1 +
gcc/testsuite/g++.dg/torture/pr118521.C | 1 +
gcc/testsuite/g++.dg/tree-ssa/deque-1.C | 2 ++
gcc/testsuite/g++.dg/tree-ssa/deque-2.C | 2 ++
gcc/testsuite/g++.dg/tree-ssa/pr109442.C | 2 ++
gcc/testsuite/g++.dg/tree-ssa/pr110819.C | 2 ++
gcc/testsuite/g++.dg/tree-ssa/pr116868.C | 2 ++
gcc/testsuite/g++.dg/tree-ssa/pr58483.C | 2 ++
gcc/testsuite/g++.dg/tree-ssa/pr80331.C | 2 ++
gcc/testsuite/g++.dg/tree-ssa/pr87502.C | 2 ++
gcc/testsuite/g++.dg/tree-ssa/pr96945.C | 2 ++
gcc/testsuite/g++.dg/tree-ssa/string-1.C | 2 ++
25 files changed, 36 insertions(+)
diff --git a/gcc/testsuite/g++.dg/DRs/dr2836.C
b/gcc/testsuite/g++.dg/DRs/dr2836.C
index 88e35a7f30525..c96c6da919b5d 100644
--- a/gcc/testsuite/g++.dg/DRs/dr2836.C
+++ b/gcc/testsuite/g++.dg/DRs/dr2836.C
@@ -1,6 +1,7 @@
// DR 2836 - Conversion rank of long double and extended floating-point types
// { dg-do compile { target c++23 } }
// { dg-additional-options "-mlong-double-64" { target powerpc*-*-* s390*-*-*
} }
+// { dg-skip-if "required hosted libstdc++ for stdfloat" { ! hostedlib } }
#include <stdfloat>
diff --git a/gcc/testsuite/g++.dg/alias-checks.C
b/gcc/testsuite/g++.dg/alias-checks.C
index ee0ac535399d9..b8ff3ad605c23 100644
--- a/gcc/testsuite/g++.dg/alias-checks.C
+++ b/gcc/testsuite/g++.dg/alias-checks.C
@@ -3,6 +3,7 @@
// { dg-require-effective-target c++17 }
// { dg-require-effective-target vect_double }
// { dg-options "-O3 -fdump-tree-vect-all" }
+// { dg-skip-if "required hosted libstdc++ for cmath and iostream" { !
hostedlib } }
#include <cstdlib>
#include <cmath>
diff --git a/gcc/testsuite/g++.dg/contracts/pr116490.C
b/gcc/testsuite/g++.dg/contracts/pr116490.C
index e3a5d77bafd32..6e66c2afb6281 100644
--- a/gcc/testsuite/g++.dg/contracts/pr116490.C
+++ b/gcc/testsuite/g++.dg/contracts/pr116490.C
@@ -1,6 +1,7 @@
// ICE in explicit instantiation of a function with contracts
// { dg-do run }
// { dg-options "-std=c++20 -fcontracts -fcontract-continuation-mode=on" }
+// { dg-skip-if "required hosted libstdc++ for stdc++exp" { ! hostedlib } }
template<class T>
void foo(T t)
diff --git a/gcc/testsuite/g++.dg/coroutines/torture/pr121219.C
b/gcc/testsuite/g++.dg/coroutines/torture/pr121219.C
index d1e7cb1e02251..1748dcaf2be3b 100644
--- a/gcc/testsuite/g++.dg/coroutines/torture/pr121219.C
+++ b/gcc/testsuite/g++.dg/coroutines/torture/pr121219.C
@@ -1,5 +1,6 @@
// PR c++/121219
// { dg-do run }
+// { dg-skip-if "required hosted libstdc++ for stdexcept" { ! hostedlib } }
#include <coroutine>
#ifdef OUTPUT
diff --git a/gcc/testsuite/g++.dg/cpp2a/constexpr-vector1.C
b/gcc/testsuite/g++.dg/cpp2a/constexpr-vector1.C
index 196c6ec51fcf3..1d6a059615a9e 100644
--- a/gcc/testsuite/g++.dg/cpp2a/constexpr-vector1.C
+++ b/gcc/testsuite/g++.dg/cpp2a/constexpr-vector1.C
@@ -1,6 +1,7 @@
// PR c++/113835
// { dg-timeout-factor 0.05 }
// { dg-do compile { target c++20_only } }
+// { dg-skip-if "required hosted libstdc++ for vector" { ! hostedlib } }
#include <vector>
const std::size_t N = 1'000'000;
diff --git a/gcc/testsuite/g++.dg/ext/is_virtual_base_of.C
b/gcc/testsuite/g++.dg/ext/is_virtual_base_of.C
index 775a35393885b..1c3049d847a53 100644
--- a/gcc/testsuite/g++.dg/ext/is_virtual_base_of.C
+++ b/gcc/testsuite/g++.dg/ext/is_virtual_base_of.C
@@ -1,4 +1,6 @@
// { dg-do run }
+// { dg-skip-if "required hosted libstdc++ for cassert" { ! hostedlib } }
+
#include <cassert>
class A1
diff --git a/gcc/testsuite/g++.dg/modules/contracts-5_b.C
b/gcc/testsuite/g++.dg/modules/contracts-5_b.C
index 0e794b8ae4538..96651fd5c75d5 100644
--- a/gcc/testsuite/g++.dg/modules/contracts-5_b.C
+++ b/gcc/testsuite/g++.dg/modules/contracts-5_b.C
@@ -1,6 +1,7 @@
// PR c++/108205
// { dg-module-do run }
// { dg-additional-options "-fmodules -fcontracts
-fcontract-continuation-mode=on" }
+// { dg-skip-if "required hosted libstdc++ for experimental/contract" { !
hostedlib } }
#include <experimental/contract>
import test;
diff --git a/gcc/testsuite/g++.dg/modules/gmf-xtreme.C
b/gcc/testsuite/g++.dg/modules/gmf-xtreme.C
index 0a01c405291dd..a9bee60001ce3 100644
--- a/gcc/testsuite/g++.dg/modules/gmf-xtreme.C
+++ b/gcc/testsuite/g++.dg/modules/gmf-xtreme.C
@@ -1,6 +1,7 @@
// PR c++/114630
// { dg-additional-options "-fmodules-ts -fdump-lang-module" }
// { dg-module-cmi empty }
+// { dg-skip-if "required hosted libstdc++ for any in xtreme-header.h" { !
hostedlib } }
module;
#include "xtreme-header.h"
diff --git a/gcc/testsuite/g++.dg/modules/lto-3_a.H
b/gcc/testsuite/g++.dg/modules/lto-3_a.H
index be63699e66f5d..95fb738e91969 100644
--- a/gcc/testsuite/g++.dg/modules/lto-3_a.H
+++ b/gcc/testsuite/g++.dg/modules/lto-3_a.H
@@ -1,6 +1,7 @@
// PR c++/118961
// { dg-additional-options "-fmodule-header -std=c++20" }
// { dg-module-cmi {} }
+// { dg-skip-if "required hosted libstdc++ for string" { ! hostedlib } }
// We shouldn't ICE when linking against the standard library.
#include <string>
diff --git a/gcc/testsuite/g++.dg/modules/lto-3_b.C
b/gcc/testsuite/g++.dg/modules/lto-3_b.C
index f459596f730f2..6b5854f1f1c0f 100644
--- a/gcc/testsuite/g++.dg/modules/lto-3_b.C
+++ b/gcc/testsuite/g++.dg/modules/lto-3_b.C
@@ -2,6 +2,7 @@
// { dg-module-do link }
// { dg-require-effective-target lto }
// { dg-additional-options "-fmodules -flto -static -std=c++20" }
+// { dg-skip-if "required hosted libstdc++ for string in lto-3_a.H" { !
hostedlib } }
import "lto-3_a.H";
diff --git a/gcc/testsuite/g++.dg/modules/xtreme-header-8.C
b/gcc/testsuite/g++.dg/modules/xtreme-header-8.C
index 82c0b59fefe31..dc8ae240ffe15 100644
--- a/gcc/testsuite/g++.dg/modules/xtreme-header-8.C
+++ b/gcc/testsuite/g++.dg/modules/xtreme-header-8.C
@@ -1,6 +1,7 @@
// PR c++/115126
// { dg-additional-options "-fmodules-ts -Wtemplate-names-tu-local" }
// { dg-module-cmi xstd }
+// { dg-skip-if "required hosted libstdc++ for any in xtreme-header.h" { !
hostedlib } }
export module xstd;
extern "C++" {
diff --git a/gcc/testsuite/g++.dg/opt/pr119274.C
b/gcc/testsuite/g++.dg/opt/pr119274.C
index 79b406162db9a..75503d3683d7d 100644
--- a/gcc/testsuite/g++.dg/opt/pr119274.C
+++ b/gcc/testsuite/g++.dg/opt/pr119274.C
@@ -1,5 +1,6 @@
// { dg-do compile { target c++11 } }
// { dg-options "-O2 -Wall" }
+// { dg-skip-if "required hosted libstdc++ for vector" { ! hostedlib } }
#include <cstdlib>
#include <vector>
diff --git a/gcc/testsuite/g++.dg/pr117222.C b/gcc/testsuite/g++.dg/pr117222.C
index 60cf6e30ed540..70dc8a1eef17f 100644
--- a/gcc/testsuite/g++.dg/pr117222.C
+++ b/gcc/testsuite/g++.dg/pr117222.C
@@ -1,6 +1,7 @@
// { dg-do compile }
// { dg-require-effective-target c++11 }
// { dg-options "-O3 -fdump-tree-evrp" }
+// { dg-skip-if "required hosted libstdc++ for vector" { ! hostedlib } }
#include <vector>
int main()
diff --git a/gcc/testsuite/g++.dg/torture/pr105769-1.C
b/gcc/testsuite/g++.dg/torture/pr105769-1.C
index 3fe973656b845..d176bdccf479d 100644
--- a/gcc/testsuite/g++.dg/torture/pr105769-1.C
+++ b/gcc/testsuite/g++.dg/torture/pr105769-1.C
@@ -1,4 +1,5 @@
// { dg-do run }
+// { dg-skip-if "required hosted libstdc++ for functional function" { !
hostedlib } }
// PR tree-optimization/105769
diff --git a/gcc/testsuite/g++.dg/torture/pr118521.C
b/gcc/testsuite/g++.dg/torture/pr118521.C
index 08836bd5f0e91..e432f99220dc4 100644
--- a/gcc/testsuite/g++.dg/torture/pr118521.C
+++ b/gcc/testsuite/g++.dg/torture/pr118521.C
@@ -1,5 +1,6 @@
// { dg-do compile }
// { dg-additional-options "-Wall" }
+// { dg-skip-if "required hosted libstdc++ for vector" { ! hostedlib } }
#include <vector> // { dg-bogus "writing 1 byte into a region of size 0" "" {
target *-*-* } 0 }
diff --git a/gcc/testsuite/g++.dg/tree-ssa/deque-1.C
b/gcc/testsuite/g++.dg/tree-ssa/deque-1.C
index c639ebb1a5f34..04b1dbb9c8aae 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/deque-1.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/deque-1.C
@@ -1,5 +1,7 @@
// { dg-do compile }
// { dg-options "-O1 -fdump-tree-optimized" }
+// { dg-skip-if "required hosted libstdc++ for deque" { ! hostedlib } }
+
#include <deque>
void
test(std::deque<int> &q, int v)
diff --git a/gcc/testsuite/g++.dg/tree-ssa/deque-2.C
b/gcc/testsuite/g++.dg/tree-ssa/deque-2.C
index 7e268b3f018d6..c1534f65b80a1 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/deque-2.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/deque-2.C
@@ -1,5 +1,7 @@
// { dg-do compile }
// { dg-options "-O3 -fdump-tree-optimized" }
+// { dg-skip-if "required hosted libstdc++ for deque" { ! hostedlib } }
+
#include <deque>
std::deque<int *>
test2(std::deque<int *> &q)
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr109442.C
b/gcc/testsuite/g++.dg/tree-ssa/pr109442.C
index dc335d1365673..6753bb947e929 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/pr109442.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr109442.C
@@ -1,5 +1,7 @@
// { dg-do compile { target c++11 } }
// { dg-options "-O2 -fdump-tree-optimized" }
+// { dg-skip-if "required hosted libstdc++ for vector" { ! hostedlib } }
+
#include <vector>
#define T int
T vat1(std::vector<T> v1) {
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr110819.C
b/gcc/testsuite/g++.dg/tree-ssa/pr110819.C
index 8305589a19d0b..90bbe916f63be 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/pr110819.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr110819.C
@@ -1,5 +1,7 @@
// { dg-do compile { target c++11 } }
// { dg-options "-O1 -fdump-tree-optimized" }
+// { dg-skip-if "required hosted libstdc++ for vector" { ! hostedlib } }
+
#include<vector>
void f(int);
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr116868.C
b/gcc/testsuite/g++.dg/tree-ssa/pr116868.C
index 8580661d35ce9..55337b2219b8e 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/pr116868.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr116868.C
@@ -1,5 +1,7 @@
// { dg-do compile { target c++11 } }
// { dg-options "-O2 -fdump-tree-optimized" }
+// { dg-skip-if "required hosted libstdc++ for vector" { ! hostedlib } }
+
#include <vector>
int sumVector() {
const std::vector<int> vec = {1};
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr58483.C
b/gcc/testsuite/g++.dg/tree-ssa/pr58483.C
index 8305589a19d0b..90bbe916f63be 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/pr58483.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr58483.C
@@ -1,5 +1,7 @@
// { dg-do compile { target c++11 } }
// { dg-options "-O1 -fdump-tree-optimized" }
+// { dg-skip-if "required hosted libstdc++ for vector" { ! hostedlib } }
+
#include<vector>
void f(int);
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr80331.C
b/gcc/testsuite/g++.dg/tree-ssa/pr80331.C
index 85034504f2f82..fd556ed7407da 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/pr80331.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr80331.C
@@ -1,5 +1,7 @@
// { dg-do compile }
// { dg-additional-options "-O2 -fdump-tree-optimized" }
+// { dg-skip-if "required hosted libstdc++ for string" { ! hostedlib } }
+
#include<string>
int sain() {
const std::string remove_me("remove_me");
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr87502.C
b/gcc/testsuite/g++.dg/tree-ssa/pr87502.C
index e8e0cd388fb03..8b4b5d8c78fb9 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/pr87502.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr87502.C
@@ -1,5 +1,7 @@
// { dg-do compile }
// { dg-additional-options "-O2 -fdump-tree-optimized" }
+// { dg-skip-if "required hosted libstdc++ for string" { ! hostedlib } }
+
#include <string>
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr96945.C
b/gcc/testsuite/g++.dg/tree-ssa/pr96945.C
index 07c141340c0b1..e4ea022d66560 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/pr96945.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr96945.C
@@ -1,5 +1,7 @@
// { dg-do compile { target c++11 } }
// { dg-options "-O1 -fdump-tree-optimized" }
+// { dg-skip-if "required hosted libstdc++ for vector" { ! hostedlib } }
+
#include <vector>
struct c {
c() = default;
diff --git a/gcc/testsuite/g++.dg/tree-ssa/string-1.C
b/gcc/testsuite/g++.dg/tree-ssa/string-1.C
index d38c23a7628b6..ff65bad97717b 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/string-1.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/string-1.C
@@ -1,5 +1,7 @@
/* { dg-do compile } */
/* { dg-options "-O3 -std=c++20 -fdump-tree-optimized" } */
+// { dg-skip-if "required hosted libstdc++ for string" { ! hostedlib } }
+
#include <string>
std::string
test (std::string &a)
--
Alexandre Oliva, happy hacker https://blog.lx.oliva.nom.br/
Free Software Activist FSFLA co-founder GNU Toolchain Engineer
More tolerance and less prejudice are key for inclusion and diversity.
Excluding neuro-others for not behaving ""normal"" is *not* inclusive!