Commit c28d1d9b by Tobias Burnus Committed by Tobias Burnus

re PR fortran/45742 (VOLATILE has no effect)

2010-11-13  Tobias Burnus  <burnus@net-b.de>

        PR fortran/45742
        * trans-common.c (build_field): Add TREE_SIDE_EFFECTS for
        * volatile.
        * trans-decl.c (gfc_finish_var_decl): Ditto.
        (create_function_arglist): Handle volatile dummy arguments.

2010-11-13  Tobias Burnus  <burnus@net-b.de>

        PR fortran/45742
        * gfortran.dg/volatile12.f90: New.

From-SVN: r166701
parent 2f413185
2010-11-13 Tobias Burnus <burnus@net-b.de>
PR fortran/45742
* trans-common.c (build_field): Add TREE_SIDE_EFFECTS for volatile.
* trans-decl.c (gfc_finish_var_decl): Ditto.
(create_function_arglist): Handle volatile dummy arguments.
2010-11-12 Joseph Myers <joseph@codesourcery.com> 2010-11-12 Joseph Myers <joseph@codesourcery.com>
* Make-lang.in (gfortranspec.o): Use $(OPTS_H). * Make-lang.in (gfortranspec.o): Use $(OPTS_H).
......
...@@ -322,6 +322,7 @@ build_field (segment_info *h, tree union_type, record_layout_info rli) ...@@ -322,6 +322,7 @@ build_field (segment_info *h, tree union_type, record_layout_info rli)
{ {
tree new_type; tree new_type;
TREE_THIS_VOLATILE (field) = 1; TREE_THIS_VOLATILE (field) = 1;
TREE_SIDE_EFFECTS (field) = 1;
new_type = build_qualified_type (TREE_TYPE (field), TYPE_QUAL_VOLATILE); new_type = build_qualified_type (TREE_TYPE (field), TYPE_QUAL_VOLATILE);
TREE_TYPE (field) = new_type; TREE_TYPE (field) = new_type;
} }
......
...@@ -555,6 +555,7 @@ gfc_finish_var_decl (tree decl, gfc_symbol * sym) ...@@ -555,6 +555,7 @@ gfc_finish_var_decl (tree decl, gfc_symbol * sym)
if (sym->attr.volatile_) if (sym->attr.volatile_)
{ {
TREE_THIS_VOLATILE (decl) = 1; TREE_THIS_VOLATILE (decl) = 1;
TREE_SIDE_EFFECTS (decl) = 1;
new_type = build_qualified_type (TREE_TYPE (decl), TYPE_QUAL_VOLATILE); new_type = build_qualified_type (TREE_TYPE (decl), TYPE_QUAL_VOLATILE);
TREE_TYPE (decl) = new_type; TREE_TYPE (decl) = new_type;
} }
...@@ -1944,10 +1945,19 @@ create_function_arglist (gfc_symbol * sym) ...@@ -1944,10 +1945,19 @@ create_function_arglist (gfc_symbol * sym)
if (f->sym->attr.proc_pointer) if (f->sym->attr.proc_pointer)
type = build_pointer_type (type); type = build_pointer_type (type);
if (f->sym->attr.volatile_)
type = build_qualified_type (type, TYPE_QUAL_VOLATILE);
/* Build the argument declaration. */ /* Build the argument declaration. */
parm = build_decl (input_location, parm = build_decl (input_location,
PARM_DECL, gfc_sym_identifier (f->sym), type); PARM_DECL, gfc_sym_identifier (f->sym), type);
if (f->sym->attr.volatile_)
{
TREE_THIS_VOLATILE (parm) = 1;
TREE_SIDE_EFFECTS (parm) = 1;
}
/* Fill in arg stuff. */ /* Fill in arg stuff. */
DECL_CONTEXT (parm) = fndecl; DECL_CONTEXT (parm) = fndecl;
DECL_ARG_TYPE (parm) = TREE_VALUE (typelist); DECL_ARG_TYPE (parm) = TREE_VALUE (typelist);
......
2010-11-13 Tobias Burnus <burnus@net-b.de>
PR fortran/45742
* gfortran.dg/volatile12.f90: New.
2010-11-13 Paolo Bonzini <bonzini@gnu.org> 2010-11-13 Paolo Bonzini <bonzini@gnu.org>
PR c/20385 PR c/20385
......
! { dg-do compile }
! { dg-options "-fdump-tree-optimized -O3" }
!
! PR fortran/45742
!
subroutine sub(arg)
integer, volatile :: arg
if (arg /= arg) call I_dont_exist()
end
! { dg-final { scan-tree-dump "integer.kind=.. . volatile arg" "optimized" } }
! { dg-final { scan-tree-dump-times " =.v. arg;" 2 "optimized" } }
! { dg-final { scan-tree-dump "i_dont_exist" "optimized" } }
! { dg-final { cleanup-tree-dump "original" } }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment