diff options
author | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2015-12-22 19:42:24 +0000 |
---|---|---|
committer | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2015-12-22 19:42:24 +0000 |
commit | a08574d7e1a4c0c3cd29c36e739c3f05f34e652e (patch) | |
tree | a8d42a55a283fef873d7bbbede9d1387b48f417a /gcc/gimple-pretty-print.c | |
parent | 7a34692065764be875267948c54789668e620c48 (diff) |
PR ipa/67811
* gimple.h (struct gtransaction): Add label_norm, label_uninst;
replace label with label_over.
(gimple_build_transaction): Remove label parameter.
(gimple_transaction_label_norm): New.
(gimple_transaction_label_uninst): New.
(gimple_transaction_label_over): Rename from gimple_transaction_label.
(gimple_transaction_label_norm_ptr): New.
(gimple_transaction_label_uninst_ptr): New.
(gimple_transaction_label_over_ptr): Rename from
gimple_transaction_label_ptr.
(gimple_transaction_set_label_norm): New.
(gimple_transaction_set_label_uninst): New.
(gimple_transaction_set_label_over): Rename from
gimple_transaction_set_label.
* gimple-pretty-print.c (dump_gimple_transaction): Update.
* gimple-streamer-in.c (input_gimple_stmt) [GIMPLE_TRANSACTION]: Same.
* gimple-streamer-out.c (output_gimple_stmt) [GIMPLE_TRANSACTION]: Same.
* gimple-walk.c (walk_gimple_op) [GIMPLE_TRANSACTION]: Same.
* tree-cfg.c (make_edges_bb) [GIMPLE_TRANSACTION]: Same.
(cleanup_dead_labels) [GIMPLE_TRANSACTION]: Same.
(verify_gimple_transaction): Same.
(gimple_redirect_edge_and_branch) [GIMPLE_TRANSACTION]: Same.
* tree-inline.c (remap_gimple_stmt) [GIMPLE_TRANSACTION]: Same.
* gimple.c (gimple_build_transaction): Remove label parameter;
initialize all three label memebers.
* gimplify.c (gimplify_transaction): Update call
to gimple_build_transaction.
* trans-mem.c (make_tm_uninst): New.
(lower_transaction): Create uninstrumented code path here...
(ipa_tm_scan_calls_transaction): ... not here.
(ipa_uninstrument_transaction): Remove.
testsuite/
* g++.dg/tm/noexcept-1.C: Update expected must_not_throw count.
* g++.dg/tm/noexcept-4.C: Likewise.
* g++.dg/tm/noexcept-5.C: Likewise.
* g++.dg/tm/pr67811.C: New.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@231907 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/gimple-pretty-print.c')
-rw-r--r-- | gcc/gimple-pretty-print.c | 48 |
1 files changed, 31 insertions, 17 deletions
diff --git a/gcc/gimple-pretty-print.c b/gcc/gimple-pretty-print.c index 01e9b6b004c..41e4c5e8dab 100644 --- a/gcc/gimple-pretty-print.c +++ b/gcc/gimple-pretty-print.c @@ -1607,8 +1607,11 @@ dump_gimple_transaction (pretty_printer *buffer, gtransaction *gs, if (flags & TDF_RAW) { dump_gimple_fmt (buffer, spc, flags, - "%G [SUBCODE=%x,LABEL=%T] <%+BODY <%S> >", - gs, subcode, gimple_transaction_label (gs), + "%G [SUBCODE=%x,NORM=%T,UNINST=%T,OVER=%T] " + "<%+BODY <%S> >", + gs, subcode, gimple_transaction_label_norm (gs), + gimple_transaction_label_uninst (gs), + gimple_transaction_label_over (gs), gimple_transaction_body (gs)); } else @@ -1621,13 +1624,35 @@ dump_gimple_transaction (pretty_printer *buffer, gtransaction *gs, pp_string (buffer, "__transaction_atomic"); subcode &= ~GTMA_DECLARATION_MASK; - if (subcode || gimple_transaction_label (gs)) + if (gimple_transaction_body (gs)) + { + newline_and_indent (buffer, spc + 2); + pp_left_brace (buffer); + pp_newline (buffer); + dump_gimple_seq (buffer, gimple_transaction_body (gs), + spc + 4, flags); + newline_and_indent (buffer, spc + 2); + pp_right_brace (buffer); + } + else { pp_string (buffer, " //"); - if (gimple_transaction_label (gs)) + if (gimple_transaction_label_norm (gs)) + { + pp_string (buffer, " NORM="); + dump_generic_node (buffer, gimple_transaction_label_norm (gs), + spc, flags, false); + } + if (gimple_transaction_label_uninst (gs)) { - pp_string (buffer, " LABEL="); - dump_generic_node (buffer, gimple_transaction_label (gs), + pp_string (buffer, " UNINST="); + dump_generic_node (buffer, gimple_transaction_label_uninst (gs), + spc, flags, false); + } + if (gimple_transaction_label_over (gs)) + { + pp_string (buffer, " OVER="); + dump_generic_node (buffer, gimple_transaction_label_over (gs), spc, flags, false); } if (subcode) @@ -1668,17 +1693,6 @@ dump_gimple_transaction (pretty_printer *buffer, gtransaction *gs, pp_right_bracket (buffer); } } - - if (!gimple_seq_empty_p (gimple_transaction_body (gs))) - { - newline_and_indent (buffer, spc + 2); - pp_left_brace (buffer); - pp_newline (buffer); - dump_gimple_seq (buffer, gimple_transaction_body (gs), - spc + 4, flags); - newline_and_indent (buffer, spc + 2); - pp_right_brace (buffer); - } } } |