From: Thomas Koenig Date: Sun, 10 Nov 2019 11:19:13 +0000 (+0000) Subject: Put vtab into RO section, same for __def_init if it contains an initializer. X-Git-Tag: releases/gcc-9.3.0~401 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=df6a2bb4573711543c08c6c4e71c5e04a861a57b;p=thirdparty%2Fgcc.git Put vtab into RO section, same for __def_init if it contains an initializer. 2019-11-10 Thomas Koenig Backport from trunk PR fortran/92113 * trans-decl.c (gfc_get_symbol_decl): If __def_init actually contains a value, put it into the read-only section. From-SVN: r278015 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 307f8ba5a18c..42430e46ef69 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,10 @@ +2019-11-10 Thomas Koenig + + Backport from trunk + PR fortran/92113 + * trans-decl.c (gfc_get_symbol_decl): If __def_init actually + contains a value, put it into the read-only section. + 2019-11-10 Thomas Koenig Backport from trunk diff --git a/gcc/fortran/trans-decl.c b/gcc/fortran/trans-decl.c index d1a6172063ed..27613f761e3c 100644 --- a/gcc/fortran/trans-decl.c +++ b/gcc/fortran/trans-decl.c @@ -1885,13 +1885,18 @@ gfc_get_symbol_decl (gfc_symbol * sym) if (sym->attr.associate_var) GFC_DECL_ASSOCIATE_VAR_P (decl) = 1; - /* We no longer mark __def_init as read-only so it does not take up - space in the read-only section and dan go into the BSS instead, - see PR 84487. Marking this as artificial means that OpenMP will - treat this as predetermined shared. */ - if (sym->attr.vtab - || (sym->name[0] == '_' && gfc_str_startswith (sym->name, "__def_init"))) - DECL_ARTIFICIAL (decl) = 1; + /* We only mark __def_init as read-only if it actually has an + initializer so it does not needlessly take up space in the + read-only section and can go into the BSS instead, see PR 84487. + Marking this as artificial means that OpenMP will treat this as + predetermined shared. */ + + if (sym->attr.vtab || gfc_str_startswith (sym->name, "__def_init")) + { + DECL_ARTIFICIAL (decl) = 1; + if (sym->attr.vtab || sym->value) + TREE_READONLY (decl) = 1; + } return decl; }