diff options
author | Harald Anlauf <anlauf@gmx.de> | 2023-03-17 22:24:49 +0100 |
---|---|---|
committer | Harald Anlauf <anlauf@gmx.de> | 2023-03-19 20:32:10 +0100 |
commit | 5426ab34643d9e6502f3ee572891a03471fa33ed (patch) | |
tree | cbd06e90f1d829408b9561842e488fc8fde88fc7 /gcc | |
parent | 655689f6be8606991f8a3359eadf017af7238a88 (diff) | |
download | gcc-5426ab34643d9e6502f3ee572891a03471fa33ed.zip gcc-5426ab34643d9e6502f3ee572891a03471fa33ed.tar.gz gcc-5426ab34643d9e6502f3ee572891a03471fa33ed.tar.bz2 |
Fortran: procedures with BIND(C) attribute require explicit interface [PR85877]
gcc/fortran/ChangeLog:
PR fortran/85877
* resolve.cc (resolve_fl_procedure): Check for an explicit interface
of procedures with the BIND(C) attribute (F2018:15.4.2.2).
gcc/testsuite/ChangeLog:
PR fortran/85877
* gfortran.dg/pr85877.f90: New test.
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/fortran/resolve.cc | 10 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/pr85877.f90 | 25 |
2 files changed, 35 insertions, 0 deletions
diff --git a/gcc/fortran/resolve.cc b/gcc/fortran/resolve.cc index ba603b4..f3f3051 100644 --- a/gcc/fortran/resolve.cc +++ b/gcc/fortran/resolve.cc @@ -13871,6 +13871,16 @@ check_formal: } } } + + /* F2018:15.4.2.2 requires an explicit interface for procedures with the + BIND(C) attribute. */ + if (sym->attr.is_bind_c && sym->attr.if_source == IFSRC_UNKNOWN) + { + gfc_error ("Interface of %qs at %L must be explicit", + sym->name, &sym->declared_at); + return false; + } + return true; } diff --git a/gcc/testsuite/gfortran.dg/pr85877.f90 b/gcc/testsuite/gfortran.dg/pr85877.f90 new file mode 100644 index 0000000..d8f08cb --- /dev/null +++ b/gcc/testsuite/gfortran.dg/pr85877.f90 @@ -0,0 +1,25 @@ +! { dg-do compile } +! PR fortran/85877 +! A procedure with the bind(c) attribute shall have an explicit interface +! Contributed by G. Steinmetz + +function f() bind(c) + f = 42. +end + +subroutine p + bind(c) f ! { dg-error "must be explicit" } + x = f() +end + +function g() bind(c) + g = 42. +end + +subroutine s + interface + function g() bind(c) + end function g + end interface + x = g() +end |