From: Andrew Benson Date: Wed, 22 Aug 2018 17:47:53 +0000 (+0000) Subject: module.c (load_generic_interfaces): Move call to find_symbol() so that only occurs... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=66f32b0e2131ce85102a5fb1acee118c416afd9b;p=gcc.git module.c (load_generic_interfaces): Move call to find_symbol() so that only occurs if actually needed. 2018-08-22 Andrew Benson * module.c (load_generic_interfaces): Move call to find_symbol() so that only occurs if actually needed. From-SVN: r263784 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 2cd5dcf3304..88edff3eed6 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,8 @@ +2018-08-22 Andrew Benson + + * module.c (load_generic_interfaces): Move call to find_symbol() + so that only occurs if actually needed. + 2018-08-22 Janus Weil PR fortran/86888 diff --git a/gcc/fortran/module.c b/gcc/fortran/module.c index 196da9c0ff7..993ea9f16b9 100644 --- a/gcc/fortran/module.c +++ b/gcc/fortran/module.c @@ -4559,9 +4559,6 @@ load_generic_interfaces (void) /* Decide if we need to load this one or not. */ p = find_use_name_n (name, &i, false); - st = find_symbol (gfc_current_ns->sym_root, - name, module_name, 1); - if (!p || gfc_find_symbol (p, NULL, 0, &sym)) { /* Skip the specific names for these cases. */ @@ -4570,6 +4567,9 @@ load_generic_interfaces (void) continue; } + st = find_symbol (gfc_current_ns->sym_root, + name, module_name, 1); + /* If the symbol exists already and is being USEd without being in an ONLY clause, do not load a new symtree(11.3.2). */ if (!only_flag && st)