[core] standardize API for clock network intermeidate drivers
This commit is contained in:
parent
af09120a52
commit
9e461284d0
|
@ -283,6 +283,39 @@ std::vector<ClockInternalDriverId> ClockNetwork::spine_intermediate_drivers(
|
||||||
return result->second;
|
return result->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
vtr::Point<int> ClockNetwork::spine_intermediate_driver_routing_track_coord(const ClockSpineId& spine_id, const vtr::Point<int>& coord) const {
|
||||||
|
vtr::Point<int> des_coord(coord.x(), coord.y());
|
||||||
|
Direction des_spine_direction = spine_direction(spine_id);
|
||||||
|
/* des node depends on the type of routing track and direction. But it
|
||||||
|
* should be a starting point at the current SB[x][y] */
|
||||||
|
if (des_spine_direction == Direction::INC &&
|
||||||
|
spine_track_type(spine_id) == CHANX) {
|
||||||
|
des_coord.set_x(coord.x() + 1);
|
||||||
|
}
|
||||||
|
if (des_spine_direction == Direction::INC &&
|
||||||
|
spine_track_type(spine_id) == CHANY) {
|
||||||
|
des_coord.set_y(coord.y() + 1);
|
||||||
|
}
|
||||||
|
return des_coord;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<ClockInternalDriverId> ClockNetwork::spine_intermediate_drivers_by_routing_track(
|
||||||
|
const ClockSpineId& spine_id, const vtr::Point<int>& track_coord) const {
|
||||||
|
vtr::Point<int> des_coord(track_coord.x(), track_coord.y());
|
||||||
|
Direction des_spine_direction = spine_direction(spine_id);
|
||||||
|
/* des node depends on the type of routing track and direction. But it
|
||||||
|
* should be a starting point at the current SB[x][y] */
|
||||||
|
if (des_spine_direction == Direction::INC &&
|
||||||
|
spine_track_type(spine_id) == CHANX) {
|
||||||
|
des_coord.set_x(track_coord.x() - 1);
|
||||||
|
}
|
||||||
|
if (des_spine_direction == Direction::INC &&
|
||||||
|
spine_track_type(spine_id) == CHANY) {
|
||||||
|
des_coord.set_y(track_coord.y() - 1);
|
||||||
|
}
|
||||||
|
return spine_intermediate_drivers(spine_id, des_coord);
|
||||||
|
}
|
||||||
|
|
||||||
ClockLevelId ClockNetwork::spine_level(const ClockSpineId& spine_id) const {
|
ClockLevelId ClockNetwork::spine_level(const ClockSpineId& spine_id) const {
|
||||||
VTR_ASSERT(valid_spine_id(spine_id));
|
VTR_ASSERT(valid_spine_id(spine_id));
|
||||||
if (is_dirty_) {
|
if (is_dirty_) {
|
||||||
|
|
|
@ -97,8 +97,14 @@ class ClockNetwork {
|
||||||
std::string spine_name(const ClockSpineId& spine_id) const;
|
std::string spine_name(const ClockSpineId& spine_id) const;
|
||||||
vtr::Point<int> spine_start_point(const ClockSpineId& spine_id) const;
|
vtr::Point<int> spine_start_point(const ClockSpineId& spine_id) const;
|
||||||
vtr::Point<int> spine_end_point(const ClockSpineId& spine_id) const;
|
vtr::Point<int> spine_end_point(const ClockSpineId& spine_id) const;
|
||||||
|
/* Find the intermediate drivers by the SB coordinate */
|
||||||
std::vector<ClockInternalDriverId> spine_intermediate_drivers(
|
std::vector<ClockInternalDriverId> spine_intermediate_drivers(
|
||||||
const ClockSpineId& spine_id, const vtr::Point<int>& coord) const;
|
const ClockSpineId& spine_id, const vtr::Point<int>& coord) const;
|
||||||
|
/* Find the coordinate of routing track which the intermediate driver will driver. Note that the coordinate may be different than the coordinate of intermeidate driver. One of the exceptions lies in the CHANX with INC direction, which starts actually on the routing tracks on the right side of a SB, resulting in x -> x + 1. Another exception is on the CHANY with INC direction, which starts actually on the routing tracks on the top side of a SB, resulting in y - > y + 1. This function is to provide an official conversion the coordinates. */
|
||||||
|
vtr::Point<int> spine_intermediate_driver_routing_track_coord(const ClockSpineId& spine_id, const vtr::Point<int>& coord) const;
|
||||||
|
/* Find the intermediate drivers by the routing track starting point. Note that the routing track starting point may be different from the SB coordinate. See the exceptions in the spine_intermediate_driver_track_coord() */
|
||||||
|
std::vector<ClockInternalDriverId> spine_intermediate_drivers_by_routing_track(
|
||||||
|
const ClockSpineId& spine_id, const vtr::Point<int>& track_coord) const;
|
||||||
|
|
||||||
/* Return the level where the spine locates in the multi-layer clock tree
|
/* Return the level where the spine locates in the multi-layer clock tree
|
||||||
* structure */
|
* structure */
|
||||||
|
@ -273,7 +279,6 @@ class ClockNetwork {
|
||||||
/* Validate the internal data. Required to ensure clean data before usage. If
|
/* Validate the internal data. Required to ensure clean data before usage. If
|
||||||
* validation is successful, is_valid() will return true */
|
* validation is successful, is_valid() will return true */
|
||||||
bool validate() const;
|
bool validate() const;
|
||||||
|
|
||||||
private: /* Public invalidators/validators */
|
private: /* Public invalidators/validators */
|
||||||
/* Ensure tree data is clean. All the spines are valid, and switch points are
|
/* Ensure tree data is clean. All the spines are valid, and switch points are
|
||||||
* valid */
|
* valid */
|
||||||
|
|
|
@ -762,17 +762,7 @@ static int add_rr_graph_opin2clk_intermediate_edges(
|
||||||
/* Get the rr node of destination spine */
|
/* Get the rr node of destination spine */
|
||||||
Direction des_spine_direction = clk_ntwk.spine_direction(ispine);
|
Direction des_spine_direction = clk_ntwk.spine_direction(ispine);
|
||||||
ClockLevelId des_spine_level = clk_ntwk.spine_level(ispine);
|
ClockLevelId des_spine_level = clk_ntwk.spine_level(ispine);
|
||||||
vtr::Point<int> des_coord(coord.x(), coord.y());
|
vtr::Point<int> des_coord = clk_ntwk.spine_intermediate_driver_routing_track_coord(ispine, coord);
|
||||||
/* des node depends on the type of routing track and direction. But it
|
|
||||||
* should be a starting point at the current SB[x][y] */
|
|
||||||
if (des_spine_direction == Direction::INC &&
|
|
||||||
clk_ntwk.spine_track_type(ispine) == CHANX) {
|
|
||||||
des_coord.set_x(coord.x() + 1);
|
|
||||||
}
|
|
||||||
if (des_spine_direction == Direction::INC &&
|
|
||||||
clk_ntwk.spine_track_type(ispine) == CHANY) {
|
|
||||||
des_coord.set_y(coord.y() + 1);
|
|
||||||
}
|
|
||||||
RRNodeId des_node = clk_rr_lookup.find_node(
|
RRNodeId des_node = clk_rr_lookup.find_node(
|
||||||
des_coord.x(), des_coord.y(), clk_tree, des_spine_level, ipin,
|
des_coord.x(), des_coord.y(), clk_tree, des_spine_level, ipin,
|
||||||
des_spine_direction, verbose);
|
des_spine_direction, verbose);
|
||||||
|
|
|
@ -440,17 +440,7 @@ static int rec_expand_and_route_clock_spine(
|
||||||
* global net is mapped to the internal driver, use it as the previous
|
* global net is mapped to the internal driver, use it as the previous
|
||||||
* node */
|
* node */
|
||||||
size_t use_int_driver = 0;
|
size_t use_int_driver = 0;
|
||||||
vtr::Point<int> int_driver_coord(des_coord.x(), des_coord.y());
|
if (!clk_ntwk.spine_intermediate_drivers_by_routing_track(curr_spine, des_coord)
|
||||||
if (des_spine_direction == Direction::INC &&
|
|
||||||
clk_ntwk.spine_track_type(curr_spine) == CHANX) {
|
|
||||||
int_driver_coord.set_x(des_coord.x() - 1);
|
|
||||||
}
|
|
||||||
if (des_spine_direction == Direction::INC &&
|
|
||||||
clk_ntwk.spine_track_type(curr_spine) == CHANY) {
|
|
||||||
int_driver_coord.set_y(des_coord.y() - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!clk_ntwk.spine_intermediate_drivers(curr_spine, int_driver_coord)
|
|
||||||
.empty() &&
|
.empty() &&
|
||||||
tree2clk_pin_map.find(curr_pin) != tree2clk_pin_map.end()) {
|
tree2clk_pin_map.find(curr_pin) != tree2clk_pin_map.end()) {
|
||||||
VTR_LOGV(verbose,
|
VTR_LOGV(verbose,
|
||||||
|
@ -517,17 +507,7 @@ static int rec_expand_and_route_clock_spine(
|
||||||
* global net is mapped to the internal driver, use it as the previous
|
* global net is mapped to the internal driver, use it as the previous
|
||||||
* node */
|
* node */
|
||||||
size_t use_int_driver = 0;
|
size_t use_int_driver = 0;
|
||||||
vtr::Point<int> int_driver_coord(des_coord.x(), des_coord.y());
|
if (!clk_ntwk.spine_intermediate_drivers_by_routing_track(curr_spine, des_coord)
|
||||||
if (des_spine_direction == Direction::INC &&
|
|
||||||
clk_ntwk.spine_track_type(curr_spine) == CHANX) {
|
|
||||||
int_driver_coord.set_x(des_coord.x() - 1);
|
|
||||||
}
|
|
||||||
if (des_spine_direction == Direction::INC &&
|
|
||||||
clk_ntwk.spine_track_type(curr_spine) == CHANY) {
|
|
||||||
int_driver_coord.set_y(des_coord.y() - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!clk_ntwk.spine_intermediate_drivers(curr_spine, int_driver_coord)
|
|
||||||
.empty() &&
|
.empty() &&
|
||||||
tree2clk_pin_map.find(curr_pin) != tree2clk_pin_map.end()) {
|
tree2clk_pin_map.find(curr_pin) != tree2clk_pin_map.end()) {
|
||||||
VTR_LOGV(
|
VTR_LOGV(
|
||||||
|
|
Loading…
Reference in New Issue