Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[flang] fatal internal error: CHECK(GetRank(*shape) == 1) failed in flang/lib/Evaluate/shape.cpp #121971

Open
yype opened this issue Jan 7, 2025 · 2 comments · May be fixed by #122193
Open

[flang] fatal internal error: CHECK(GetRank(*shape) == 1) failed in flang/lib/Evaluate/shape.cpp #121971

yype opened this issue Jan 7, 2025 · 2 comments · May be fixed by #122193
Assignees
Labels
crash Prefer [crash-on-valid] or [crash-on-invalid] flang:frontend generated by fuzzer

Comments

@yype
Copy link

yype commented Jan 7, 2025

Hi there, flang crashes from an assertion failure on the following test case:

SUBROUTINE sub00(a,b,n,m)
  real(2) n,m
  integer(1) a(n,m), b(n,m)

  b = a ** b
  DO 10 j = 1,m
     a = a(a,j) - b(i,j)
10   PRINT *, g
END SUBROUTINE sub00

Tested version(s): 19.1.0, trunk.

Example: https://godbolt.org/z/68d8ErTba

Stack dump:

Click me

fatal internal error: CHECK(GetRank(*shape) == 1) failed at /root/llvm-project/flang/lib/Evaluate/shape.cpp(571)
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0.	Program arguments: /opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang -fc1 -triple x86_64-unknown-linux-gnu -S -mrelocation-model pic -pic-level 2 -pic-is-pie -target-cpu x86-64 -mllvm -x86-asm-syntax=intel -resource-dir /opt/compiler-explorer/clang-llvmflang-trunk-20250107/lib/clang/20 -mframe-pointer=all -o /app/output.s -x f95-cpp-input /app/example.f90
 #0 0x00000000039ffa18 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x39ffa18)
 #1 0x00000000039fd5dc SignalHandler(int) Signals.cpp:0:0
 #2 0x00007f2063642520 (/lib/x86_64-linux-gnu/libc.so.6+0x42520)
 #3 0x00007f20636969fc pthread_kill (/lib/x86_64-linux-gnu/libc.so.6+0x969fc)
 #4 0x00007f2063642476 gsignal (/lib/x86_64-linux-gnu/libc.so.6+0x42476)
 #5 0x00007f20636287f3 abort (/lib/x86_64-linux-gnu/libc.so.6+0x287f3)
 #6 0x00000000053ed959 (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x53ed959)
 #7 0x0000000004f80769 Fortran::evaluate::GetShapeHelper::operator()(Fortran::evaluate::ArrayRef const&) const (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x4f80769)
 #8 0x0000000003f62a62 std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::common::log2visit::Log2VisitHelper<0ul, 3ul, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>>, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::evaluate::Traverse<Fortran::evaluate::GetShapeHelper, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>>, true>::operator()<Fortran::common::Reference<Fortran::semantics::Symbol const>, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef>(std::variant<Fortran::common::Reference<Fortran::semantics::Symbol const>, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef> const&) const::'lambda'(auto const&), std::variant<Fortran::common::Reference<Fortran::semantics::Symbol const>, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef> const&>(std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::evaluate::Traverse<Fortran::evaluate::GetShapeHelper, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>>, true>::operator()<Fortran::common::Reference<Fortran::semantics::Symbol const>, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef>(std::variant<Fortran::common::Reference<Fortran::semantics::Symbol const>, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef> const&) const::'lambda'(auto const&)&&, unsigned long, std::variant<Fortran::common::Reference<Fortran::semantics::Symbol const>, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef> const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3f62a62)
 #9 0x0000000003f7acac std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::common::log2visit::Log2VisitHelper<0ul, 14ul, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>>, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::evaluate::Traverse<Fortran::evaluate::GetShapeHelper, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>>, true>::operator()<Fortran::evaluate::Parentheses<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Negate<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Add<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Subtract<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Multiply<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Divide<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Power<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Extremum<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)0>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)2>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)1>, Fortran::evaluate::Constant<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::ArrayConstructor<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Designator<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::FunctionRef<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>>(std::variant<Fortran::evaluate::Parentheses<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Negate<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Add<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Subtract<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Multiply<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Divide<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Power<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Extremum<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)0>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)2>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)1>, Fortran::evaluate::Constant<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::ArrayConstructor<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Designator<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::FunctionRef<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>> const&) const::'lambda'(auto const&), std::variant<Fortran::evaluate::Parentheses<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Negate<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Add<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Subtract<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Multiply<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Divide<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Power<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Extremum<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)0>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)2>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)1>, Fortran::evaluate::Constant<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::ArrayConstructor<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Designator<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::FunctionRef<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>> const&>(std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::evaluate::Traverse<Fortran::evaluate::GetShapeHelper, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>>, true>::operator()<Fortran::evaluate::Parentheses<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Negate<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Add<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Subtract<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Multiply<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Divide<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Power<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Extremum<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)0>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)2>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)1>, Fortran::evaluate::Constant<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::ArrayConstructor<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Designator<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::FunctionRef<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>>(std::variant<Fortran::evaluate::Parentheses<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Negate<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Add<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Subtract<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Multiply<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Divide<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Power<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Extremum<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)0>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)2>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)1>, Fortran::evaluate::Constant<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::ArrayConstructor<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Designator<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::FunctionRef<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>> const&) const::'lambda'(auto const&)&&, unsigned long, std::variant<Fortran::evaluate::Parentheses<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Negate<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Add<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Subtract<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Multiply<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Divide<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Power<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Extremum<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)0>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)2>, Fortran::evaluate::Convert<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>, (Fortran::common::TypeCategory)1>, Fortran::evaluate::Constant<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::ArrayConstructor<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Designator<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::FunctionRef<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>> const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3f7acac)
