GCC Middle and Back End API Reference
exploded-graph.h
Go to the documentation of this file.
1/* Classes for managing a directed graph of <point, state> pairs.
2 Copyright (C) 2019-2026 Free Software Foundation, Inc.
3 Contributed by David Malcolm <dmalcolm@redhat.com>.
4
5This file is part of GCC.
6
7GCC is free software; you can redistribute it and/or modify it
8under the terms of the GNU General Public License as published by
9the Free Software Foundation; either version 3, or (at your option)
10any later version.
11
12GCC is distributed in the hope that it will be useful, but
13WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15General Public License for more details.
16
17You should have received a copy of the GNU General Public License
18along with GCC; see the file COPYING3. If not see
19<http://www.gnu.org/licenses/>. */
20
21#ifndef GCC_ANALYZER_EXPLODED_GRAPH_H
22#define GCC_ANALYZER_EXPLODED_GRAPH_H
23
24#include "alloc-pool.h"
25#include "fibonacci_heap.h"
26#include "supergraph.h"
27#include "sbitmap.h"
28#include "shortest-paths.h"
29#include "analyzer/sm.h"
33
34namespace ana {
35
36/* Concrete implementation of region_model_context, wiring it up to the
37 rest of the analysis engine. */
38
40{
41 public:
43 exploded_node *enode_for_diag,
44
45 /* TODO: should we be getting the ECs from the
46 old state, rather than the new? */
47 const program_state *old_state,
48 program_state *new_state,
49 uncertainty_t *uncertainty,
50 path_context *path_ctxt,
51 const gimple *stmt = nullptr,
52 bool *out_could_have_done_work = nullptr);
53
56 uncertainty_t *uncertainty,
57 logger *logger = nullptr);
58
59 bool
60 warn_at (std::unique_ptr<pending_diagnostic> d,
61 pending_location &&ploc) final override;
62 void add_note (std::unique_ptr<pending_note> pn) final override;
63 void add_event (std::unique_ptr<checker_event> event) final override;
64 void on_svalue_leak (const svalue *) override;
65 void on_liveness_change (const svalue_set &live_svalues,
66 const region_model *model) final override;
67 logger *get_logger () final override
68 {
69 return m_logger.get_logger ();
70 }
71
73 const svalue *sval,
75
76 void on_condition (const svalue *lhs,
77 enum tree_code op,
78 const svalue *rhs) final override;
79
80 void on_bounded_ranges (const svalue &sval,
81 const bounded_ranges &ranges) final override;
82
83 void on_pop_frame (const frame_region *frame_reg) final override;
84
85 void on_unknown_change (const svalue *sval, bool is_mutable) final override;
86
87 void on_phi (const gphi *phi, tree rhs) final override;
88
90 const dump_location_t &loc) final override;
91
92 void on_escaped_function (tree fndecl) final override;
93
95
96 void purge_state_involving (const svalue *sval) final override;
97
98 void bifurcate (std::unique_ptr<custom_edge_info> info) final override;
99 void terminate_path () final override;
100 const extrinsic_state *get_ext_state () const final override
101 {
102 return &m_ext_state;
103 }
104 bool
105 get_state_map_by_name (const char *name,
106 sm_state_map **out_smap,
107 const state_machine **out_sm,
108 unsigned *out_sm_idx,
109 std::unique_ptr<sm_context> *out_sm_context) override;
110
111 const gimple *get_stmt () const override { return m_stmt; }
112 const exploded_graph *get_eg () const override { return m_eg; }
113
114 const program_state *get_state () const override { return m_new_state; }
115
116 void maybe_did_work () override;
117 bool checking_for_infinite_loop_p () const override { return false; }
119
122
133};
134
135/* A <program_point, program_state> pair, used internally by
136 exploded_node as its immutable data, and as a key for identifying
137 exploded_nodes we've already seen in the graph. */
138
140{
141public:
143 const program_state &state)
144 : m_point (point),
145 m_state (state),
146 m_hash (m_point.hash () ^ m_state.hash ())
147 {
148 /* We shouldn't be building point_and_states and thus exploded_nodes
149 for states that aren't valid. */
150 gcc_assert (state.m_valid);
151 }
152
153 hashval_t hash () const
154 {
155 return m_hash;
156 }
157 bool operator== (const point_and_state &other) const
158 {
159 return m_point == other.m_point && m_state == other.m_state;
160 }
161
162 const program_point &get_point () const { return m_point; }
163 const program_state &get_state () const { return m_state; }
164
166 {
167 m_state = state;
168 m_hash = m_point.hash () ^ m_state.hash ();
169 }
170
171 void validate (const extrinsic_state &ext_state) const;
172
173private:
176 hashval_t m_hash;
177};
178
179/* A traits class for exploded graphs and their nodes and edges. */
180
182{
187 {
188 dump_args_t (const exploded_graph &eg) : m_eg (eg) {}
189
190 bool show_enode_details_p (const exploded_node &enode) const;
191
192 virtual void
194
196 };
197 typedef exploded_cluster cluster_t;
198};
199
200/* An exploded_node is a unique, immutable <point, state> pair within the
201 exploded_graph.
202 Each exploded_node has a unique index within the graph
203 (for ease of debugging). */
204
205class exploded_node : public dnode<eg_traits>
206{
207 public:
208 /* Has this enode had exploded_graph::process_node called on it?
209 This allows us to distinguish enodes that were merged during
210 worklist-handling, and thus never had process_node called on them
211 (in favor of processing the merged node). */
212 enum class status
213 {
214 /* Node is in the worklist. */
216
217 /* Node has had exploded_graph::process_node called on it. */
219
220 /* Node was excluded from worklist on creation.
221 e.g. for handling exception-unwinding. */
223
224 /* Node was left unprocessed due to merger; it won't have had
225 exploded_graph::process_node called on it. */
227
228 /* Node was processed by maybe_process_run_of_enodes. */
230 };
231 static const char * status_to_str (enum status s);
232
233 exploded_node (const point_and_state &ps, int index);
234
235 hashval_t hash () const { return m_ps.hash (); }
236
237 const char * get_dot_fillcolor () const;
238 void dump_dot (graphviz_out *gv, const dump_args_t &args)
239 const final override;
240 void dump_dot_id (pretty_printer *pp) const;
241
243 void dump (FILE *fp, const extrinsic_state &ext_state) const;
244 void dump (const extrinsic_state &ext_state) const;
245
248
249 std::unique_ptr<json::object> to_json (const extrinsic_state &ext_state) const;
250
252 const gcall &call,
253 program_state *new_state,
256 const gcall &call,
257 const program_point &after_throw_point,
258 program_state *new_state,
259 bool is_rethrow,
261
263
264 const program_point &get_point () const { return m_ps.get_point (); }
265 const supernode *get_supernode () const
266 {
267 return get_point ().get_supernode ();
268 }
269 location_t get_location () const
270 {
271 return get_point ().get_location ();
272 }
274 {
275 return get_point ().get_function ();
276 }
277 int get_stack_depth () const
278 {
279 return get_point ().get_stack_depth ();
280 }
281
282 const program_state &get_state () const { return m_ps.get_state (); }
283
284 const point_and_state *get_ps_key () const { return &m_ps; }
285 const program_point *get_point_key () const { return &m_ps.get_point (); }
286
287 void dump_succs_and_preds (FILE *outf) const;
288
289 enum status get_status () const { return m_status; }
290 void set_status (enum status s)
291 {
293 m_status = s;
294 }
295
297 {
298 m_saved_diagnostics.safe_push (sd);
299 }
300 unsigned get_num_diagnostics () const
301 {
302 return m_saved_diagnostics.length ();
303 }
304 const saved_diagnostic *get_saved_diagnostic (unsigned idx) const
305 {
306 return m_saved_diagnostics[idx];
307 }
308
309private:
311
312 /* The <program_point, program_state> pair. This is const, as it
313 is immutable once the exploded_node has been created. */
315
317
318 /* The saved_diagnostics at this enode, borrowed from the
319 diagnostic_manager. */
320 auto_vec <const saved_diagnostic *> m_saved_diagnostics;
321
322public:
323 /* The index of this exploded_node. */
324 const int m_index;
325
326 /* The number of stmts that were processed when process_node was
327 called on this enode. */
329};
330
331/* An edge within the exploded graph.
332 Some exploded_edges have an underlying superedge; others don't. */
333
334class exploded_edge : public dedge<eg_traits>
335{
336 public:
338 const superedge *sedge, bool could_do_work,
339 std::unique_ptr<custom_edge_info> custom_info);
340 void dump_dot (graphviz_out *gv, const dump_args_t &args)
341 const final override;
343
344 std::unique_ptr<json::object> to_json () const;
345
346 //private:
347 const superedge *const m_sedge;
348
349 /* nullptr for most edges; will be non-NULL for special cases
350 such as an unwind from a longjmp to a setjmp, or when
351 a signal is delivered to a signal-handler. */
352 std::unique_ptr<custom_edge_info> m_custom_info;
353
354 bool could_do_work_p () const { return m_could_do_work_p; }
355
356 const gimple *maybe_get_stmt () const;
357 const operation *maybe_get_op () const;
358
359private:
361
362 /* For -Wanalyzer-infinite-loop.
363 Set to true during processing if any of the activity along
364 this edge is "externally-visible work" (and thus ruling this
365 out as being part of an infinite loop.
366
367 For example, given:
368
369 while (1)
370 do_something ();
371
372 although it is an infinite loop, presumably the point of the
373 program is the loop body, and thus reporting this as an infinite
374 loop is likely to be unhelpful to the user. */
376};
377
378/* Extra data for an exploded_edge that represents an interprocedural
379 call. */
380
382{
383public:
385 function &callee_fun)
386 : m_op (op),
387 m_callee_fun (callee_fun)
388 {}
389
390 void print (pretty_printer *pp) const final override;
391
392 void get_dot_attrs (const char *&out_style,
393 const char *&out_color) const final override;
394
396 const exploded_edge *eedge,
397 region_model_context *ctxt) const final override;
398
400 const exploded_edge *eedge,
401 region_model_context *ctxt) const final override;
402
403 void add_events_to_path (checker_path *emission_path,
404 const exploded_edge &eedge,
406 const state_transition *state_trans) const final override;
407
408 bool
409 try_to_rewind_data_flow (rewind_context &) const final override;
410
411 const gcall &get_gcall () const;
412
413private:
416};
417
418/* Extra data for an exploded_edge that represents an interprocedural
419 return. */
420
422{
423public:
424 interprocedural_return (const gcall &call_stmt)
425 : m_call_stmt (call_stmt)
426 {}
427
428 void print (pretty_printer *pp) const final override;
429
430 void get_dot_attrs (const char *&out_style,
431 const char *&out_color) const final override;
432
434 const exploded_edge *eedge,
435 region_model_context *ctxt) const final override;
436
438 const exploded_edge *eedge,
439 region_model_context *ctxt) const final override;
440
441 void add_events_to_path (checker_path *emission_path,
442 const exploded_edge &eedge,
444 const state_transition *state_trans) const final override;
445
446 bool
447 try_to_rewind_data_flow (rewind_context &) const final override;
448
449private:
451};
452
453/* Extra data for an exploded_edge that represents a rewind from a
454 longjmp to a setjmp (or from a siglongjmp to a sigsetjmp). */
455
457{
458public:
460 const gcall &longjmp_call)
462 m_longjmp_call (longjmp_call)
463 {}
464
465 void print (pretty_printer *pp) const final override
466 {
467 pp_string (pp, "rewind");
468 }
469
471 const exploded_edge *eedge,
472 region_model_context *ctxt) const final override;
473
474 void add_events_to_path (checker_path *emission_path,
475 const exploded_edge &eedge,
477 const state_transition *state_trans) const final override;
478
481 {
482 return get_enode_origin ()->get_point ();
483 }
484
487 {
488 const program_point &origin_point = get_enode_origin ()->get_point ();
489 return program_point (m_setjmp_record.m_sedge->m_dest,
490 origin_point.get_call_string ());
491 }
492
493 const gcall &get_setjmp_call () const
494 {
495 return *m_setjmp_record.m_setjmp_call;
496 }
497
498 const gcall &get_longjmp_call () const
499 {
500 return m_longjmp_call;
501 }
502
504 {
505 return m_setjmp_record.m_enode;
506 }
507
508private:
511};
512
513/* Statistics about aspects of an exploded_graph. */
514
515struct stats
516{
517 stats (int num_supernodes);
518 void log (logger *logger) const;
519 void dump (FILE *out) const;
520
521 int get_total_enodes () const;
522
527};
528
529/* Traits class for ensuring uniqueness of point_and_state data within
530 an exploded_graph. */
531
533{
534 typedef const point_and_state *key_type;
537
538 static inline hashval_t hash (const key_type &k)
539 {
540 gcc_assert (k != nullptr);
541 gcc_assert (k != reinterpret_cast<key_type> (1));
542 return k->hash ();
543 }
544 static inline bool equal_keys (const key_type &k1, const key_type &k2)
545 {
546 gcc_assert (k1 != nullptr);
547 gcc_assert (k2 != nullptr);
548 gcc_assert (k1 != reinterpret_cast<key_type> (1));
549 gcc_assert (k2 != reinterpret_cast<key_type> (1));
550 if (k1 && k2)
551 return *k1 == *k2;
552 else
553 /* Otherwise they must both be non-NULL. */
554 return k1 == k2;
555 }
556 template <typename T>
557 static inline void remove (T &)
558 {
559 /* empty; the nodes are handled elsewhere. */
560 }
561 template <typename T>
562 static inline void mark_deleted (T &entry)
563 {
564 entry.m_key = reinterpret_cast<key_type> (1);
565 }
566 template <typename T>
567 static inline void mark_empty (T &entry)
568 {
569 entry.m_key = nullptr;
570 }
571 template <typename T>
572 static inline bool is_deleted (const T &entry)
573 {
574 return entry.m_key == reinterpret_cast<key_type> (1);
575 }
576 template <typename T>
577 static inline bool is_empty (const T &entry)
578 {
579 return entry.m_key == nullptr;
580 }
581 static const bool empty_zero_p = false;
582};
583
584/* Per-program_point data for an exploded_graph. */
585
587{
589 : m_key (key), m_excess_enodes (0)
590 {}
591
594 /* The number of attempts to create an enode for this point
595 after exceeding --param=analyzer-max-enodes-per-program-point. */
597};
598
599/* Traits class for storing per-program_point data within
600 an exploded_graph. */
601
603{
604 typedef const program_point *key_type;
607
608 static inline hashval_t hash (const key_type &k)
609 {
610 gcc_assert (k != nullptr);
611 gcc_assert (k != reinterpret_cast<key_type> (1));
612 return k->hash ();
613 }
614 static inline bool equal_keys (const key_type &k1, const key_type &k2)
615 {
616 gcc_assert (k1 != nullptr);
617 gcc_assert (k2 != nullptr);
618 gcc_assert (k1 != reinterpret_cast<key_type> (1));
619 gcc_assert (k2 != reinterpret_cast<key_type> (1));
620 if (k1 && k2)
621 return *k1 == *k2;
622 else
623 /* Otherwise they must both be non-NULL. */
624 return k1 == k2;
625 }
626 template <typename T>
627 static inline void remove (T &)
628 {
629 /* empty; the nodes are handled elsewhere. */
630 }
631 template <typename T>
632 static inline void mark_deleted (T &entry)
633 {
634 entry.m_key = reinterpret_cast<key_type> (1);
635 }
636 template <typename T>
637 static inline void mark_empty (T &entry)
638 {
639 entry.m_key = nullptr;
640 }
641 template <typename T>
642 static inline bool is_deleted (const T &entry)
643 {
644 return entry.m_key == reinterpret_cast<key_type> (1);
645 }
646 template <typename T>
647 static inline bool is_empty (const T &entry)
648 {
649 return entry.m_key == nullptr;
650 }
651 static const bool empty_zero_p = false;
652};
653
654/* Data about a particular call_string within an exploded_graph. */
655
657{
658 per_call_string_data (const call_string &key, int num_supernodes)
659 : m_key (key), m_stats (num_supernodes)
660 {}
661
664};
665
666/* Data about a particular function within an exploded_graph. */
667
677
678/* The strongly connected components of a supergraph.
679 In particular, this allows us to compute a partial ordering
680 of supernodes. */
681
683{
684public:
686
687 int get_scc_id (int node_index) const
688 {
689 return m_per_node[node_index].m_lowlink;
690 }
691
692 void dump () const;
693
694 std::unique_ptr<json::array> to_json () const;
695
696private:
698 {
700 : m_id (-1), m_lowlink (-1), m_on_stack (false)
701 {}
702
703 int m_id;
706 };
707
708 void strong_connect (unsigned index, logger *logger);
709
713};
714
715/* The worklist of exploded_node instances that have been added to
716 an exploded_graph, but that haven't yet been processed to find
717 their successors (or warnings).
718
719 The enodes are stored in a priority queue, ordered by a topological
720 sort of the SCCs in the supergraph, so that enodes for the same
721 program_point should appear at the front of the queue together.
722 This allows for state-merging at CFG join-points, so that
723 sufficiently-similar enodes can be merged into one. */
724
726{
727public:
728 worklist (const exploded_graph &eg, const analysis_plan &plan);
729 unsigned length () const;
732 void add_node (exploded_node *enode);
733 int get_scc_id (const supernode &snode) const
734 {
735 return m_scc.get_scc_id (snode.m_id);
736 }
737
738 std::unique_ptr<json::object> to_json () const;
739
740private:
741 class key_t
742 {
743 public:
744 key_t (const worklist &w, exploded_node *enode)
745 : m_worklist (w), m_enode (enode)
746 {}
747
748 bool operator< (const key_t &other) const
749 {
750 return cmp (*this, other) < 0;
751 }
752
753 bool operator== (const key_t &other) const
754 {
755 return cmp (*this, other) == 0;
756 }
757
758 bool operator> (const key_t &other) const
759 {
760 return !(*this == other || *this < other);
761 }
762
763 private:
764 static int cmp (const key_t &ka, const key_t &kb);
765
766 int get_scc_id (const exploded_node *enode) const
767 {
768 const supernode *snode = enode->get_supernode ();
769 if (snode == nullptr)
770 return 0;
771 return m_worklist.m_scc.get_scc_id (snode->m_id);
772 }
773
776 };
777
778 /* The order is important here: m_scc needs to stick around
779 until after m_queue has finished being cleaned up (the dtor
780 calls the ordering fns). */
783
784 /* Priority queue, backed by a fibonacci_heap. */
787};
788
789/* An exploded_graph is a directed graph of unique <point, state> pairs.
790 It also has a worklist of nodes that are waiting for their successors
791 to be added to the graph. */
792
793class exploded_graph : public digraph<eg_traits>
794{
795public:
796 typedef hash_map <const call_string *,
798
801 const state_purge_map *purge_map,
802 const analysis_plan &plan,
803 int verbosity);
805
806 logger *get_logger () const { return m_logger.get_logger (); }
807
808 const supergraph &get_supergraph () const { return m_sg; }
809 const extrinsic_state &get_ext_state () const { return m_ext_state; }
810 engine *get_engine () const { return m_ext_state.get_engine (); }
811 const state_purge_map *get_purge_map () const { return m_purge_map; }
812 const analysis_plan &get_analysis_plan () const { return m_plan; }
813
814 exploded_node *get_origin () const { return m_origin; }
815
817
822
824 const program_state &state,
825 exploded_node *enode_for_diag,
826 bool add_to_worklist = true);
828 const superedge *sedge, bool could_do_work,
829 std::unique_ptr<custom_edge_info> custom = nullptr);
830
835
838
842
844 const exploded_node *enode,
845 const supernode *node, const gimple *stmt,
848
854 {
856 }
857
860 void log_stats () const;
861 void dump_stats (FILE *) const;
862 void dump_exploded_nodes () const;
863
864 std::unique_ptr<json::object> to_json () const;
865
867
870
871 int get_scc_id (const supernode &node) const
872 {
873 return m_worklist.get_scc_id (node);
874 }
875
877
879 const gimple *stmt,
881
882 /* In infinite-loop.cc */
883 void detect_infinite_loops ();
884
885 /* In infinite-recursion.cc */
888 exploded_node *enode) const;
889
890private:
892
894
896
898
899 /* Map from point/state to exploded node.
900 To avoid duplication we store point_and_state
901 *pointers* as keys, rather than point_and_state, using the
902 instance from within the exploded_node, with a custom hasher. */
903 typedef hash_map <const point_and_state *, exploded_node *,
906
907 /* Map from program_point to per-program_point data. */
911
913
915
917
919
921
924
926
927 /* Stats. */
932
934
935 /* Functions with a top-level enode, to make add_function_entry
936 be idempotent, for use in handling callbacks. */
938};
939
940/* A reason why a particular exploded_path is infeasible. */
941
943{
944public:
945 feasibility_problem (unsigned eedge_idx,
946 const exploded_edge &eedge,
947 std::unique_ptr<rejected_constraint> rc)
948 : m_eedge_idx (eedge_idx), m_eedge (eedge),
949 m_rc (std::move (rc))
950 {}
951
952 void dump_to_pp (pretty_printer *pp) const;
953
954 unsigned m_eedge_idx;
956 std::unique_ptr<rejected_constraint> m_rc;
957};
958
959/* A class for capturing the state of a node when checking a path
960 through the exploded_graph for feasibility. */
961
963{
964public:
966 const supergraph &sg);
968 const supergraph &sg);
970
972
974 const exploded_edge *eedge,
976 std::unique_ptr<rejected_constraint> *out_rc);
977
979 const region_model &get_model () const { return m_model; }
982
983 void dump_to_pp (pretty_printer *pp, bool simple, bool multiline) const;
984
985private:
988};
989
990// TODO: split the above up?
991
992} // namespace ana
993
994#endif /* GCC_ANALYZER_EXPLODED_GRAPH_H */
Definition analysis-plan.h:35
Definition ops.h:433
Definition call-string.h:41
Definition checker-path.h:32
Definition common.h:428
Definition diagnostic-manager.h:161
Definition region-model.h:1314
Definition exploded-graph.h:335
std::unique_ptr< json::object > to_json() const
const operation * maybe_get_op() const
void dump_dot_label(pretty_printer *pp) const
bool m_could_do_work_p
Definition exploded-graph.h:375
exploded_edge(exploded_node *src, exploded_node *dest, const superedge *sedge, bool could_do_work, std::unique_ptr< custom_edge_info > custom_info)
std::unique_ptr< custom_edge_info > m_custom_info
Definition exploded-graph.h:352
void dump_dot(graphviz_out *gv, const dump_args_t &args) const final override
bool could_do_work_p() const
Definition exploded-graph.h:354
DISABLE_COPY_AND_ASSIGN(exploded_edge)
const gimple * maybe_get_stmt() const
const superedge *const m_sedge
Definition exploded-graph.h:347
Definition exploded-graph.h:794
hash_map< const point_and_state *, exploded_node *, eg_hash_map_traits > map_t
Definition exploded-graph.h:904
void log_stats() const
stats * get_global_stats()
Definition exploded-graph.h:858
const call_string_data_map_t * get_per_call_string_data() const
Definition exploded-graph.h:868
const state_purge_map * get_purge_map() const
Definition exploded-graph.h:811
const extrinsic_state & m_ext_state
Definition exploded-graph.h:916
void detect_infinite_recursion(exploded_node *enode)
Definition infinite-recursion.cc:585
call_string_data_map_t m_per_call_string_data
Definition exploded-graph.h:933
stats m_functionless_stats
Definition exploded-graph.h:931
exploded_node * find_previous_entry_to(function *top_of_stack_fun, exploded_node *enode) const
Definition infinite-recursion.cc:328
function_stat_map_t m_per_function_stats
Definition exploded-graph.h:930
exploded_edge * add_edge(exploded_node *src, exploded_node *dest, const superedge *sedge, bool could_do_work, std::unique_ptr< custom_edge_info > custom=nullptr)
void detect_infinite_loops()
Definition infinite-loop.cc:555
void process_node(exploded_node *node)
engine * get_engine() const
Definition exploded-graph.h:810
point_map_t m_per_point_data
Definition exploded-graph.h:910
diagnostic_manager & get_diagnostic_manager()
Definition exploded-graph.h:849
exploded_node * add_function_entry(const function &fun)
per_function_data * get_per_function_data(function *) const
log_user m_logger
Definition exploded-graph.h:897
bool maybe_process_run_of_enodes(exploded_node *node)
const supergraph & get_supergraph() const
Definition exploded-graph.h:808
const analysis_plan & get_analysis_plan() const
Definition exploded-graph.h:812
map_t m_point_and_state_to_node
Definition exploded-graph.h:905
const supergraph & m_sg
Definition exploded-graph.h:895
exploded_graph(const supergraph &sg, logger *logger, const extrinsic_state &ext_state, const state_purge_map *purge_map, const analysis_plan &plan, int verbosity)
diagnostic_manager m_diagnostic_manager
Definition exploded-graph.h:925
hash_map< function *, per_function_data * > per_function_data_t
Definition exploded-graph.h:922
void build_initial_worklist()
per_call_string_data * get_or_create_per_call_string_data(const call_string &)
const diagnostic_manager & get_diagnostic_manager() const
Definition exploded-graph.h:853
per_program_point_data * get_per_program_point_data(const program_point &) const
logger * get_logger() const
Definition exploded-graph.h:806
exploded_node * m_origin
Definition exploded-graph.h:914
per_function_data * get_or_create_per_function_data(function *)
void on_escaped_function(tree fndecl)
void dump_exploded_nodes() const
hash_map< const call_string *, per_call_string_data * > call_string_data_map_t
Definition exploded-graph.h:797
hash_set< function * > m_functions_with_enodes
Definition exploded-graph.h:937
stats * get_or_create_function_stats(function *fn)
void print_bar_charts(pretty_printer *pp) const
stats m_global_stats
Definition exploded-graph.h:928
ordered_hash_map< function *, stats * > function_stat_map_t
Definition exploded-graph.h:929
const extrinsic_state & get_ext_state() const
Definition exploded-graph.h:809
worklist m_worklist
Definition exploded-graph.h:912
void dump_stats(FILE *) const
int get_scc_id(const supernode &node) const
Definition exploded-graph.h:871
hash_map< const program_point *, per_program_point_data *, eg_point_hash_map_traits > point_map_t
Definition exploded-graph.h:909
std::unique_ptr< json::object > to_json() const
void save_diagnostic(const state_machine &sm, const exploded_node *enode, const supernode *node, const gimple *stmt, tree var, state_machine::state_t state, pending_diagnostic *d)
const state_purge_map *const m_purge_map
Definition exploded-graph.h:918
const analysis_plan & m_plan
Definition exploded-graph.h:920
void unwind_from_exception(exploded_node &enode, const gimple *stmt, region_model_context *ctxt)
exploded_node * get_or_create_node(const program_point &point, const program_state &state, exploded_node *enode_for_diag, bool add_to_worklist=true)
per_program_point_data * get_or_create_per_program_point_data(const program_point &)
per_function_data_t m_per_function_data
Definition exploded-graph.h:923
exploded_node * get_origin() const
Definition exploded-graph.h:814
exploded_node * get_node_by_index(int idx) const
DISABLE_COPY_AND_ASSIGN(exploded_graph)
Definition exploded-graph.h:206
DISABLE_COPY_AND_ASSIGN(exploded_node)
const point_and_state * get_ps_key() const
Definition exploded-graph.h:284
void dump(const extrinsic_state &ext_state) const
unsigned m_num_processed_stmts
Definition exploded-graph.h:328
status
Definition exploded-graph.h:213
@ special
Definition exploded-graph.h:222
@ bulk_merged
Definition exploded-graph.h:229
@ worklist
Definition exploded-graph.h:215
@ merger
Definition exploded-graph.h:226
function * get_function() const
Definition exploded-graph.h:273
void dump_to_pp(pretty_printer *pp, const extrinsic_state &ext_state) const
location_t get_location() const
Definition exploded-graph.h:269
unsigned get_num_diagnostics() const
Definition exploded-graph.h:300
void dump_saved_diagnostics(pretty_printer *pp) const
void dump_dot(graphviz_out *gv, const dump_args_t &args) const final override
void on_throw(exploded_graph &eg, const gcall &call, const program_point &after_throw_point, program_state *new_state, bool is_rethrow, region_model_context *ctxt)
std::unique_ptr< json::object > to_json(const extrinsic_state &ext_state) const
void add_diagnostic(const saved_diagnostic *sd)
Definition exploded-graph.h:296
void dump_processed_stmts(pretty_printer *pp) const
const point_and_state m_ps
Definition exploded-graph.h:314
const char * get_dot_fillcolor() const
void dump_dot_id(pretty_printer *pp) const
const program_state & get_state() const
Definition exploded-graph.h:282
static const char * status_to_str(enum status s)
void dump_succs_and_preds(FILE *outf) const
const int m_index
Definition exploded-graph.h:324
const program_point * get_point_key() const
Definition exploded-graph.h:285
enum status get_status() const
Definition exploded-graph.h:289
void set_status(enum status s)
Definition exploded-graph.h:290
int get_stack_depth() const
Definition exploded-graph.h:277
void on_longjmp(exploded_graph &eg, const gcall &call, program_state *new_state, region_model_context *ctxt)
exploded_node(const point_and_state &ps, int index)
const program_point & get_point() const
Definition exploded-graph.h:264
void dump(FILE *fp, const extrinsic_state &ext_state) const
auto_vec< const saved_diagnostic * > m_saved_diagnostics
Definition exploded-graph.h:320
const supernode * get_supernode() const
Definition exploded-graph.h:265
void detect_leaks(exploded_graph &eg)
hashval_t hash() const
Definition exploded-graph.h:235
enum status m_status
Definition exploded-graph.h:316
const saved_diagnostic * get_saved_diagnostic(unsigned idx) const
Definition exploded-graph.h:304
Definition program-state.h:34
feasibility_problem(unsigned eedge_idx, const exploded_edge &eedge, std::unique_ptr< rejected_constraint > rc)
Definition exploded-graph.h:945
const exploded_edge & m_eedge
Definition exploded-graph.h:955
void dump_to_pp(pretty_printer *pp) const
unsigned m_eedge_idx
Definition exploded-graph.h:954
std::unique_ptr< rejected_constraint > m_rc
Definition exploded-graph.h:956
bool maybe_update_for_edge(logger *logger, const exploded_edge *eedge, region_model_context *ctxt, std::unique_ptr< rejected_constraint > *out_rc)
auto_sbitmap & get_snodes_visited()
Definition exploded-graph.h:980
feasibility_state(const region_model &model, const supergraph &sg)
auto_sbitmap m_snodes_visited
Definition exploded-graph.h:987
feasibility_state(region_model_manager *manager, const supergraph &sg)
void dump_to_pp(pretty_printer *pp, bool simple, bool multiline) const
region_model & get_model()
Definition exploded-graph.h:978
feasibility_state(const feasibility_state &other)
region_model m_model
Definition exploded-graph.h:986
const region_model & get_model() const
Definition exploded-graph.h:979
feasibility_state & operator=(const feasibility_state &other)
const auto_sbitmap & get_snodes_visited() const
Definition exploded-graph.h:981
Definition region.h:320
void on_condition(const svalue *lhs, enum tree_code op, const svalue *rhs) final override
void on_unknown_change(const svalue *sval, bool is_mutable) final override
void terminate_path() final override
impl_region_model_context(exploded_graph &eg, exploded_node *enode_for_diag, const program_state *old_state, program_state *new_state, uncertainty_t *uncertainty, path_context *path_ctxt, const gimple *stmt=nullptr, bool *out_could_have_done_work=nullptr)
exploded_graph * m_eg
Definition exploded-graph.h:123
const extrinsic_state & m_ext_state
Definition exploded-graph.h:129
logger * get_logger() final override
Definition exploded-graph.h:67
void on_svalue_leak(const svalue *) override
void on_pop_frame(const frame_region *frame_reg) final override
void on_liveness_change(const svalue_set &live_svalues, const region_model *model) final override
void add_note(std::unique_ptr< pending_note > pn) final override
bool * m_out_could_have_done_work
Definition exploded-graph.h:132
bool warn_at(std::unique_ptr< pending_diagnostic > d, pending_location &&ploc) final override
void on_state_leak(const state_machine &sm, const svalue *sval, state_machine::state_t state)
impl_region_model_context(program_state *state, const extrinsic_state &ext_state, uncertainty_t *uncertainty, logger *logger=nullptr)
void add_event(std::unique_ptr< checker_event > event) final override
pending_location get_pending_location_for_diag() const override
program_state * m_new_state
Definition exploded-graph.h:127
log_user m_logger
Definition exploded-graph.h:124
const program_state * m_old_state
Definition exploded-graph.h:126
void on_unusable_in_infinite_loop() override
Definition exploded-graph.h:118
const program_state * get_state() const override
Definition exploded-graph.h:114
void on_phi(const gphi *phi, tree rhs) final override
void on_unexpected_tree_code(tree t, const dump_location_t &loc) final override
void on_escaped_function(tree fndecl) final override
void bifurcate(std::unique_ptr< custom_edge_info > info) final override
path_context * m_path_ctxt
Definition exploded-graph.h:131
void purge_state_involving(const svalue *sval) final override
void on_bounded_ranges(const svalue &sval, const bounded_ranges &ranges) final override
uncertainty_t * get_uncertainty() final override
const gimple * m_stmt
Definition exploded-graph.h:128
uncertainty_t * m_uncertainty
Definition exploded-graph.h:130
const gimple * get_stmt() const override
Definition exploded-graph.h:111
bool get_state_map_by_name(const char *name, sm_state_map **out_smap, const state_machine **out_sm, unsigned *out_sm_idx, std::unique_ptr< sm_context > *out_sm_context) override
bool checking_for_infinite_loop_p() const override
Definition exploded-graph.h:117
const extrinsic_state * get_ext_state() const final override
Definition exploded-graph.h:100
const exploded_graph * get_eg() const override
Definition exploded-graph.h:112
exploded_node * m_enode_for_diag
Definition exploded-graph.h:125
interprocedural_call(const call_and_return_op &op, function &callee_fun)
Definition exploded-graph.h:384
void get_dot_attrs(const char *&out_style, const char *&out_color) const final override
bool update_model(region_model *model, const exploded_edge *eedge, region_model_context *ctxt) const final override
const gcall & get_gcall() const
void add_events_to_path(checker_path *emission_path, const exploded_edge &eedge, pending_diagnostic &pd, const state_transition *state_trans) const final override
const call_and_return_op & m_op
Definition exploded-graph.h:414
bool update_state(program_state *state, const exploded_edge *eedge, region_model_context *ctxt) const final override
bool try_to_rewind_data_flow(rewind_context &) const final override
function & m_callee_fun
Definition exploded-graph.h:415
void print(pretty_printer *pp) const final override
const gcall & m_call_stmt
Definition exploded-graph.h:450
void print(pretty_printer *pp) const final override
bool try_to_rewind_data_flow(rewind_context &) const final override
interprocedural_return(const gcall &call_stmt)
Definition exploded-graph.h:424
bool update_model(region_model *model, const exploded_edge *eedge, region_model_context *ctxt) const final override
bool update_state(program_state *state, const exploded_edge *eedge, region_model_context *ctxt) const final override
void get_dot_attrs(const char *&out_style, const char *&out_color) const final override
void add_events_to_path(checker_path *emission_path, const exploded_edge &eedge, pending_diagnostic &pd, const state_transition *state_trans) const final override
Definition analyzer-logging.h:193
Definition analyzer-logging.h:36
Definition ops.h:113
Definition common.h:478
Definition pending-diagnostic.h:258
Definition exploded-graph.h:140
hashval_t m_hash
Definition exploded-graph.h:176
bool operator==(const point_and_state &other) const
Definition exploded-graph.h:157
void validate(const extrinsic_state &ext_state) const
const program_state & get_state() const
Definition exploded-graph.h:163
program_state m_state
Definition exploded-graph.h:175
program_point m_point
Definition exploded-graph.h:174
point_and_state(const program_point &point, const program_state &state)
Definition exploded-graph.h:142
const program_point & get_point() const
Definition exploded-graph.h:162
hashval_t hash() const
Definition exploded-graph.h:153
void set_state(const program_state &state)
Definition exploded-graph.h:165
Definition program-point.h:54
location_t get_location() const
Definition program-point.h:98
function * get_function() const
Definition program-point.h:88
const supernode * get_supernode() const
Definition program-point.h:82
int get_stack_depth() const
Definition program-point.h:107
const call_string & get_call_string() const
Definition program-point.h:86
hashval_t hash() const
Definition program-state.h:224
Definition region-model.h:748
Definition region-model-manager.h:32
Definition region-model.h:294
setjmp_record m_setjmp_record
Definition exploded-graph.h:509
program_point get_point_before_setjmp() const
Definition exploded-graph.h:480
bool update_model(region_model *model, const exploded_edge *eedge, region_model_context *ctxt) const final override
void add_events_to_path(checker_path *emission_path, const exploded_edge &eedge, pending_diagnostic &pd, const state_transition *state_trans) const final override
const gcall & get_setjmp_call() const
Definition exploded-graph.h:493
void print(pretty_printer *pp) const final override
Definition exploded-graph.h:465
const exploded_node * get_enode_origin() const
Definition exploded-graph.h:503
const gcall & m_longjmp_call
Definition exploded-graph.h:510
program_point get_point_after_setjmp() const
Definition exploded-graph.h:486
rewind_info_t(const setjmp_record &setjmp_record, const gcall &longjmp_call)
Definition exploded-graph.h:459
const gcall & get_longjmp_call() const
Definition exploded-graph.h:498
Definition diagnostic-manager.h:79
Definition program-state.h:92
Definition sm.h:43
const state_machine::state * state_t
Definition sm.h:63
Definition state-purge.h:31
Definition state-transition.h:31
Definition exploded-graph.h:683
void strong_connect(unsigned index, logger *logger)
int get_scc_id(int node_index) const
Definition exploded-graph.h:687
auto_vec< per_node_data > m_per_node
Definition exploded-graph.h:712
const supergraph & m_sg
Definition exploded-graph.h:710
strongly_connected_components(const supergraph &sg, logger *logger)
auto_vec< unsigned > m_stack
Definition exploded-graph.h:711
std::unique_ptr< json::array > to_json() const
Definition supergraph.h:281
Definition supergraph.h:105
Definition supergraph.h:224
int m_id
Definition supergraph.h:268
Definition svalue.h:92
Definition store.h:162
bool operator<(const key_t &other) const
Definition exploded-graph.h:748
const worklist & m_worklist
Definition exploded-graph.h:774
bool operator==(const key_t &other) const
Definition exploded-graph.h:753
exploded_node * m_enode
Definition exploded-graph.h:775
bool operator>(const key_t &other) const
Definition exploded-graph.h:758
static int cmp(const key_t &ka, const key_t &kb)
int get_scc_id(const exploded_node *enode) const
Definition exploded-graph.h:766
key_t(const worklist &w, exploded_node *enode)
Definition exploded-graph.h:744
Definition exploded-graph.h:726
std::unique_ptr< json::object > to_json() const
void add_node(exploded_node *enode)
strongly_connected_components m_scc
Definition exploded-graph.h:781
worklist(const exploded_graph &eg, const analysis_plan &plan)
queue_t m_queue
Definition exploded-graph.h:786
exploded_node * take_next()
fibonacci_heap< key_t, exploded_node > queue_t
Definition exploded-graph.h:785
exploded_node * peek_next()
const analysis_plan & m_plan
Definition exploded-graph.h:782
int get_scc_id(const supernode &snode) const
Definition exploded-graph.h:733
unsigned length() const
Definition sbitmap.h:303
Definition vec.h:1667
dedge(node_t *src, node_t *dest)
Definition digraph.h:93
eg_traits::dump_args_t dump_args_t
Definition digraph.h:91
digraph()
Definition digraph.h:128
Definition digraph.h:43
eg_traits::dump_args_t dump_args_t
Definition digraph.h:46
Definition dumpfile.h:446
Definition ree.cc:583
Definition fibonacci_heap.h:143
Definition graphviz.h:388
Definition hash-map.h:40
Definition hash-set.h:37
Definition ordered-hash-map.h:35
Definition pretty-print.h:241
union tree_node * tree
Definition coretypes.h:97
void final(rtx_insn *first, FILE *file, int optimize_p)
Definition final.cc:2009
tree_code
Definition genmatch.cc:1002
Definition access-diagram.h:30
@ stmt
Definition checker-event.h:38
@ custom
Definition checker-event.h:37
hash_set< const svalue * > svalue_set
Definition common.h:76
Definition custom-sarif-properties/state-graphs.h:33
void pp_string(pretty_printer *pp, const char *str)
Definition pretty-print.cc:2764
Definition constraint-manager.h:123
Definition exploded-graph.h:533
static bool equal_keys(const key_type &k1, const key_type &k2)
Definition exploded-graph.h:544
static void mark_empty(T &entry)
Definition exploded-graph.h:567
static void mark_deleted(T &entry)
Definition exploded-graph.h:562
static bool is_deleted(const T &entry)
Definition exploded-graph.h:572
static const bool empty_zero_p
Definition exploded-graph.h:581
exploded_node * compare_type
Definition exploded-graph.h:536
const point_and_state * key_type
Definition exploded-graph.h:534
exploded_node * value_type
Definition exploded-graph.h:535
static void remove(T &)
Definition exploded-graph.h:557
static hashval_t hash(const key_type &k)
Definition exploded-graph.h:538
static bool is_empty(const T &entry)
Definition exploded-graph.h:577
Definition exploded-graph.h:603
static bool is_deleted(const T &entry)
Definition exploded-graph.h:642
static const bool empty_zero_p
Definition exploded-graph.h:651
static void mark_empty(T &entry)
Definition exploded-graph.h:637
static hashval_t hash(const key_type &k)
Definition exploded-graph.h:608
const program_point * key_type
Definition exploded-graph.h:604
per_program_point_data * value_type
Definition exploded-graph.h:605
per_program_point_data * compare_type
Definition exploded-graph.h:606
static void mark_deleted(T &entry)
Definition exploded-graph.h:632
static bool is_empty(const T &entry)
Definition exploded-graph.h:647
static bool equal_keys(const key_type &k1, const key_type &k2)
Definition exploded-graph.h:614
static void remove(T &)
Definition exploded-graph.h:627
bool show_enode_details_p(const exploded_node &enode) const
const exploded_graph & m_eg
Definition exploded-graph.h:195
virtual void dump_extra_info(const exploded_node *, pretty_printer *) const
Definition exploded-graph.h:193
dump_args_t(const exploded_graph &eg)
Definition exploded-graph.h:188
Definition exploded-graph.h:182
exploded_graph graph_t
Definition exploded-graph.h:185
exploded_edge edge_t
Definition exploded-graph.h:184
exploded_node node_t
Definition exploded-graph.h:183
exploded_cluster cluster_t
Definition exploded-graph.h:197
Definition diagnostic-manager.h:35
Definition exploded-graph.h:657
stats m_stats
Definition exploded-graph.h:663
const call_string & m_key
Definition exploded-graph.h:662
per_call_string_data(const call_string &key, int num_supernodes)
Definition exploded-graph.h:658
Definition exploded-graph.h:669
per_function_data()
Definition exploded-graph.h:670
auto_vec< call_summary * > m_summaries
Definition exploded-graph.h:675
void add_call_summary(exploded_node *node)
Definition exploded-graph.h:587
const program_point m_key
Definition exploded-graph.h:592
int m_excess_enodes
Definition exploded-graph.h:596
per_program_point_data(const program_point &key)
Definition exploded-graph.h:588
auto_vec< exploded_node * > m_enodes
Definition exploded-graph.h:593
Definition ops.h:78
Definition svalue.h:550
Definition exploded-graph.h:516
void log(logger *logger) const
void dump(FILE *out) const
int m_num_nodes
Definition exploded-graph.h:523
int m_num_supernodes
Definition exploded-graph.h:526
int m_node_reuse_after_merge_count
Definition exploded-graph.h:525
stats(int num_supernodes)
int get_total_enodes() const
int m_node_reuse_count
Definition exploded-graph.h:524
per_node_data()
Definition exploded-graph.h:699
bool m_on_stack
Definition exploded-graph.h:705
int m_id
Definition exploded-graph.h:703
int m_lowlink
Definition exploded-graph.h:704
Definition function.h:249
Definition gimple.h:355
Definition gimple.h:224
Definition gimple.h:464
Definition ira-emit.cc:158
Definition gengtype.h:377
Definition genautomata.cc:669
#define gcc_assert(EXPR)
Definition system.h:817
#define false
Definition system.h:891
static sbitmap processed
Definition tree-ssa-dce.cc:89
static void add_to_worklist(same_succ *same)
Definition tree-ssa-tail-merge.cc:714