]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
PR fortran/95500 - Segfault compiling extra interface on intrinsic
authorHarald Anlauf <anlauf@gmx.de>
Thu, 4 Jun 2020 19:00:33 +0000 (21:00 +0200)
committerHarald Anlauf <anlauf@gmx.de>
Fri, 5 Jun 2020 18:50:04 +0000 (20:50 +0200)
Converting an expression so that it can be passed by reference could
result in a NULL pointer dereference.

2020-06-04  Steven G. Kargl  <kargl@gcc.gnu.org>
    Harald Anlauf  <anlauf@gmx.de>

gcc/fortran/
PR fortran/95500
* trans-expr.c (gfc_conv_expr_reference): Do not dereference NULL
pointer.

gcc/testsuite/
PR fortran/95500
* gfortran.dg/pr95500.f90: New test.

(cherry picked from commit 8c727bdf4acf28c8315b119a1c8f6d6af745c2af)

gcc/fortran/trans-expr.c
gcc/testsuite/gfortran.dg/pr95500.f90 [new file with mode: 0644]

index fe10d52dd164448f885d0c65f585fb10ce8c2fb6..b34e8c6020b3fd9bf5bc75775deac2a5119dd44f 100644 (file)
@@ -8558,6 +8558,7 @@ gfc_conv_expr_reference (gfc_se * se, gfc_expr * expr, bool add_clobber)
 
   if (expr->expr_type == EXPR_FUNCTION
       && ((expr->value.function.esym
+          && expr->value.function.esym->result
           && expr->value.function.esym->result->attr.pointer
           && !expr->value.function.esym->result->attr.dimension)
          || (!expr->value.function.esym && !expr->ref
diff --git a/gcc/testsuite/gfortran.dg/pr95500.f90 b/gcc/testsuite/gfortran.dg/pr95500.f90
new file mode 100644 (file)
index 0000000..e9eb7c6
--- /dev/null
@@ -0,0 +1,15 @@
+! { dg-do compile }
+! PR fortran/95500 - ICE compiling extra interface on intrinsic
+
+program test_intrinsic
+  implicit none
+  intrinsic :: alog
+  intrinsic :: dlog
+  real (4), parameter :: one = 1
+
+  interface ln
+     procedure :: alog, dlog
+  end interface ln
+
+  write (*,*) 'ln  1', ln (one)
+end program test_intrinsic