This class represents a segment graph for a process. More...
#include <segment_graph.h>
Public Types | |
typedef std::set < SgFunctionDefinition * > | FunctionCallBoundarySet |
typedef std::set< VariantT > | CCxxKeywordsBoundarySet |
typedef std::set < VertexDescriptor > | SegmentSet |
Public Member Functions | |
SegmentGraph () | |
SegmentGraph (FunctionCallBoundarySet function_boundaries) | |
SegmentGraph (CCxxKeywordsBoundarySet keyword_boundaries) | |
SegmentGraph (FunctionCallBoundarySet function_boundaries, CCxxKeywordsBoundarySet keyword_boundaries) | |
void | get_wait_and_notifying_events () |
void | find_module_segments (std::vector< Module * > &module_definitions_) |
void | print_psg_file (std::string file_name) |
void | read_psg_from_file (std::string) |
void | write_psg_attributes (std::string) |
void | replace_function_call_vertex_with_its_psg () |
void | remove_dangling_segments () |
void | integrate_psg_into_sg (VertexDescriptor, SgSymbol *) |
void | count_segments_that_belongs_to_certain_psg () |
void | clean_graph () |
This function deletes all duplicated nodes in each vertex of the graph. | |
void | print_graph (std::string filename) |
void | print_graph_read_write_access (std::string filename) |
void | add_function (Function *function, bool duplicate_segments=false, bool is_simulation_process=true, std::string module_name="") |
void | read_write_analysis_of_segments () |
The function determines which variables are read and written in the individual segments. | |
void | set_all_segments_to_untouched () |
This function sets the status of the flag helper_for_graph_algorithms for all nodes to 'Untouched'. | |
bool | has_transition (int seg_id_from, int seg_id_to) |
VertexDescriptor | id_to_vertex_descriptor (int seg_id) |
Public Attributes | |
std::vector< std::pair < VertexDescriptor, SgSymbol * > > | function_call_segments |
std::map< SgSymbol *, std::vector < VertexDescriptor > > | map_of_function_name_and_starting_segments |
std::map< SgSymbol *, std::vector < VertexDescriptor > > | map_of_function_name_and_ending_segments |
std::vector< SgExprStatement * > | vector_of_statements_which_contain_non_defining_func_calls |
std::map< std::string, SegmentSet > | map_of_function_name_and_leaving_segments_id_to_be_stored_into_a_psg_file |
std::map< std::string, VertexDescriptor > | map_of_function_name_and_starting_segments_id_to_be_stored_into_a_psg_file |
std::set< VertexDescriptor > | first_segments |
std::map< VertexDescriptor, int > | is_psg_first_segment_touched |
std::map< VertexDescriptor, std::vector< VertexDescriptor > > | psg_segments |
std::map< int, int > | count_of_segments_that_belongs_to_certain_psg |
Graph | graph_ |
Internal data structure of the segment graph. | |
std::set< VertexDescriptor > | precached_function_segments_ |
This set stores segments from precached functions. These segments will be deleted later. | |
std::set< SgFunctionCallExp * > | port_calls_ |
This set stores all function calls which belong to a port. These segments will be deleted later. | |
bool | is_succesfully_created_ |
Is true if the segment graph is successfully created. | |
Private Member Functions | |
void | handle_recursive_calls () |
This function integrates the recursive function calls. | |
void | separate_variable_declaration_and_initializer_on_demand (SgBasicBlock *&bb, bool duplicate_segments, PortCallPath pcp) |
void | decompose_expression_with_boundary_calls (SgExpression *expr, SgBasicBlock *&bb, bool duplicate_segments, PortCallPath pcp) |
void | create_temp_variable_for_expression (SgExpression *expr, SgBasicBlock *&bb) |
std::string | generate_unique_name (SgNode *node) |
bool | is_boundary_stmt (SgStatement const *const current_stmt) |
SgFunctionCallExp * | has_function_call_with_boundary (SgExpression *expr, bool duplicate_segments, PortCallPath pcp) |
bool | should_decompose_function (SgExpression *expr, bool duplicate_segments, PortCallPath pcp) |
SgFunctionDeclaration * | contains_function_call_expression (SgExpression *expr) |
SegmentSet | build_graph (SgStatement *current_stmt, SegmentSet current_segments, SegmentSet &break_segments, SegmentSet &continue_segments, bool duplicate_segments, PortCallPath pcp) |
void | add_expression_to_segment (SegmentSet segments, SgNode *expr, PortCallPath pcp) |
CachedFunctionAstAttributes * | build_segment_graph_for_function (SgFunctionDefinition *func_def, bool duplicate_segments, PortCallPath pcp) |
void | insert_loop_edges (VertexDescriptor &loop_vertex, SegmentSet ¤t_segments, SegmentSet &continue_segments, SegmentSet &leaf_segments_of_loop) |
FunctionAnnotationAttributes * | get_function_call_annotation (SgFunctionCallExp *func_call_exp) |
CachedFunctionAstAttributes * | create_cached_function_attribute_for_annotated_function (SgNode *boundary_node, WAIT_CONSTRUCT wait_type, SegmentSet incoming_segments, bool is_conflict_free, PortCallPath pcp) |
void | add_mapped_symbol_to_reference (SgFunctionCallExp *func_call, SgFunctionDefinition *func_def) |
void | forward_reference_function_parameters (SgFunctionCallExp *func_call_exp) |
void | mark_not_conflict_free_func_calls_in_segment (SgNode *stmt, SegmentSet segments) |
FunctionAnnotation * | analyze_prepended_pragmas_for_annotation (SgFunctionDeclaration *func_decl) |
SegmentSet | duplicate_segments (SegmentSet segments) |
SegmentSet | duplicate_empty_segments (SegmentSet segments) |
bool | follow_function_call (SgFunctionDeclaration *func_decl) |
Private Attributes | |
bool | static_analysis_ |
FunctionCallBoundarySet | function_boundaries_ |
CCxxKeywordsBoundarySet | keyword_boundaries_ |
std::set< VertexDescriptor > | recursive_function_calls_ |
Static Private Attributes | |
static int | counter = 0 |
This counter is used for generating variables names with unique names. |
This class represents a segment graph for a process.
typedef std::set<VariantT> risc::sg::SegmentGraph::CCxxKeywordsBoundarySet |
typedef std::set<SgFunctionDefinition*> risc::sg::SegmentGraph::FunctionCallBoundarySet |
typedef std::set<VertexDescriptor> risc::sg::SegmentGraph::SegmentSet |
risc::sg::SegmentGraph::SegmentGraph | ( | ) |
risc::sg::SegmentGraph::SegmentGraph | ( | FunctionCallBoundarySet | function_boundaries | ) |
risc::sg::SegmentGraph::SegmentGraph | ( | CCxxKeywordsBoundarySet | keyword_boundaries | ) |
risc::sg::SegmentGraph::SegmentGraph | ( | FunctionCallBoundarySet | function_boundaries, | |
CCxxKeywordsBoundarySet | keyword_boundaries | |||
) |
void risc::sg::SegmentGraph::add_expression_to_segment | ( | SegmentSet | segments, | |
SgNode * | expr, | |||
PortCallPath | pcp | |||
) | [private] |
void risc::sg::SegmentGraph::add_function | ( | Function * | function, | |
bool | duplicate_segments = false , |
|||
bool | is_simulation_process = true , |
|||
std::string | module_name = "" | |||
) |
void risc::sg::SegmentGraph::add_mapped_symbol_to_reference | ( | SgFunctionCallExp * | func_call, | |
SgFunctionDefinition * | func_def | |||
) | [private] |
FunctionAnnotation * risc::sg::SegmentGraph::analyze_prepended_pragmas_for_annotation | ( | SgFunctionDeclaration * | func_decl | ) | [private] |
risc::sg::SegmentGraph::SegmentSet risc::sg::SegmentGraph::build_graph | ( | SgStatement * | current_stmt, | |
SegmentSet | current_segments, | |||
SegmentSet & | break_segments, | |||
SegmentSet & | continue_segments, | |||
bool | duplicate_segments, | |||
PortCallPath | pcp | |||
) | [private] |
risc::sg::CachedFunctionAstAttributes * risc::sg::SegmentGraph::build_segment_graph_for_function | ( | SgFunctionDefinition * | func_def, | |
bool | duplicate_segments, | |||
PortCallPath | pcp | |||
) | [private] |
risc::sg::SegmentGraph::clean_graph | ( | ) |
This function deletes all duplicated nodes in each vertex of the graph.
SgFunctionDeclaration * risc::sg::SegmentGraph::contains_function_call_expression | ( | SgExpression * | expr | ) | [private] |
void risc::sg::SegmentGraph::count_segments_that_belongs_to_certain_psg | ( | ) |
risc::sg::CachedFunctionAstAttributes * risc::sg::SegmentGraph::create_cached_function_attribute_for_annotated_function | ( | SgNode * | boundary_node, | |
WAIT_CONSTRUCT | wait_type, | |||
SegmentSet | incoming_segments, | |||
bool | is_conflict_free, | |||
PortCallPath | pcp | |||
) | [private] |
void risc::sg::SegmentGraph::create_temp_variable_for_expression | ( | SgExpression * | expr, | |
SgBasicBlock *& | bb | |||
) | [private] |
void risc::sg::SegmentGraph::decompose_expression_with_boundary_calls | ( | SgExpression * | expr, | |
SgBasicBlock *& | bb, | |||
bool | duplicate_segments, | |||
PortCallPath | pcp | |||
) | [private] |
risc::sg::SegmentGraph::SegmentSet risc::sg::SegmentGraph::duplicate_empty_segments | ( | SegmentSet | segments | ) | [private] |
risc::sg::SegmentGraph::SegmentSet risc::sg::SegmentGraph::duplicate_segments | ( | SegmentSet | segments | ) | [private] |
void risc::sg::SegmentGraph::find_module_segments | ( | std::vector< Module * > & | module_definitions_ | ) |
bool risc::sg::SegmentGraph::follow_function_call | ( | SgFunctionDeclaration * | func_decl | ) | [private] |
void risc::sg::SegmentGraph::forward_reference_function_parameters | ( | SgFunctionCallExp * | func_call_exp | ) | [private] |
std::string risc::sg::SegmentGraph::generate_unique_name | ( | SgNode * | node | ) | [private] |
risc::sg::FunctionAnnotationAttributes * risc::sg::SegmentGraph::get_function_call_annotation | ( | SgFunctionCallExp * | func_call_exp | ) | [private] |
void risc::sg::SegmentGraph::get_wait_and_notifying_events | ( | ) |
risc::sg::SegmentGraph::handle_recursive_calls | ( | ) | [private] |
This function integrates the recursive function calls.
SgFunctionCallExp * risc::sg::SegmentGraph::has_function_call_with_boundary | ( | SgExpression * | expr, | |
bool | duplicate_segments, | |||
PortCallPath | pcp | |||
) | [private] |
bool risc::sg::SegmentGraph::has_transition | ( | int | seg_id_from, | |
int | seg_id_to | |||
) |
risc::sg::VertexDescriptor risc::sg::SegmentGraph::id_to_vertex_descriptor | ( | int | seg_id | ) |
void risc::sg::SegmentGraph::insert_loop_edges | ( | VertexDescriptor & | loop_vertex, | |
SegmentSet & | current_segments, | |||
SegmentSet & | continue_segments, | |||
SegmentSet & | leaf_segments_of_loop | |||
) | [private] |
void risc::sg::SegmentGraph::integrate_psg_into_sg | ( | VertexDescriptor | func_call_vertex_id, | |
SgSymbol * | func_sym | |||
) |
bool risc::sg::SegmentGraph::is_boundary_stmt | ( | SgStatement const *const | current_stmt | ) | [private] |
void risc::sg::SegmentGraph::mark_not_conflict_free_func_calls_in_segment | ( | SgNode * | stmt, | |
SegmentSet | segments | |||
) | [private] |
void risc::sg::SegmentGraph::print_graph | ( | std::string | filename | ) |
void risc::sg::SegmentGraph::print_graph_read_write_access | ( | std::string | filename | ) |
void risc::sg::SegmentGraph::print_psg_file | ( | std::string | file_name | ) |
void risc::sg::SegmentGraph::read_psg_from_file | ( | std::string | file_name | ) |
risc::sg::SegmentGraph::read_write_analysis_of_segments | ( | ) |
The function determines which variables are read and written in the individual segments.
void risc::sg::SegmentGraph::remove_dangling_segments | ( | ) |
void risc::sg::SegmentGraph::replace_function_call_vertex_with_its_psg | ( | ) |
void risc::sg::SegmentGraph::separate_variable_declaration_and_initializer_on_demand | ( | SgBasicBlock *& | bb, | |
bool | duplicate_segments, | |||
PortCallPath | pcp | |||
) | [private] |
risc::sg::SegmentGraph::set_all_segments_to_untouched | ( | ) |
This function sets the status of the flag helper_for_graph_algorithms for all nodes to 'Untouched'.
bool risc::sg::SegmentGraph::should_decompose_function | ( | SgExpression * | expr, | |
bool | duplicate_segments, | |||
PortCallPath | pcp | |||
) | [private] |
void risc::sg::SegmentGraph::write_psg_attributes | ( | std::string | ) |
std::map<int,int> risc::sg::SegmentGraph::count_of_segments_that_belongs_to_certain_psg |
int risc::sg::SegmentGraph::counter = 0 [static, private] |
This counter is used for generating variables names with unique names.
std::vector<std::pair<VertexDescriptor, SgSymbol *> > risc::sg::SegmentGraph::function_call_segments |
Internal data structure of the segment graph.
Is true if the segment graph is successfully created.
std::map< SgSymbol * , std::vector<VertexDescriptor> > risc::sg::SegmentGraph::map_of_function_name_and_ending_segments |
std::map<std::string, SegmentSet> risc::sg::SegmentGraph::map_of_function_name_and_leaving_segments_id_to_be_stored_into_a_psg_file |
std::map< SgSymbol * , std::vector<VertexDescriptor> > risc::sg::SegmentGraph::map_of_function_name_and_starting_segments |
std::map<std::string, VertexDescriptor> risc::sg::SegmentGraph::map_of_function_name_and_starting_segments_id_to_be_stored_into_a_psg_file |
std::set<SgFunctionCallExp*> risc::sg::SegmentGraph::port_calls_ |
This set stores all function calls which belong to a port. These segments will be deleted later.
This set stores segments from precached functions. These segments will be deleted later.
std::map<VertexDescriptor, std::vector<VertexDescriptor> > risc::sg::SegmentGraph::psg_segments |
std::set<VertexDescriptor> risc::sg::SegmentGraph::recursive_function_calls_ [private] |
bool risc::sg::SegmentGraph::static_analysis_ [private] |
std::vector<SgExprStatement*> risc::sg::SegmentGraph::vector_of_statements_which_contain_non_defining_func_calls |