This class represents the data conflict table among the individual segments. Two segments have a conflict if a least one variable is by the first segment and read by the second segment. A two dimensional array represents this array. More...
#include <data_conflict_table.h>
Public Member Functions | |
DataConflictTable (SegmentGraph &graph, PathInstanceMapper &path_instance_mapper, bool debugging) | |
Default constructor for the DataConflictTable. | |
virtual void | determine_conflict_table () |
This function determines conflicts among the segments. | |
bool | data_conflict_between (VertexDescriptor first, VertexDescriptor second, int row, int column, int inst_id_first, int inst_id_second) |
This function checks if there is a read write conflict between two segments. | |
void | color_members_of_class (SgVariableSymbol *var_symbol, DataConflictAstAttributes::Status color) |
This function checks if the type of the given variable symbol is is a class or struct. If so, all the member variables which are not static will be set to the given color. | |
void | uncolor_members_of_class (SgVariableSymbol *var_symbol) |
This function checks if the type of the given variable symbol is is a class or struct. If so, all the member variables which are not static will be set to UNUSED. | |
bool | check_members_of_class (SgVariableSymbol *var_symbol, DataConflictAstAttributes::Status color) |
This function checks if the type of the given variable symbol is is a class or struct. If so, it will check if at least on member variable which is not static has the given color. | |
SgVariableSymbol * | get_mapped_variable (SgVariableSymbol *variable, int instance_id) |
This function determines for a given variable the mapped variable. If variable is a reference, the mapped variable will be looked up. Otherwise, the original variable is returned. | |
void | print_conflict_table (std::string filename) |
Generates a html file of the conflict table. | |
void | print_lookup_table (std::string filename) |
Generates a html file of the lookup table. | |
int | segment_and_instance_id_to_index (int segment_id, int instance_id) |
This function translates a given segment id and instance id to a index of the conflict table. | |
std::pair< int, int > | index_to_segment_and_instance_id (int index) |
This function translates a given index from the conflict table into the corresponding segment id and instance id. The first value is the segment id and the second value is the instance id. | |
bool | has_conflict (int segment_id_1, int instance_id_1, int segment_id_2, int instance_id_2) |
This function looks up if there is a conflict between segment 1 with instance id 1 and segment 2 with instance id 2. | |
void | print_instance_id_to_index_lookup_table () |
This function prints the table instance_id_to_index_lookup_table in the terminal. | |
void | set_conflict (int segment_id_1, int instance_id_1, int segment_id_2, int instance_id_2) |
This function sets a conflict in the conflict table. | |
void | set_conflict_cause (int segment_id_1, int instance_id_1, int segment_id_2, int instance_id_2, SgNode *cause=NULL) |
This function sets a conflict in the conflict table. | |
VertexDescriptor | segment_id_to_vertex_descriptor (int id) |
This function translates the given segment id to the corresponding vertex descriptor. | |
Public Attributes | |
VertexDescriptor * | vertex_lookup_ |
This lookup table translates segment ids into vertex descriptors. At position i is the segment with the id of instance_id_to_index_lookup_[0][i]. | |
int | size_of_conflict_table_ |
This variable defines the size of the conflict table. The size is quadratic. | |
int | max_instances_ |
This variable represents the max number of module instances in the design. Also, this is the number of rows in the instance_id_to_index_lookup_ table. | |
int | number_of_segments_ |
This variable defines how many segments exist in the segment graph. Also, this is the number of columns in the instance_id_to_index_lookup_ table. | |
int ** | instance_id_to_index_lookup_ |
This table should be used a lookup table: (segment id, instance id) -> index of conflict table. | |
bool ** | conflict_table_ |
The conflict table. | |
PathInstanceMapper & | path_instance_mapper_ |
SegmentGraph & | segment_graph_ |
ConflictInformation ** | conflict_info_ |
bool | debugging_ |
This class represents the data conflict table among the individual segments. Two segments have a conflict if a least one variable is by the first segment and read by the second segment. A two dimensional array represents this array.
risc::sg::DataConflictTable::DataConflictTable | ( | SegmentGraph & | graph, | |
PathInstanceMapper & | path_instance_mapper, | |||
bool | debugging | |||
) |
Default constructor for the DataConflictTable.
bool risc::sg::DataConflictTable::check_members_of_class | ( | SgVariableSymbol * | var_symbol, | |
DataConflictAstAttributes::Status | color | |||
) |
This function checks if the type of the given variable symbol is is a class or struct. If so, it will check if at least on member variable which is not static has the given color.
check_members_of_class
void risc::sg::DataConflictTable::color_members_of_class | ( | SgVariableSymbol * | var_symbol, | |
DataConflictAstAttributes::Status | color | |||
) |
This function checks if the type of the given variable symbol is is a class or struct. If so, all the member variables which are not static will be set to the given color.
color_members_of_class
bool risc::sg::DataConflictTable::data_conflict_between | ( | VertexDescriptor | first, | |
VertexDescriptor | second, | |||
int | row, | |||
int | column, | |||
int | inst_id_first, | |||
int | inst_id_second | |||
) |
This function checks if there is a read write conflict between two segments.
data_conflict_between
void risc::sg::DataConflictTable::determine_conflict_table | ( | ) | [virtual] |
This function determines conflicts among the segments.
determine_conflict_table
Reimplemented from risc::sg::ConflictTable.
SgVariableSymbol * risc::sg::DataConflictTable::get_mapped_variable | ( | SgVariableSymbol * | variable, | |
int | instance_id | |||
) |
This function determines for a given variable the mapped variable. If variable is a reference, the mapped variable will be looked up. Otherwise, the original variable is returned.
get_mapped_variable
bool risc::sg::ConflictTable::has_conflict | ( | int | segment_id_1, | |
int | instance_id_1, | |||
int | segment_id_2, | |||
int | instance_id_2 | |||
) | [inherited] |
This function looks up if there is a conflict between segment 1 with instance id 1 and segment 2 with instance id 2.
has_conflict
std::pair< int, int > risc::sg::ConflictTable::index_to_segment_and_instance_id | ( | int | index | ) | [inherited] |
This function translates a given index from the conflict table into the corresponding segment id and instance id. The first value is the segment id and the second value is the instance id.
index_to_segment_and_instance_id
void risc::sg::ConflictTable::print_conflict_table | ( | std::string | filename | ) | [inherited] |
Generates a html file of the conflict table.
print_conflict_table
void risc::sg::ConflictTable::print_instance_id_to_index_lookup_table | ( | ) | [inherited] |
This function prints the table instance_id_to_index_lookup_table in the terminal.
print_instance_id_to_index_lookup_table
void risc::sg::ConflictTable::print_lookup_table | ( | std::string | filename | ) | [inherited] |
Generates a html file of the lookup table.
print_lookup_table
int risc::sg::ConflictTable::segment_and_instance_id_to_index | ( | int | segment_id, | |
int | instance_id | |||
) | [inherited] |
This function translates a given segment id and instance id to a index of the conflict table.
segment_and_instance_id_to_index
risc::sg::VertexDescriptor risc::sg::ConflictTable::segment_id_to_vertex_descriptor | ( | int | id | ) | [inherited] |
This function translates the given segment id to the corresponding vertex descriptor.
segment_id_to_vertex_descriptor
void risc::sg::ConflictTable::set_conflict | ( | int | segment_id_1, | |
int | instance_id_1, | |||
int | segment_id_2, | |||
int | instance_id_2 | |||
) | [inherited] |
This function sets a conflict in the conflict table.
set_conflict
void risc::sg::ConflictTable::set_conflict_cause | ( | int | segment_id_1, | |
int | instance_id_1, | |||
int | segment_id_2, | |||
int | instance_id_2, | |||
SgNode * | cause = NULL | |||
) | [inherited] |
This function sets a conflict in the conflict table.
set_conflict
void risc::sg::DataConflictTable::uncolor_members_of_class | ( | SgVariableSymbol * | var_symbol | ) |
This function checks if the type of the given variable symbol is is a class or struct. If so, all the member variables which are not static will be set to UNUSED.
uncolor_members_of_class
ConflictInformation** risc::sg::ConflictTable::conflict_info_ [inherited] |
bool** risc::sg::ConflictTable::conflict_table_ [inherited] |
The conflict table.
bool risc::sg::ConflictTable::debugging_ [inherited] |
int** risc::sg::ConflictTable::instance_id_to_index_lookup_ [inherited] |
This table should be used a lookup table: (segment id, instance id) -> index of conflict table.
int risc::sg::ConflictTable::max_instances_ [inherited] |
This variable represents the max number of module instances in the design. Also, this is the number of rows in the instance_id_to_index_lookup_ table.
int risc::sg::ConflictTable::number_of_segments_ [inherited] |
This variable defines how many segments exist in the segment graph. Also, this is the number of columns in the instance_id_to_index_lookup_ table.
SegmentGraph& risc::sg::ConflictTable::segment_graph_ [inherited] |
int risc::sg::ConflictTable::size_of_conflict_table_ [inherited] |
This variable defines the size of the conflict table. The size is quadratic.
VertexDescriptor* risc::sg::ConflictTable::vertex_lookup_ [inherited] |
This lookup table translates segment ids into vertex descriptors. At position i is the segment with the id of instance_id_to_index_lookup_[0][i].