diff --git a/flang/lib/Semantics/resolve-names.cpp b/flang/lib/Semantics/resolve-names.cpp index 398f45c5c4ae3..f69e7702559f5 100644 --- a/flang/lib/Semantics/resolve-names.cpp +++ b/flang/lib/Semantics/resolve-names.cpp @@ -3248,7 +3248,12 @@ Symbol *SubprogramVisitor::GetSpecificFromGeneric(const parser::Name &name) { if (!specific) { specific = &currScope().MakeSymbol(name.source, Attrs{}, SubprogramDetails{}); - details->set_specific(Resolve(name, *specific)); + if (details->derivedType()) { + // A specific procedure with the same name as a derived type + SayAlreadyDeclared(name, *details->derivedType()); + } else { + details->set_specific(Resolve(name, *specific)); + } } else if (isGeneric()) { SayAlreadyDeclared(name, *specific); } diff --git a/flang/test/Semantics/resolve18.f90 b/flang/test/Semantics/resolve18.f90 index 94b217e248f03..dd9214533b26e 100644 --- a/flang/test/Semantics/resolve18.f90 +++ b/flang/test/Semantics/resolve18.f90 @@ -63,6 +63,15 @@ module m4b function foo(x) end end +module m4c + type :: foo + end type + interface foo + !ERROR: 'foo' is already declared in this scoping unit + real function foo() + end function foo + end interface foo +end ! Use associating a name that is a generic and a derived type module m5a