risc::sg::SegmentGraph Class Reference

This class represents a segment graph for a process. More...

#include <segment_graph.h>

List of all members.

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, SegmentSetmap_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< VertexDescriptorfirst_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< VertexDescriptorprecached_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)
CachedFunctionAstAttributesbuild_segment_graph_for_function (SgFunctionDefinition *func_def, bool duplicate_segments, PortCallPath pcp)
void insert_loop_edges (VertexDescriptor &loop_vertex, SegmentSet &current_segments, SegmentSet &continue_segments, SegmentSet &leaf_segments_of_loop)
FunctionAnnotationAttributesget_function_call_annotation (SgFunctionCallExp *func_call_exp)
CachedFunctionAstAttributescreate_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)
FunctionAnnotationanalyze_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< VertexDescriptorrecursive_function_calls_

Static Private Attributes

static int counter = 0
 This counter is used for generating variables names with unique names.

Detailed Description

This class represents a segment graph for a process.


Member Typedef Documentation

typedef std::set<SgFunctionDefinition*> risc::sg::SegmentGraph::FunctionCallBoundarySet

Constructor & Destructor Documentation

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 
)

Member Function Documentation

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   ) 

Member Data Documentation

int risc::sg::SegmentGraph::counter = 0 [static, private]

This counter is used for generating variables names with unique names.

Internal data structure of the segment graph.

Is true if the segment graph is successfully created.

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.


The documentation for this class was generated from the following files:
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines

Generated on 12 Jun 2018 by  doxygen 1.6.1