#10 0x0000000003f6c94e std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::common::log2visit::Log2VisitHelper<0ul, 4ul, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>>, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::evaluate::Traverse<Fortran::evaluate::GetShapeHelper, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>>, true>::operator()<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 2>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 4>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 16>>>(std::variant<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 2>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 4>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 16>>> const&) const::'lambda'(auto const&), std::variant<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 2>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 4>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 16>>> const&>(std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::evaluate::Traverse<Fortran::evaluate::GetShapeHelper, std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>>, true>::operator()<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 2>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 4>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 16>>>(std::variant<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 2>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 4>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 16>>> const&) const::'lambda'(auto const&)&&, unsigned long, std::variant<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 2>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 4>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>, Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 16>>> const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3f6c94e)
#11 0x00000000043d03f9 std::optional<std::vector<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>, std::allocator<std::optional<Fortran::evaluate::Expr<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 8>>>>>> Fortran::evaluate::GetShape<Fortran::evaluate::Expr<Fortran::evaluate::SomeType>>(Fortran::evaluate::FoldingContext&, Fortran::evaluate::Expr<Fortran::evaluate::SomeType> const&, bool) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43d03f9)
#12 0x00000000043d0726 Fortran::evaluate::ArgumentAnalyzer::CheckConformance() (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43d0726)
#13 0x00000000043f8a37 std::optional<Fortran::evaluate::Expr<Fortran::evaluate::SomeType>> Fortran::evaluate::NumericBinaryHelper<Fortran::evaluate::Subtract, (Fortran::common::NumericOperator)4>(Fortran::evaluate::ExpressionAnalyzer&, Fortran::parser::Expr::IntrinsicBinary const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f8a37)
#14 0x00000000043f9230 std::optional<Fortran::evaluate::Expr<Fortran::evaluate::SomeType>> Fortran::common::log2visit::Log2VisitHelper<16ul, 23ul, std::optional<Fortran::evaluate::Expr<Fortran::evaluate::SomeType>>, std::optional<Fortran::evaluate::Expr<Fortran::evaluate::SomeType>> Fortran::evaluate::ExpressionAnalyzer::Analyze<Fortran::common::Indirection<Fortran::parser::CharLiteralConstantSubstring, false>, Fortran::parser::LiteralConstant, Fortran::common::Indirection<Fortran::parser::Designator, false>, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection<Fortran::parser::FunctionReference, false>, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection<Fortran::parser::SubstringInquiry, false>>(std::variant<Fortran::common::Indirection<Fortran::parser::CharLiteralConstantSubstring, false>, Fortran::parser::LiteralConstant, Fortran::common::Indirection<Fortran::parser::Designator, false>, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection<Fortran::parser::FunctionReference, false>, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection<Fortran::parser::SubstringInquiry, false>> const&)::'lambda'(auto const&), std::variant<Fortran::common::Indirection<Fortran::parser::CharLiteralConstantSubstring, false>, Fortran::parser::LiteralConstant, Fortran::common::Indirection<Fortran::parser::Designator, false>, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection<Fortran::parser::FunctionReference, false>, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection<Fortran::parser::SubstringInquiry, false>> const&>(std::optional<Fortran::evaluate::Expr<Fortran::evaluate::SomeType>> Fortran::evaluate::ExpressionAnalyzer::Analyze<Fortran::common::Indirection<Fortran::parser::CharLiteralConstantSubstring, false>, Fortran::parser::LiteralConstant, Fortran::common::Indirection<Fortran::parser::Designator, false>, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection<Fortran::parser::FunctionReference, false>, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection<Fortran::parser::SubstringInquiry, false>>(std::variant<Fortran::common::Indirection<Fortran::parser::CharLiteralConstantSubstring, false>, Fortran::parser::LiteralConstant, Fortran::common::Indirection<Fortran::parser::Designator, false>, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection<Fortran::parser::FunctionReference, false>, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection<Fortran::parser::SubstringInquiry, false>> const&)::'lambda'(auto const&)&&, unsigned long, std::variant<Fortran::common::Indirection<Fortran::parser::CharLiteralConstantSubstring, false>, Fortran::parser::LiteralConstant, Fortran::common::Indirection<Fortran::parser::Designator, false>, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection<Fortran::parser::FunctionReference, false>, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection<Fortran::parser::SubstringInquiry, false>> const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f9230)
#15 0x00000000043f6d3d std::optional<Fortran::evaluate::Expr<Fortran::evaluate::SomeType>> Fortran::evaluate::ExpressionAnalyzer::ExprOrVariable<Fortran::parser::Expr>(Fortran::parser::Expr const&, Fortran::parser::CharBlock) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f6d3d)
#16 0x00000000043f702f Fortran::evaluate::ExpressionAnalyzer::IterativelyAnalyzeSubexpressions(Fortran::parser::Expr const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f702f)
#17 0x00000000043f73c5 Fortran::evaluate::ExpressionAnalyzer::Analyze(Fortran::parser::Expr const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f73c5)
#18 0x00000000043f74e7 Fortran::evaluate::ArgumentAnalyzer::AnalyzeExprOrWholeAssumedSizeArray(Fortran::parser::Expr const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f74e7)
#19 0x00000000043f76bb Fortran::evaluate::ArgumentAnalyzer::AnalyzeExpr(Fortran::parser::Expr const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f76bb)
#20 0x00000000043f7d41 Fortran::evaluate::ArgumentAnalyzer::Analyze(Fortran::parser::Expr const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f7d41)
#21 0x00000000044062fc Fortran::evaluate::ExpressionAnalyzer::Analyze(Fortran::parser::AssignmentStmt const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x44062fc)
#22 0x00000000044116b3 void Fortran::common::log2visit::Log2VisitHelper<0ul, 41ul, void, void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk<Fortran::semantics::ExprChecker, Fortran::common::Indirection<Fortran::parser::AllocateStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::BackspaceStmt, false>, Fortran::common::Indirection<Fortran::parser::CallStmt, false>, Fortran::common::Indirection<Fortran::parser::CloseStmt, false>, Fortran::parser::ContinueStmt, Fortran::common::Indirection<Fortran::parser::CycleStmt, false>, Fortran::common::Indirection<Fortran::parser::DeallocateStmt, false>, Fortran::common::Indirection<Fortran::parser::EndfileStmt, false>, Fortran::common::Indirection<Fortran::parser::EventPostStmt, false>, Fortran::common::Indirection<Fortran::parser::EventWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::ExitStmt, false>, Fortran::parser::FailImageStmt, Fortran::common::Indirection<Fortran::parser::FlushStmt, false>, Fortran::common::Indirection<Fortran::parser::FormTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::GotoStmt, false>, Fortran::common::Indirection<Fortran::parser::IfStmt, false>, Fortran::common::Indirection<Fortran::parser::InquireStmt, false>, Fortran::common::Indirection<Fortran::parser::LockStmt, false>, Fortran::common::Indirection<Fortran::parser::NotifyWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::NullifyStmt, false>, Fortran::common::Indirection<Fortran::parser::OpenStmt, false>, Fortran::common::Indirection<Fortran::parser::PointerAssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::PrintStmt, false>, Fortran::common::Indirection<Fortran::parser::ReadStmt, false>, Fortran::common::Indirection<Fortran::parser::ReturnStmt, false>, Fortran::common::Indirection<Fortran::parser::RewindStmt, false>, Fortran::common::Indirection<Fortran::parser::StopStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncAllStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncImagesStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncMemoryStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::UnlockStmt, false>, Fortran::common::Indirection<Fortran::parser::WaitStmt, false>, Fortran::common::Indirection<Fortran::parser::WhereStmt, false>, Fortran::common::Indirection<Fortran::parser::WriteStmt, false>, Fortran::common::Indirection<Fortran::parser::ComputedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::ForallStmt, false>, Fortran::common::Indirection<Fortran::parser::ArithmeticIfStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::PauseStmt, false>>(std::variant<Fortran::common::Indirection<Fortran::parser::AllocateStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::BackspaceStmt, false>, Fortran::common::Indirection<Fortran::parser::CallStmt, false>, Fortran::common::Indirection<Fortran::parser::CloseStmt, false>, Fortran::parser::ContinueStmt, Fortran::common::Indirection<Fortran::parser::CycleStmt, false>, Fortran::common::Indirection<Fortran::parser::DeallocateStmt, false>, Fortran::common::Indirection<Fortran::parser::EndfileStmt, false>, Fortran::common::Indirection<Fortran::parser::EventPostStmt, false>, Fortran::common::Indirection<Fortran::parser::EventWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::ExitStmt, false>, Fortran::parser::FailImageStmt, Fortran::common::Indirection<Fortran::parser::FlushStmt, false>, Fortran::common::Indirection<Fortran::parser::FormTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::GotoStmt, false>, Fortran::common::Indirection<Fortran::parser::IfStmt, false>, Fortran::common::Indirection<Fortran::parser::InquireStmt, false>, Fortran::common::Indirection<Fortran::parser::LockStmt, false>, Fortran::common::Indirection<Fortran::parser::NotifyWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::NullifyStmt, false>, Fortran::common::Indirection<Fortran::parser::OpenStmt, false>, Fortran::common::Indirection<Fortran::parser::PointerAssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::PrintStmt, false>, Fortran::common::Indirection<Fortran::parser::ReadStmt, false>, Fortran::common::Indirection<Fortran::parser::ReturnStmt, false>, Fortran::common::Indirection<Fortran::parser::RewindStmt, false>, Fortran::common::Indirection<Fortran::parser::StopStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncAllStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncImagesStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncMemoryStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::UnlockStmt, false>, Fortran::common::Indirection<Fortran::parser::WaitStmt, false>, Fortran::common::Indirection<Fortran::parser::WhereStmt, false>, Fortran::common::Indirection<Fortran::parser::WriteStmt, false>, Fortran::common::Indirection<Fortran::parser::ComputedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::ForallStmt, false>, Fortran::common::Indirection<Fortran::parser::ArithmeticIfStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::PauseStmt, false>> const&, Fortran::semantics::ExprChecker&)::'lambda'(Fortran::semantics::ExprChecker const&), std::variant<Fortran::common::Indirection<Fortran::parser::AllocateStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::BackspaceStmt, false>, Fortran::common::Indirection<Fortran::parser::CallStmt, false>, Fortran::common::Indirection<Fortran::parser::CloseStmt, false>, Fortran::parser::ContinueStmt, Fortran::common::Indirection<Fortran::parser::CycleStmt, false>, Fortran::common::Indirection<Fortran::parser::DeallocateStmt, false>, Fortran::common::Indirection<Fortran::parser::EndfileStmt, false>, Fortran::common::Indirection<Fortran::parser::EventPostStmt, false>, Fortran::common::Indirection<Fortran::parser::EventWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::ExitStmt, false>, Fortran::parser::FailImageStmt, Fortran::common::Indirection<Fortran::parser::FlushStmt, false>, Fortran::common::Indirection<Fortran::parser::FormTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::GotoStmt, false>, Fortran::common::Indirection<Fortran::parser::IfStmt, false>, Fortran::common::Indirection<Fortran::parser::InquireStmt, false>, Fortran::common::Indirection<Fortran::parser::LockStmt, false>, Fortran::common::Indirection<Fortran::parser::NotifyWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::NullifyStmt, false>, Fortran::common::Indirection<Fortran::parser::OpenStmt, false>, Fortran::common::Indirection<Fortran::parser::PointerAssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::PrintStmt, false>, Fortran::common::Indirection<Fortran::parser::ReadStmt, false>, Fortran::common::Indirection<Fortran::parser::ReturnStmt, false>, Fortran::common::Indirection<Fortran::parser::RewindStmt, false>, Fortran::common::Indirection<Fortran::parser::StopStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncAllStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncImagesStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncMemoryStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::UnlockStmt, false>, Fortran::common::Indirection<Fortran::parser::WaitStmt, false>, Fortran::common::Indirection<Fortran::parser::WhereStmt, false>, Fortran::common::Indirection<Fortran::parser::WriteStmt, false>, Fortran::common::Indirection<Fortran::parser::ComputedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::ForallStmt, false>, Fortran::common::Indirection<Fortran::parser::ArithmeticIfStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::PauseStmt, false>> const&>(void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk<Fortran::semantics::ExprChecker, Fortran::common::Indirection<Fortran::parser::AllocateStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::BackspaceStmt, false>, Fortran::common::Indirection<Fortran::parser::CallStmt, false>, Fortran::common::Indirection<Fortran::parser::CloseStmt, false>, Fortran::parser::ContinueStmt, Fortran::common::Indirection<Fortran::parser::CycleStmt, false>, Fortran::common::Indirection<Fortran::parser::DeallocateStmt, false>, Fortran::common::Indirection<Fortran::parser::EndfileStmt, false>, Fortran::common::Indirection<Fortran::parser::EventPostStmt, false>, Fortran::common::Indirection<Fortran::parser::EventWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::ExitStmt, false>, Fortran::parser::FailImageStmt, Fortran::common::Indirection<Fortran::parser::FlushStmt, false>, Fortran::common::Indirection<Fortran::parser::FormTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::GotoStmt, false>, Fortran::common::Indirection<Fortran::parser::IfStmt, false>, Fortran::common::Indirection<Fortran::parser::InquireStmt, false>, Fortran::common::Indirection<Fortran::parser::LockStmt, false>, Fortran::common::Indirection<Fortran::parser::NotifyWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::NullifyStmt, false>, Fortran::common::Indirection<Fortran::parser::OpenStmt, false>, Fortran::common::Indirection<Fortran::parser::PointerAssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::PrintStmt, false>, Fortran::common::Indirection<Fortran::parser::ReadStmt, false>, Fortran::common::Indirection<Fortran::parser::ReturnStmt, false>, Fortran::common::Indirection<Fortran::parser::RewindStmt, false>, Fortran::common::Indirection<Fortran::parser::StopStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncAllStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncImagesStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncMemoryStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::UnlockStmt, false>, Fortran::common::Indirection<Fortran::parser::WaitStmt, false>, Fortran::common::Indirection<Fortran::parser::WhereStmt, false>, Fortran::common::Indirection<Fortran::parser::WriteStmt, false>, Fortran::common::Indirection<Fortran::parser::ComputedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::ForallStmt, false>, Fortran::common::Indirection<Fortran::parser::ArithmeticIfStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::PauseStmt, false>>(std::variant<Fortran::common::Indirection<Fortran::parser::AllocateStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::BackspaceStmt, false>, Fortran::common::Indirection<Fortran::parser::CallStmt, false>, Fortran::common::Indirection<Fortran::parser::CloseStmt, false>, Fortran::parser::ContinueStmt, Fortran::common::Indirection<Fortran::parser::CycleStmt, false>, Fortran::common::Indirection<Fortran::parser::DeallocateStmt, false>, Fortran::common::Indirection<Fortran::parser::EndfileStmt, false>, Fortran::common::Indirection<Fortran::parser::EventPostStmt, false>, Fortran::common::Indirection<Fortran::parser::EventWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::ExitStmt, false>, Fortran::parser::FailImageStmt, Fortran::common::Indirection<Fortran::parser::FlushStmt, false>, Fortran::common::Indirection<Fortran::parser::FormTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::GotoStmt, false>, Fortran::common::Indirection<Fortran::parser::IfStmt, false>, Fortran::common::Indirection<Fortran::parser::InquireStmt, false>, Fortran::common::Indirection<Fortran::parser::LockStmt, false>, Fortran::common::Indirection<Fortran::parser::NotifyWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::NullifyStmt, false>, Fortran::common::Indirection<Fortran::parser::OpenStmt, false>, Fortran::common::Indirection<Fortran::parser::PointerAssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::PrintStmt, false>, Fortran::common::Indirection<Fortran::parser::ReadStmt, false>, Fortran::common::Indirection<Fortran::parser::ReturnStmt, false>, Fortran::common::Indirection<Fortran::parser::RewindStmt, false>, Fortran::common::Indirection<Fortran::parser::StopStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncAllStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncImagesStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncMemoryStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::UnlockStmt, false>, Fortran::common::Indirection<Fortran::parser::WaitStmt, false>, Fortran::common::Indirection<Fortran::parser::WhereStmt, false>, Fortran::common::Indirection<Fortran::parser::WriteStmt, false>, Fortran::common::Indirection<Fortran::parser::ComputedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::ForallStmt, false>, Fortran::common::Indirection<Fortran::parser::ArithmeticIfStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::PauseStmt, false>> const&, Fortran::semantics::ExprChecker&)::'lambda'(Fortran::semantics::ExprChecker const&)&&, unsigned long, std::variant<Fortran::common::Indirection<Fortran::parser::AllocateStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::BackspaceStmt, false>, Fortran::common::Indirection<Fortran::parser::CallStmt, false>, Fortran::common::Indirection<Fortran::parser::CloseStmt, false>, Fortran::parser::ContinueStmt, Fortran::common::Indirection<Fortran::parser::CycleStmt, false>, Fortran::common::Indirection<Fortran::parser::DeallocateStmt, false>, Fortran::common::Indirection<Fortran::parser::EndfileStmt, false>, Fortran::common::Indirection<Fortran::parser::EventPostStmt, false>, Fortran::common::Indirection<Fortran::parser::EventWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::ExitStmt, false>, Fortran::parser::FailImageStmt, Fortran::common::Indirection<Fortran::parser::FlushStmt, false>, Fortran::common::Indirection<Fortran::parser::FormTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::GotoStmt, false>, Fortran::common::Indirection<Fortran::parser::IfStmt, false>, Fortran::common::Indirection<Fortran::parser::InquireStmt, false>, Fortran::common::Indirection<Fortran::parser::LockStmt, false>, Fortran::common::Indirection<Fortran::parser::NotifyWaitStmt, false>, Fortran::common::Indirection<Fortran::parser::NullifyStmt, false>, Fortran::common::Indirection<Fortran::parser::OpenStmt, false>, Fortran::common::Indirection<Fortran::parser::PointerAssignmentStmt, false>, Fortran::common::Indirection<Fortran::parser::PrintStmt, false>, Fortran::common::Indirection<Fortran::parser::ReadStmt, false>, Fortran::common::Indirection<Fortran::parser::ReturnStmt, false>, Fortran::common::Indirection<Fortran::parser::RewindStmt, false>, Fortran::common::Indirection<Fortran::parser::StopStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncAllStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncImagesStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncMemoryStmt, false>, Fortran::common::Indirection<Fortran::parser::SyncTeamStmt, false>, Fortran::common::Indirection<Fortran::parser::UnlockStmt, false>, Fortran::common::Indirection<Fortran::parser::WaitStmt, false>, Fortran::common::Indirection<Fortran::parser::WhereStmt, false>, Fortran::common::Indirection<Fortran::parser::WriteStmt, false>, Fortran::common::Indirection<Fortran::parser::ComputedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::ForallStmt, false>, Fortran::common::Indirection<Fortran::parser::ArithmeticIfStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignStmt, false>, Fortran::common::Indirection<Fortran::parser::AssignedGotoStmt, false>, Fortran::common::Indirection<Fortran::parser::PauseStmt, false>> const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x44116b3)
#23 0x000000000441edf0 void Fortran::common::log2visit::Log2VisitHelper<0ul, 4ul, void, void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk<Fortran::semantics::ExprChecker, Fortran::parser::Statement<Fortran::parser::ActionStmt>, Fortran::common::Indirection<Fortran::parser::AssociateConstruct, false>, Fortran::common::Indirection<Fortran::parser::BlockConstruct, false>, Fortran::common::Indirection<Fortran::parser::CaseConstruct, false>, Fortran::common::Indirection<Fortran::parser::ChangeTeamConstruct, false>, Fortran::common::Indirection<Fortran::parser::CriticalConstruct, false>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::LabelDoStmt, false>>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::EndDoStmt, false>>, Fortran::common::Indirection<Fortran::parser::DoConstruct, false>, Fortran::common::Indirection<Fortran::parser::IfConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectRankConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectTypeConstruct, false>, Fortran::common::Indirection<Fortran::parser::WhereConstruct, false>, Fortran::common::Indirection<Fortran::parser::ForallConstruct, false>, Fortran::common::Indirection<Fortran::parser::CompilerDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenACCConstruct, false>, Fortran::common::Indirection<Fortran::parser::AccEndCombinedDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenMPConstruct, false>, Fortran::common::Indirection<Fortran::parser::OmpEndLoopDirective, false>, Fortran::common::Indirection<Fortran::parser::CUFKernelDoConstruct, false>>(std::variant<Fortran::parser::Statement<Fortran::parser::ActionStmt>, Fortran::common::Indirection<Fortran::parser::AssociateConstruct, false>, Fortran::common::Indirection<Fortran::parser::BlockConstruct, false>, Fortran::common::Indirection<Fortran::parser::CaseConstruct, false>, Fortran::common::Indirection<Fortran::parser::ChangeTeamConstruct, false>, Fortran::common::Indirection<Fortran::parser::CriticalConstruct, false>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::LabelDoStmt, false>>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::EndDoStmt, false>>, Fortran::common::Indirection<Fortran::parser::DoConstruct, false>, Fortran::common::Indirection<Fortran::parser::IfConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectRankConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectTypeConstruct, false>, Fortran::common::Indirection<Fortran::parser::WhereConstruct, false>, Fortran::common::Indirection<Fortran::parser::ForallConstruct, false>, Fortran::common::Indirection<Fortran::parser::CompilerDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenACCConstruct, false>, Fortran::common::Indirection<Fortran::parser::AccEndCombinedDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenMPConstruct, false>, Fortran::common::Indirection<Fortran::parser::OmpEndLoopDirective, false>, Fortran::common::Indirection<Fortran::parser::CUFKernelDoConstruct, false>> const&, Fortran::semantics::ExprChecker&)::'lambda'(Fortran::semantics::ExprChecker const&), std::variant<Fortran::parser::Statement<Fortran::parser::ActionStmt>, Fortran::common::Indirection<Fortran::parser::AssociateConstruct, false>, Fortran::common::Indirection<Fortran::parser::BlockConstruct, false>, Fortran::common::Indirection<Fortran::parser::CaseConstruct, false>, Fortran::common::Indirection<Fortran::parser::ChangeTeamConstruct, false>, Fortran::common::Indirection<Fortran::parser::CriticalConstruct, false>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::LabelDoStmt, false>>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::EndDoStmt, false>>, Fortran::common::Indirection<Fortran::parser::DoConstruct, false>, Fortran::common::Indirection<Fortran::parser::IfConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectRankConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectTypeConstruct, false>, Fortran::common::Indirection<Fortran::parser::WhereConstruct, false>, Fortran::common::Indirection<Fortran::parser::ForallConstruct, false>, Fortran::common::Indirection<Fortran::parser::CompilerDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenACCConstruct, false>, Fortran::common::Indirection<Fortran::parser::AccEndCombinedDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenMPConstruct, false>, Fortran::common::Indirection<Fortran::parser::OmpEndLoopDirective, false>, Fortran::common::Indirection<Fortran::parser::CUFKernelDoConstruct, false>> const&>(void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk<Fortran::semantics::ExprChecker, Fortran::parser::Statement<Fortran::parser::ActionStmt>, Fortran::common::Indirection<Fortran::parser::AssociateConstruct, false>, Fortran::common::Indirection<Fortran::parser::BlockConstruct, false>, Fortran::common::Indirection<Fortran::parser::CaseConstruct, false>, Fortran::common::Indirection<Fortran::parser::ChangeTeamConstruct, false>, Fortran::common::Indirection<Fortran::parser::CriticalConstruct, false>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::LabelDoStmt, false>>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::EndDoStmt, false>>, Fortran::common::Indirection<Fortran::parser::DoConstruct, false>, Fortran::common::Indirection<Fortran::parser::IfConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectRankConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectTypeConstruct, false>, Fortran::common::Indirection<Fortran::parser::WhereConstruct, false>, Fortran::common::Indirection<Fortran::parser::ForallConstruct, false>, Fortran::common::Indirection<Fortran::parser::CompilerDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenACCConstruct, false>, Fortran::common::Indirection<Fortran::parser::AccEndCombinedDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenMPConstruct, false>, Fortran::common::Indirection<Fortran::parser::OmpEndLoopDirective, false>, Fortran::common::Indirection<Fortran::parser::CUFKernelDoConstruct, false>>(std::variant<Fortran::parser::Statement<Fortran::parser::ActionStmt>, Fortran::common::Indirection<Fortran::parser::AssociateConstruct, false>, Fortran::common::Indirection<Fortran::parser::BlockConstruct, false>, Fortran::common::Indirection<Fortran::parser::CaseConstruct, false>, Fortran::common::Indirection<Fortran::parser::ChangeTeamConstruct, false>, Fortran::common::Indirection<Fortran::parser::CriticalConstruct, false>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::LabelDoStmt, false>>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::EndDoStmt, false>>, Fortran::common::Indirection<Fortran::parser::DoConstruct, false>, Fortran::common::Indirection<Fortran::parser::IfConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectRankConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectTypeConstruct, false>, Fortran::common::Indirection<Fortran::parser::WhereConstruct, false>, Fortran::common::Indirection<Fortran::parser::ForallConstruct, false>, Fortran::common::Indirection<Fortran::parser::CompilerDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenACCConstruct, false>, Fortran::common::Indirection<Fortran::parser::AccEndCombinedDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenMPConstruct, false>, Fortran::common::Indirection<Fortran::parser::OmpEndLoopDirective, false>, Fortran::common::Indirection<Fortran::parser::CUFKernelDoConstruct, false>> const&, Fortran::semantics::ExprChecker&)::'lambda'(Fortran::semantics::ExprChecker const&)&&, unsigned long, std::variant<Fortran::parser::Statement<Fortran::parser::ActionStmt>, Fortran::common::Indirection<Fortran::parser::AssociateConstruct, false>, Fortran::common::Indirection<Fortran::parser::BlockConstruct, false>, Fortran::common::Indirection<Fortran::parser::CaseConstruct, false>, Fortran::common::Indirection<Fortran::parser::ChangeTeamConstruct, false>, Fortran::common::Indirection<Fortran::parser::CriticalConstruct, false>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::LabelDoStmt, false>>, Fortran::parser::Statement<Fortran::common::Indirection<Fortran::parser::EndDoStmt, false>>, Fortran::common::Indirection<Fortran::parser::DoConstruct, false>, Fortran::common::Indirection<Fortran::parser::IfConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectRankConstruct, false>, Fortran::common::Indirection<Fortran::parser::SelectTypeConstruct, false>, Fortran::common::Indirection<Fortran::parser::WhereConstruct, false>, Fortran::common::Indirection<Fortran::parser::ForallConstruct, false>, Fortran::common::Indirection<Fortran::parser::CompilerDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenACCConstruct, false>, Fortran::common::Indirection<Fortran::parser::AccEndCombinedDirective, false>, Fortran::common::Indirection<Fortran::parser::OpenMPConstruct, false>, Fortran::common::Indirection<Fortran::parser::OmpEndLoopDirective, false>, Fortran::common::Indirection<Fortran::parser::CUFKernelDoConstruct, false>> const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x441edf0)
#24 0x000000000441f1bd void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk<Fortran::semantics::ExprChecker>(std::__cxx11::list<Fortran::parser::ExecutionPartConstruct, std::allocator<Fortran::parser::ExecutionPartConstruct>> const&, Fortran::semantics::ExprChecker&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x441f1bd)
#25 0x000000000441f544 void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk<Fortran::semantics::ExprChecker>(std::__cxx11::list<Fortran::parser::ExecutionPartConstruct, std::allocator<Fortran::parser::ExecutionPartConstruct>> const&, Fortran::semantics::ExprChecker&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x441f544)
#26 0x0000000004421e41 Fortran::semantics::ExprChecker::Walk(Fortran::parser::Program const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x4421e41)
#27 0x0000000004541f9a Fortran::semantics::Semantics::Perform() (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x4541f9a)
#28 0x0000000003a537bd Fortran::frontend::FrontendAction::runSemanticChecks() (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3a537bd)
#29 0x0000000003de1932 Fortran::frontend::CodeGenAction::beginSourceFileAction() (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3de1932)
#30 0x0000000003a51f8d Fortran::frontend::FrontendAction::beginSourceFile(Fortran::frontend::CompilerInstance&, Fortran::frontend::FrontendInputFile const&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3a51f8d)
#31 0x0000000003a42c27 Fortran::frontend::CompilerInstance::executeAction(Fortran::frontend::FrontendAction&) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3a42c27)
#32 0x0000000003a59c03 Fortran::frontend::executeCompilerInvocation(Fortran::frontend::CompilerInstance*) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3a59c03)
#33 0x0000000001f7cd27 fc1_main(llvm::ArrayRef<char const*>, char const*) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x1f7cd27)
#34 0x0000000001e5068e main (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x1e5068e)
#35 0x00007f2063629d90 (/lib/x86_64-linux-gnu/libc.so.6+0x29d90)
#36 0x00007f2063629e40 __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x29e40)
#37 0x0000000001f7b795 _start (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x1f7b795)
flang-20: error: unable to execute command: Aborted (core dumped)
flang-20: error: flang frontend command failed due to signal (use -v to see invocation)
flang version 20.0.0git (https://github.com/llvm/llvm-project.git 97097958fdf525e8c14fcdde94231bae72ea2673)
Target: x86_64-unknown-linux-gnu
Thread model: posix
InstalledDir: /opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin
flang-20: note: diagnostic msg: 
********************

PLEASE ATTACH THE FOLLOWING FILES TO THE BUG REPORT:
Preprocessed source(s) and associated run script(s) are located at:
flang-20: note: diagnostic msg: /tmp/example-a9819a
flang-20: note: diagnostic msg: /tmp/example-a9819a.sh
flang-20: note: diagnostic msg: 

********************
Compiler returned: 254

The test case was generated by a fuzzer.

@llvmbot llvmbot added the flang Flang issues not falling into any other category label Jan 7, 2025
@EugeneZelenko EugeneZelenko added flang:frontend crash Prefer [crash-on-valid] or [crash-on-invalid] and removed flang Flang issues not falling into any other category labels Jan 7, 2025
@llvmbot
Copy link
Member

llvmbot commented Jan 7, 2025

@llvm/issue-subscribers-flang-frontend

Author: yype (yype)

Hi there, flang crashes from an assertion failure on the following test case:
SUBROUTINE sub00(a,b,n,m)
  real(2) n,m
  integer(1) a(n,m), b(n,m)

  b = a ** b
  DO 10 j = 1,m
     a = a(a,j) - b(i,j)
10   PRINT *, g
END SUBROUTINE sub00

Tested version(s): 19.1.0, trunk.

Example: https://godbolt.org/z/68d8ErTba

Stack dump:

<details>
<summary>Click me</summary>


fatal internal error: CHECK(GetRank(*shape) == 1) failed at /root/llvm-project/flang/lib/Evaluate/shape.cpp(571)
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0.	Program arguments: /opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang -fc1 -triple x86_64-unknown-linux-gnu -S -mrelocation-model pic -pic-level 2 -pic-is-pie -target-cpu x86-64 -mllvm -x86-asm-syntax=intel -resource-dir /opt/compiler-explorer/clang-llvmflang-trunk-20250107/lib/clang/20 -mframe-pointer=all -o /app/output.s -x f95-cpp-input /app/example.f90
 #<!-- -->0 0x00000000039ffa18 llvm::sys::PrintStackTrace(llvm::raw_ostream&amp;, int) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x39ffa18)
 #<!-- -->1 0x00000000039fd5dc SignalHandler(int) Signals.cpp:0:0
 #<!-- -->2 0x00007f2063642520 (/lib/x86_64-linux-gnu/libc.so.6+0x42520)
 #<!-- -->3 0x00007f20636969fc pthread_kill (/lib/x86_64-linux-gnu/libc.so.6+0x969fc)
 #<!-- -->4 0x00007f2063642476 gsignal (/lib/x86_64-linux-gnu/libc.so.6+0x42476)
 #<!-- -->5 0x00007f20636287f3 abort (/lib/x86_64-linux-gnu/libc.so.6+0x287f3)
 #<!-- -->6 0x00000000053ed959 (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x53ed959)
 #<!-- -->7 0x0000000004f80769 Fortran::evaluate::GetShapeHelper::operator()(Fortran::evaluate::ArrayRef const&amp;) const (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x4f80769)
 #<!-- -->8 0x0000000003f62a62 std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::common::log2visit::Log2VisitHelper&lt;0ul, 3ul, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt;, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::evaluate::Traverse&lt;Fortran::evaluate::GetShapeHelper, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt;, true&gt;::operator()&lt;Fortran::common::Reference&lt;Fortran::semantics::Symbol const&gt;, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef&gt;(std::variant&lt;Fortran::common::Reference&lt;Fortran::semantics::Symbol const&gt;, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef&gt; const&amp;) const::'lambda'(auto const&amp;), std::variant&lt;Fortran::common::Reference&lt;Fortran::semantics::Symbol const&gt;, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef&gt; const&amp;&gt;(std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::evaluate::Traverse&lt;Fortran::evaluate::GetShapeHelper, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt;, true&gt;::operator()&lt;Fortran::common::Reference&lt;Fortran::semantics::Symbol const&gt;, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef&gt;(std::variant&lt;Fortran::common::Reference&lt;Fortran::semantics::Symbol const&gt;, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef&gt; const&amp;) const::'lambda'(auto const&amp;)&amp;&amp;, unsigned long, std::variant&lt;Fortran::common::Reference&lt;Fortran::semantics::Symbol const&gt;, Fortran::evaluate::Component, Fortran::evaluate::ArrayRef, Fortran::evaluate::CoarrayRef&gt; const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3f62a62)
 #<!-- -->9 0x0000000003f7acac std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::common::log2visit::Log2VisitHelper&lt;0ul, 14ul, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt;, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::evaluate::Traverse&lt;Fortran::evaluate::GetShapeHelper, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt;, true&gt;::operator()&lt;Fortran::evaluate::Parentheses&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Negate&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Add&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Subtract&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Multiply&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Divide&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Power&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Extremum&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)0&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)2&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)1&gt;, Fortran::evaluate::Constant&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::ArrayConstructor&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Designator&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::FunctionRef&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;&gt;(std::variant&lt;Fortran::evaluate::Parentheses&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Negate&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Add&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Subtract&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Multiply&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Divide&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Power&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Extremum&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)0&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)2&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)1&gt;, Fortran::evaluate::Constant&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::ArrayConstructor&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Designator&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::FunctionRef&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;&gt; const&amp;) const::'lambda'(auto const&amp;), std::variant&lt;Fortran::evaluate::Parentheses&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Negate&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Add&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Subtract&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Multiply&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Divide&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Power&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Extremum&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)0&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)2&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)1&gt;, Fortran::evaluate::Constant&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::ArrayConstructor&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Designator&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::FunctionRef&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;&gt; const&amp;&gt;(std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::evaluate::Traverse&lt;Fortran::evaluate::GetShapeHelper, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt;, true&gt;::operator()&lt;Fortran::evaluate::Parentheses&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Negate&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Add&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Subtract&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Multiply&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Divide&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Power&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Extremum&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)0&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)2&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)1&gt;, Fortran::evaluate::Constant&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::ArrayConstructor&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Designator&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::FunctionRef&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;&gt;(std::variant&lt;Fortran::evaluate::Parentheses&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Negate&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Add&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Subtract&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Multiply&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Divide&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Power&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Extremum&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)0&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)2&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)1&gt;, Fortran::evaluate::Constant&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::ArrayConstructor&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Designator&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::FunctionRef&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;&gt; const&amp;) const::'lambda'(auto const&amp;)&amp;&amp;, unsigned long, std::variant&lt;Fortran::evaluate::Parentheses&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Negate&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Add&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Subtract&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Multiply&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Divide&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Power&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Extremum&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)0&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)2&gt;, Fortran::evaluate::Convert&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;, (Fortran::common::TypeCategory)1&gt;, Fortran::evaluate::Constant&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::ArrayConstructor&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Designator&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::FunctionRef&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;&gt; const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3f7acac)
#<!-- -->10 0x0000000003f6c94e std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::common::log2visit::Log2VisitHelper&lt;0ul, 4ul, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt;, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::evaluate::Traverse&lt;Fortran::evaluate::GetShapeHelper, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt;, true&gt;::operator()&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 2&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 4&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 16&gt;&gt;&gt;(std::variant&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 2&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 4&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 16&gt;&gt;&gt; const&amp;) const::'lambda'(auto const&amp;), std::variant&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 2&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 4&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 16&gt;&gt;&gt; const&amp;&gt;(std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::evaluate::Traverse&lt;Fortran::evaluate::GetShapeHelper, std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt;, true&gt;::operator()&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 2&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 4&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 16&gt;&gt;&gt;(std::variant&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 2&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 4&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 16&gt;&gt;&gt; const&amp;) const::'lambda'(auto const&amp;)&amp;&amp;, unsigned long, std::variant&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 1&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 2&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 4&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;, Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 16&gt;&gt;&gt; const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3f6c94e)
#<!-- -->11 0x00000000043d03f9 std::optional&lt;std::vector&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;, std::allocator&lt;std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::Type&lt;(Fortran::common::TypeCategory)0, 8&gt;&gt;&gt;&gt;&gt;&gt; Fortran::evaluate::GetShape&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::SomeType&gt;&gt;(Fortran::evaluate::FoldingContext&amp;, Fortran::evaluate::Expr&lt;Fortran::evaluate::SomeType&gt; const&amp;, bool) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43d03f9)
#<!-- -->12 0x00000000043d0726 Fortran::evaluate::ArgumentAnalyzer::CheckConformance() (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43d0726)
#<!-- -->13 0x00000000043f8a37 std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::SomeType&gt;&gt; Fortran::evaluate::NumericBinaryHelper&lt;Fortran::evaluate::Subtract, (Fortran::common::NumericOperator)4&gt;(Fortran::evaluate::ExpressionAnalyzer&amp;, Fortran::parser::Expr::IntrinsicBinary const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f8a37)
#<!-- -->14 0x00000000043f9230 std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::SomeType&gt;&gt; Fortran::common::log2visit::Log2VisitHelper&lt;16ul, 23ul, std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::SomeType&gt;&gt;, std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::SomeType&gt;&gt; Fortran::evaluate::ExpressionAnalyzer::Analyze&lt;Fortran::common::Indirection&lt;Fortran::parser::CharLiteralConstantSubstring, false&gt;, Fortran::parser::LiteralConstant, Fortran::common::Indirection&lt;Fortran::parser::Designator, false&gt;, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection&lt;Fortran::parser::FunctionReference, false&gt;, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection&lt;Fortran::parser::SubstringInquiry, false&gt;&gt;(std::variant&lt;Fortran::common::Indirection&lt;Fortran::parser::CharLiteralConstantSubstring, false&gt;, Fortran::parser::LiteralConstant, Fortran::common::Indirection&lt;Fortran::parser::Designator, false&gt;, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection&lt;Fortran::parser::FunctionReference, false&gt;, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection&lt;Fortran::parser::SubstringInquiry, false&gt;&gt; const&amp;)::'lambda'(auto const&amp;), std::variant&lt;Fortran::common::Indirection&lt;Fortran::parser::CharLiteralConstantSubstring, false&gt;, Fortran::parser::LiteralConstant, Fortran::common::Indirection&lt;Fortran::parser::Designator, false&gt;, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection&lt;Fortran::parser::FunctionReference, false&gt;, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection&lt;Fortran::parser::SubstringInquiry, false&gt;&gt; const&amp;&gt;(std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::SomeType&gt;&gt; Fortran::evaluate::ExpressionAnalyzer::Analyze&lt;Fortran::common::Indirection&lt;Fortran::parser::CharLiteralConstantSubstring, false&gt;, Fortran::parser::LiteralConstant, Fortran::common::Indirection&lt;Fortran::parser::Designator, false&gt;, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection&lt;Fortran::parser::FunctionReference, false&gt;, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection&lt;Fortran::parser::SubstringInquiry, false&gt;&gt;(std::variant&lt;Fortran::common::Indirection&lt;Fortran::parser::CharLiteralConstantSubstring, false&gt;, Fortran::parser::LiteralConstant, Fortran::common::Indirection&lt;Fortran::parser::Designator, false&gt;, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection&lt;Fortran::parser::FunctionReference, false&gt;, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection&lt;Fortran::parser::SubstringInquiry, false&gt;&gt; const&amp;)::'lambda'(auto const&amp;)&amp;&amp;, unsigned long, std::variant&lt;Fortran::common::Indirection&lt;Fortran::parser::CharLiteralConstantSubstring, false&gt;, Fortran::parser::LiteralConstant, Fortran::common::Indirection&lt;Fortran::parser::Designator, false&gt;, Fortran::parser::ArrayConstructor, Fortran::parser::StructureConstructor, Fortran::common::Indirection&lt;Fortran::parser::FunctionReference, false&gt;, Fortran::parser::Expr::Parentheses, Fortran::parser::Expr::UnaryPlus, Fortran::parser::Expr::Negate, Fortran::parser::Expr::NOT, Fortran::parser::Expr::PercentLoc, Fortran::parser::Expr::DefinedUnary, Fortran::parser::Expr::Power, Fortran::parser::Expr::Multiply, Fortran::parser::Expr::Divide, Fortran::parser::Expr::Add, Fortran::parser::Expr::Subtract, Fortran::parser::Expr::Concat, Fortran::parser::Expr::LT, Fortran::parser::Expr::LE, Fortran::parser::Expr::EQ, Fortran::parser::Expr::NE, Fortran::parser::Expr::GE, Fortran::parser::Expr::GT, Fortran::parser::Expr::AND, Fortran::parser::Expr::OR, Fortran::parser::Expr::EQV, Fortran::parser::Expr::NEQV, Fortran::parser::Expr::DefinedBinary, Fortran::parser::Expr::ComplexConstructor, Fortran::common::Indirection&lt;Fortran::parser::SubstringInquiry, false&gt;&gt; const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f9230)
#<!-- -->15 0x00000000043f6d3d std::optional&lt;Fortran::evaluate::Expr&lt;Fortran::evaluate::SomeType&gt;&gt; Fortran::evaluate::ExpressionAnalyzer::ExprOrVariable&lt;Fortran::parser::Expr&gt;(Fortran::parser::Expr const&amp;, Fortran::parser::CharBlock) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f6d3d)
#<!-- -->16 0x00000000043f702f Fortran::evaluate::ExpressionAnalyzer::IterativelyAnalyzeSubexpressions(Fortran::parser::Expr const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f702f)
#<!-- -->17 0x00000000043f73c5 Fortran::evaluate::ExpressionAnalyzer::Analyze(Fortran::parser::Expr const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f73c5)
#<!-- -->18 0x00000000043f74e7 Fortran::evaluate::ArgumentAnalyzer::AnalyzeExprOrWholeAssumedSizeArray(Fortran::parser::Expr const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f74e7)
#<!-- -->19 0x00000000043f76bb Fortran::evaluate::ArgumentAnalyzer::AnalyzeExpr(Fortran::parser::Expr const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f76bb)
#<!-- -->20 0x00000000043f7d41 Fortran::evaluate::ArgumentAnalyzer::Analyze(Fortran::parser::Expr const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x43f7d41)
#<!-- -->21 0x00000000044062fc Fortran::evaluate::ExpressionAnalyzer::Analyze(Fortran::parser::AssignmentStmt const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x44062fc)
#<!-- -->22 0x00000000044116b3 void Fortran::common::log2visit::Log2VisitHelper&lt;0ul, 41ul, void, void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk&lt;Fortran::semantics::ExprChecker, Fortran::common::Indirection&lt;Fortran::parser::AllocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BackspaceStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CloseStmt, false&gt;, Fortran::parser::ContinueStmt, Fortran::common::Indirection&lt;Fortran::parser::CycleStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::DeallocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EndfileStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventPostStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ExitStmt, false&gt;, Fortran::parser::FailImageStmt, Fortran::common::Indirection&lt;Fortran::parser::FlushStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::FormTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::GotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::InquireStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::LockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NotifyWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NullifyStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PointerAssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PrintStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReadStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReturnStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::RewindStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::StopStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncAllStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncImagesStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncMemoryStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::UnlockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WriteStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ComputedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ArithmeticIfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PauseStmt, false&gt;&gt;(std::variant&lt;Fortran::common::Indirection&lt;Fortran::parser::AllocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BackspaceStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CloseStmt, false&gt;, Fortran::parser::ContinueStmt, Fortran::common::Indirection&lt;Fortran::parser::CycleStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::DeallocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EndfileStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventPostStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ExitStmt, false&gt;, Fortran::parser::FailImageStmt, Fortran::common::Indirection&lt;Fortran::parser::FlushStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::FormTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::GotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::InquireStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::LockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NotifyWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NullifyStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PointerAssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PrintStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReadStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReturnStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::RewindStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::StopStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncAllStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncImagesStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncMemoryStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::UnlockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WriteStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ComputedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ArithmeticIfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PauseStmt, false&gt;&gt; const&amp;, Fortran::semantics::ExprChecker&amp;)::'lambda'(Fortran::semantics::ExprChecker const&amp;), std::variant&lt;Fortran::common::Indirection&lt;Fortran::parser::AllocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BackspaceStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CloseStmt, false&gt;, Fortran::parser::ContinueStmt, Fortran::common::Indirection&lt;Fortran::parser::CycleStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::DeallocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EndfileStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventPostStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ExitStmt, false&gt;, Fortran::parser::FailImageStmt, Fortran::common::Indirection&lt;Fortran::parser::FlushStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::FormTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::GotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::InquireStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::LockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NotifyWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NullifyStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PointerAssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PrintStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReadStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReturnStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::RewindStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::StopStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncAllStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncImagesStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncMemoryStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::UnlockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WriteStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ComputedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ArithmeticIfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PauseStmt, false&gt;&gt; const&amp;&gt;(void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk&lt;Fortran::semantics::ExprChecker, Fortran::common::Indirection&lt;Fortran::parser::AllocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BackspaceStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CloseStmt, false&gt;, Fortran::parser::ContinueStmt, Fortran::common::Indirection&lt;Fortran::parser::CycleStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::DeallocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EndfileStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventPostStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ExitStmt, false&gt;, Fortran::parser::FailImageStmt, Fortran::common::Indirection&lt;Fortran::parser::FlushStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::FormTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::GotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::InquireStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::LockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NotifyWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NullifyStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PointerAssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PrintStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReadStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReturnStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::RewindStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::StopStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncAllStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncImagesStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncMemoryStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::UnlockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WriteStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ComputedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ArithmeticIfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PauseStmt, false&gt;&gt;(std::variant&lt;Fortran::common::Indirection&lt;Fortran::parser::AllocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BackspaceStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CloseStmt, false&gt;, Fortran::parser::ContinueStmt, Fortran::common::Indirection&lt;Fortran::parser::CycleStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::DeallocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EndfileStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventPostStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ExitStmt, false&gt;, Fortran::parser::FailImageStmt, Fortran::common::Indirection&lt;Fortran::parser::FlushStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::FormTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::GotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::InquireStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::LockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NotifyWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NullifyStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PointerAssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PrintStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReadStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReturnStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::RewindStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::StopStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncAllStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncImagesStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncMemoryStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::UnlockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WriteStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ComputedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ArithmeticIfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PauseStmt, false&gt;&gt; const&amp;, Fortran::semantics::ExprChecker&amp;)::'lambda'(Fortran::semantics::ExprChecker const&amp;)&amp;&amp;, unsigned long, std::variant&lt;Fortran::common::Indirection&lt;Fortran::parser::AllocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BackspaceStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CloseStmt, false&gt;, Fortran::parser::ContinueStmt, Fortran::common::Indirection&lt;Fortran::parser::CycleStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::DeallocateStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EndfileStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventPostStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::EventWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ExitStmt, false&gt;, Fortran::parser::FailImageStmt, Fortran::common::Indirection&lt;Fortran::parser::FlushStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::FormTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::GotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::InquireStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::LockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NotifyWaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::NullifyStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PointerAssignmentStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PrintStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReadStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ReturnStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::RewindStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::StopStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncAllStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncImagesStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncMemoryStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SyncTeamStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::UnlockStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WaitStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WriteStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ComputedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ArithmeticIfStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssignedGotoStmt, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::PauseStmt, false&gt;&gt; const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x44116b3)
#<!-- -->23 0x000000000441edf0 void Fortran::common::log2visit::Log2VisitHelper&lt;0ul, 4ul, void, void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk&lt;Fortran::semantics::ExprChecker, Fortran::parser::Statement&lt;Fortran::parser::ActionStmt&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssociateConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BlockConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CaseConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ChangeTeamConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CriticalConstruct, false&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::LabelDoStmt, false&gt;&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::EndDoStmt, false&gt;&gt;, Fortran::common::Indirection&lt;Fortran::parser::DoConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectRankConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectTypeConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CompilerDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenACCConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AccEndCombinedDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenMPConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OmpEndLoopDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CUFKernelDoConstruct, false&gt;&gt;(std::variant&lt;Fortran::parser::Statement&lt;Fortran::parser::ActionStmt&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssociateConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BlockConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CaseConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ChangeTeamConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CriticalConstruct, false&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::LabelDoStmt, false&gt;&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::EndDoStmt, false&gt;&gt;, Fortran::common::Indirection&lt;Fortran::parser::DoConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectRankConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectTypeConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CompilerDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenACCConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AccEndCombinedDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenMPConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OmpEndLoopDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CUFKernelDoConstruct, false&gt;&gt; const&amp;, Fortran::semantics::ExprChecker&amp;)::'lambda'(Fortran::semantics::ExprChecker const&amp;), std::variant&lt;Fortran::parser::Statement&lt;Fortran::parser::ActionStmt&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssociateConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BlockConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CaseConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ChangeTeamConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CriticalConstruct, false&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::LabelDoStmt, false&gt;&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::EndDoStmt, false&gt;&gt;, Fortran::common::Indirection&lt;Fortran::parser::DoConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectRankConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectTypeConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CompilerDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenACCConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AccEndCombinedDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenMPConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OmpEndLoopDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CUFKernelDoConstruct, false&gt;&gt; const&amp;&gt;(void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk&lt;Fortran::semantics::ExprChecker, Fortran::parser::Statement&lt;Fortran::parser::ActionStmt&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssociateConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BlockConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CaseConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ChangeTeamConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CriticalConstruct, false&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::LabelDoStmt, false&gt;&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::EndDoStmt, false&gt;&gt;, Fortran::common::Indirection&lt;Fortran::parser::DoConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectRankConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectTypeConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CompilerDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenACCConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AccEndCombinedDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenMPConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OmpEndLoopDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CUFKernelDoConstruct, false&gt;&gt;(std::variant&lt;Fortran::parser::Statement&lt;Fortran::parser::ActionStmt&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssociateConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BlockConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CaseConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ChangeTeamConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CriticalConstruct, false&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::LabelDoStmt, false&gt;&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::EndDoStmt, false&gt;&gt;, Fortran::common::Indirection&lt;Fortran::parser::DoConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectRankConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectTypeConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CompilerDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenACCConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AccEndCombinedDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenMPConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OmpEndLoopDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CUFKernelDoConstruct, false&gt;&gt; const&amp;, Fortran::semantics::ExprChecker&amp;)::'lambda'(Fortran::semantics::ExprChecker const&amp;)&amp;&amp;, unsigned long, std::variant&lt;Fortran::parser::Statement&lt;Fortran::parser::ActionStmt&gt;, Fortran::common::Indirection&lt;Fortran::parser::AssociateConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::BlockConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CaseConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ChangeTeamConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CriticalConstruct, false&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::LabelDoStmt, false&gt;&gt;, Fortran::parser::Statement&lt;Fortran::common::Indirection&lt;Fortran::parser::EndDoStmt, false&gt;&gt;, Fortran::common::Indirection&lt;Fortran::parser::DoConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::IfConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectRankConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::SelectTypeConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::WhereConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::ForallConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CompilerDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenACCConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::AccEndCombinedDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OpenMPConstruct, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::OmpEndLoopDirective, false&gt;, Fortran::common::Indirection&lt;Fortran::parser::CUFKernelDoConstruct, false&gt;&gt; const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x441edf0)
#<!-- -->24 0x000000000441f1bd void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk&lt;Fortran::semantics::ExprChecker&gt;(std::__cxx11::list&lt;Fortran::parser::ExecutionPartConstruct, std::allocator&lt;Fortran::parser::ExecutionPartConstruct&gt;&gt; const&amp;, Fortran::semantics::ExprChecker&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x441f1bd)
#<!-- -->25 0x000000000441f544 void Fortran::parser::detail::ParseTreeVisitorLookupScope::Walk&lt;Fortran::semantics::ExprChecker&gt;(std::__cxx11::list&lt;Fortran::parser::ExecutionPartConstruct, std::allocator&lt;Fortran::parser::ExecutionPartConstruct&gt;&gt; const&amp;, Fortran::semantics::ExprChecker&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x441f544)
#<!-- -->26 0x0000000004421e41 Fortran::semantics::ExprChecker::Walk(Fortran::parser::Program const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x4421e41)
#<!-- -->27 0x0000000004541f9a Fortran::semantics::Semantics::Perform() (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x4541f9a)
#<!-- -->28 0x0000000003a537bd Fortran::frontend::FrontendAction::runSemanticChecks() (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3a537bd)
#<!-- -->29 0x0000000003de1932 Fortran::frontend::CodeGenAction::beginSourceFileAction() (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3de1932)
#<!-- -->30 0x0000000003a51f8d Fortran::frontend::FrontendAction::beginSourceFile(Fortran::frontend::CompilerInstance&amp;, Fortran::frontend::FrontendInputFile const&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3a51f8d)
#<!-- -->31 0x0000000003a42c27 Fortran::frontend::CompilerInstance::executeAction(Fortran::frontend::FrontendAction&amp;) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3a42c27)
#<!-- -->32 0x0000000003a59c03 Fortran::frontend::executeCompilerInvocation(Fortran::frontend::CompilerInstance*) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x3a59c03)
#<!-- -->33 0x0000000001f7cd27 fc1_main(llvm::ArrayRef&lt;char const*&gt;, char const*) (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x1f7cd27)
#<!-- -->34 0x0000000001e5068e main (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x1e5068e)
#<!-- -->35 0x00007f2063629d90 (/lib/x86_64-linux-gnu/libc.so.6+0x29d90)
#<!-- -->36 0x00007f2063629e40 __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x29e40)
#<!-- -->37 0x0000000001f7b795 _start (/opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin/flang+0x1f7b795)
flang-20: error: unable to execute command: Aborted (core dumped)
flang-20: error: flang frontend command failed due to signal (use -v to see invocation)
flang version 20.0.0git (https://github.com/llvm/llvm-project.git 97097958fdf525e8c14fcdde94231bae72ea2673)
Target: x86_64-unknown-linux-gnu
Thread model: posix
InstalledDir: /opt/compiler-explorer/clang-llvmflang-trunk-20250107/bin
flang-20: note: diagnostic msg: 
********************

PLEASE ATTACH THE FOLLOWING FILES TO THE BUG REPORT:
Preprocessed source(s) and associated run script(s) are located at:
flang-20: note: diagnostic msg: /tmp/example-a9819a
flang-20: note: diagnostic msg: /tmp/example-a9819a.sh
flang-20: note: diagnostic msg: 

********************
Compiler returned: 254

</details>

The test case was generated by a fuzzer.

@k-arrows
Copy link

k-arrows commented Jan 8, 2025

I think the following is a minimal reproducer:
https://godbolt.org/z/T544rEqcG

integer a(1,1)
a = a(a,1)
end

klausler added a commit to klausler/llvm-project that referenced this issue Jan 8, 2025
@klausler klausler self-assigned this Jan 8, 2025
@klausler klausler linked a pull request Jan 8, 2025 that will close this issue
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
crash Prefer [crash-on-valid] or [crash-on-invalid] flang:frontend generated by fuzzer
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants