diff options
author | Andrew Haley <aph@cygnus.com> | 1999-01-13 06:13:37 +0000 |
---|---|---|
committer | Andrew Haley <aph@gcc.gnu.org> | 1999-01-13 06:13:37 +0000 |
commit | 9684789222a5e8e34eac4565cd42f4e848a942fc (patch) | |
tree | 2c27d075b4014382a25b9f3db1ff1efc6de4ed40 /gcc/java/parse.y | |
parent | ba179f9f6f3c593721837c6c24cc39296a6eb92d (diff) | |
download | gcc-9684789222a5e8e34eac4565cd42f4e848a942fc.zip gcc-9684789222a5e8e34eac4565cd42f4e848a942fc.tar.gz gcc-9684789222a5e8e34eac4565cd42f4e848a942fc.tar.bz2 |
expr.c (generate_name): Name prefix changed to avoid clashes with assembler temp labels.
1999-01-13 Andrew Haley <aph@cygnus.com>
* expr.c (generate_name): Name prefix changed to avoid clashes
with assembler temp labels.
* parse.y (patch_synchronized_statement): Set TREE_SIDE_EFFECTS on
MODIFY_EXPR. Without this, code for the assignement may not be
generated at all and the synchronized statement will read an
uninitialized variable.
From-SVN: r24649
Diffstat (limited to 'gcc/java/parse.y')
-rw-r--r-- | gcc/java/parse.y | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/gcc/java/parse.y b/gcc/java/parse.y index 03d04ee..0384004 100644 --- a/gcc/java/parse.y +++ b/gcc/java/parse.y @@ -10823,7 +10823,7 @@ patch_synchronized_statement (node, wfl_op1) tree expr = java_complete_tree (TREE_OPERAND (node, 0)); tree block = TREE_OPERAND (node, 1); - tree enter, exit, finally, expr_decl; + tree enter, exit, finally, expr_decl, assignment; if (expr == error_mark_node) { @@ -10863,13 +10863,13 @@ patch_synchronized_statement (node, wfl_op1) BUILD_MONITOR_EXIT (exit, expr_decl); CAN_COMPLETE_NORMALLY (enter) = 1; CAN_COMPLETE_NORMALLY (exit) = 1; + assignment = build (MODIFY_EXPR, NULL_TREE, expr_decl, expr); + TREE_SIDE_EFFECTS (assignment) = 1; node = build1 (CLEANUP_POINT_EXPR, NULL_TREE, build (COMPOUND_EXPR, NULL_TREE, build (WITH_CLEANUP_EXPR, NULL_TREE, build (COMPOUND_EXPR, NULL_TREE, - build (MODIFY_EXPR, NULL_TREE, - expr_decl, expr), - enter), + assignment, enter), NULL_TREE, exit), block)); node = build_expr_block (node, expr_decl); |