diff options
author | Duo Wang <duow1@uci.edu> | 2024-01-05 01:59:26 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-01-05 09:59:26 +0000 |
commit | c458f928fad7bbcf08ab1da9949eb2969fc9f89c (patch) | |
tree | 1f8f1f0fb708ec1bc1f574e5f03e4c4c8c0569b5 | |
parent | 0eefcaf96d2900a4f3009026a3673ed3b7793fcc (diff) | |
download | llvm-c458f928fad7bbcf08ab1da9949eb2969fc9f89c.zip llvm-c458f928fad7bbcf08ab1da9949eb2969fc9f89c.tar.gz llvm-c458f928fad7bbcf08ab1da9949eb2969fc9f89c.tar.bz2 |
[NFC][clang][test][asan] Make `instantiation-depth-default.cpp` a valid test case under `asan` and `ubsan` configs (#75254)
Clang test `instantiation-depth-default.cpp` fails on Windows when built
with `ubsan` due to extra warnings printed by the compiler:
```console
File instantiation-depth-default.cpp Line 11: stack nearly exhausted; compilation time may suffer, and crashes due to stack overflow are likely
```
The test case was disabled for `asan` in 571a647 because of the extra
stack usage. Since `ubsan` also increases stack usage, seems like the
two configs should be treated uniformly.
On the other hand, we might be able to re-enable this test case for
`asan`. During some preliminary testing on Windows, Linux, and macOS
with the host compiler being as old as clang-10, the test case exited
successfully if the `stack-exhausted` warnings are suppressed, though I
haven't done exhaustive testing across platforms and clang versions. Any
insights into whether this change will introduce any risks to existing
buildbots is appreciated.
Enabling this test case for `asan` helps to improve our test coverage,
but if it causes problems on any buildbot, marking it as unsupported for
`ubsan` is also a viable solution.
-rw-r--r-- | clang/test/SemaTemplate/instantiation-depth-default.cpp | 16 |
1 files changed, 5 insertions, 11 deletions
diff --git a/clang/test/SemaTemplate/instantiation-depth-default.cpp b/clang/test/SemaTemplate/instantiation-depth-default.cpp index f5835b8..430d042 100644 --- a/clang/test/SemaTemplate/instantiation-depth-default.cpp +++ b/clang/test/SemaTemplate/instantiation-depth-default.cpp @@ -1,18 +1,12 @@ -// RUN: %clang_cc1 -fsyntax-only -verify -ftemplate-backtrace-limit=2 %s -// -// FIXME: Disable this test when Clang was built with ASan, because ASan -// increases our per-frame stack usage enough that this test no longer fits -// within our normal stack space allocation. -// UNSUPPORTED: asan -// +// RUN: %clang_cc1 -fsyntax-only -verify -ftemplate-backtrace-limit=2 %if {{asan|ubsan}} %{ -Wno-stack-exhausted %} %s // The default stack size on NetBSD is too small for this test. // UNSUPPORTED: system-netbsd template<int N, typename T> struct X : X<N+1, T*> {}; -// expected-error-re@11 {{recursive template instantiation exceeded maximum depth of 1024{{$}}}} -// expected-note@11 {{instantiation of template class}} -// expected-note@11 {{skipping 1023 contexts in backtrace}} -// expected-note@11 {{use -ftemplate-depth=N to increase recursive template instantiation depth}} +// expected-error-re@5 {{recursive template instantiation exceeded maximum depth of 1024{{$}}}} +// expected-note@5 {{instantiation of template class}} +// expected-note@5 {{skipping 1023 contexts in backtrace}} +// expected-note@5 {{use -ftemplate-depth=N to increase recursive template instantiation depth}} X<0, int> x; // expected-note {{in instantiation of}} |