On Sat, 5 Sep 2020, Jakub Jelinek wrote: > Hi! > > The following patch adds streaming of edge goto_locus (both LOCATION_LOCUS > and LOCATION_BLOCK from it), the PR shows a testcase (inappropriate for > gcc testsuite) where the lack of streaming of goto_locus results in worse > debug info. > Earlier version of the patch (without the output_function changes) failed > miserably, because on the order mismatch - input_function would > first input_cfg, then input_eh_regions and then input_bb (all of which now > have locations), while output_function used output_eh_regions, then output_bb > and then output_cfg. *_cfg went to a separate stream... > Now, is there a reason why the order is different?
It's probably simply an oversight. > Bootstrap/regtest on x86_64-linux and i686-linux went fine after changing > that, > including lto bootstrap on x86_64-linux. OK. Thanks, Richard. > If the intent is that the cfg could be read separately from the rest of > function or vice versa, alternatively we'd need to clear_line_info (); > before output_eh_regions and before/after output_cfg to make them > independent. > > 2020-09-05 Jakub Jelinek <ja...@redhat.com> > > PR debug/94235 > * lto-streamer-out.c (output_cfg): Also stream goto_locus for edges. > Use bp_pack_var_len_unsigned instead of streamer_write_uhwi to stream > e->dest->index and e->flags. > (output_function): Call output_cfg before output_ssa_name, rather than > after streaming all bbs. > * lto-streamer-in.c (input_cfg): Stream in goto_locus for edges. > Use bp_unpack_var_len_unsigned instead of streamer_read_uhwi to stream > in dest_index and edge_flags. > > --- gcc/lto-streamer-out.c.jj 2020-09-04 11:53:22.673647471 +0200 > +++ gcc/lto-streamer-out.c 2020-09-04 22:42:14.595657649 +0200 > @@ -2100,9 +2100,11 @@ output_cfg (struct output_block *ob, str > streamer_write_uhwi (ob, EDGE_COUNT (bb->succs)); > FOR_EACH_EDGE (e, ei, bb->succs) > { > - streamer_write_uhwi (ob, e->dest->index); > + bitpack_d bp = bitpack_create (ob->main_stream); > + bp_pack_var_len_unsigned (&bp, e->dest->index); > + bp_pack_var_len_unsigned (&bp, e->flags); > + stream_output_location_and_block (ob, &bp, e->goto_locus); > e->probability.stream_out (ob); > - streamer_write_uhwi (ob, e->flags); > } > } > > @@ -2418,6 +2420,8 @@ output_function (struct cgraph_node *nod > streamer_write_uhwi (ob, 1); > output_struct_function_base (ob, fn); > > + output_cfg (ob, fn); > + > /* Output all the SSA names used in the function. */ > output_ssa_names (ob, fn); > > @@ -2430,8 +2434,6 @@ output_function (struct cgraph_node *nod > > /* The terminator for this function. */ > streamer_write_record_start (ob, LTO_null); > - > - output_cfg (ob, fn); > } > else > streamer_write_uhwi (ob, 0); > --- gcc/lto-streamer-in.c.jj 2020-09-04 11:55:08.069114502 +0200 > +++ gcc/lto-streamer-in.c 2020-09-04 13:26:04.439987053 +0200 > @@ -780,23 +780,19 @@ input_cfg (class lto_input_block *ib, cl > /* Connect up the CFG. */ > for (i = 0; i < edge_count; i++) > { > - unsigned int dest_index; > - unsigned int edge_flags; > - basic_block dest; > - profile_probability probability; > - edge e; > - > - dest_index = streamer_read_uhwi (ib); > - probability = profile_probability::stream_in (ib); > - edge_flags = streamer_read_uhwi (ib); > - > - dest = BASIC_BLOCK_FOR_FN (fn, dest_index); > + bitpack_d bp = streamer_read_bitpack (ib); > + unsigned int dest_index = bp_unpack_var_len_unsigned (&bp); > + unsigned int edge_flags = bp_unpack_var_len_unsigned (&bp); > + basic_block dest = BASIC_BLOCK_FOR_FN (fn, dest_index); > > if (dest == NULL) > dest = make_new_block (fn, dest_index); > > - e = make_edge (bb, dest, edge_flags); > - e->probability = probability; > + edge e = make_edge (bb, dest, edge_flags); > + data_in->location_cache.input_location_and_block (&e->goto_locus, > + &bp, ib, data_in); > + e->probability = profile_probability::stream_in (ib); > + > } > > index = streamer_read_hwi (ib); > > Jakub > > -- Richard Biener <rguent...@suse.de> SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg, Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)