2020-11-10 15:32:24 -06:00
|
|
|
/************************************************************************
|
|
|
|
* Member functions for class TileAnnotation
|
|
|
|
***********************************************************************/
|
|
|
|
#include "tile_annotation.h"
|
2023-09-25 18:51:01 -05:00
|
|
|
|
2023-09-25 18:46:34 -05:00
|
|
|
#include <algorithm>
|
2020-11-10 15:32:24 -06:00
|
|
|
|
2023-09-25 18:51:01 -05:00
|
|
|
#include "command_exit_codes.h"
|
2022-10-06 19:08:50 -05:00
|
|
|
#include "vtr_assert.h"
|
2023-09-25 18:46:34 -05:00
|
|
|
#include "vtr_log.h"
|
2022-10-06 19:08:50 -05:00
|
|
|
|
2020-11-10 15:32:24 -06:00
|
|
|
/* namespace openfpga begins */
|
|
|
|
namespace openfpga {
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
* Constructors
|
|
|
|
***********************************************************************/
|
2022-10-06 19:08:50 -05:00
|
|
|
TileAnnotation::TileAnnotation() { return; }
|
2020-11-10 15:32:24 -06:00
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
* Public Accessors : aggregates
|
|
|
|
***********************************************************************/
|
|
|
|
TileAnnotation::global_port_range TileAnnotation::global_ports() const {
|
|
|
|
return vtr::make_range(global_port_ids_.begin(), global_port_ids_.end());
|
|
|
|
}
|
|
|
|
|
2023-09-25 18:50:30 -05:00
|
|
|
std::vector<std::string> TileAnnotation::tiles_to_merge_ports() const {
|
2023-09-25 18:46:34 -05:00
|
|
|
std::vector<std::string> tile_names;
|
2023-09-25 18:51:01 -05:00
|
|
|
for (auto it = tile_ports_to_merge_.begin(); it != tile_ports_to_merge_.end();
|
|
|
|
it++) {
|
2023-09-25 18:46:34 -05:00
|
|
|
tile_names.push_back(it->first);
|
|
|
|
}
|
|
|
|
return tile_names;
|
|
|
|
}
|
|
|
|
|
2023-09-25 18:51:01 -05:00
|
|
|
std::vector<std::string> TileAnnotation::tile_ports_to_merge(
|
|
|
|
const std::string& tile_name) const {
|
2023-09-25 18:46:34 -05:00
|
|
|
std::vector<std::string> port_names;
|
|
|
|
const auto& result = tile_ports_to_merge_.find(tile_name);
|
2023-09-25 18:50:30 -05:00
|
|
|
if (result == tile_ports_to_merge_.end()) {
|
2023-09-25 18:51:01 -05:00
|
|
|
VTR_LOG_WARN("Tile '%s' does not contain any ports to merge!\n",
|
|
|
|
tile_name.c_str());
|
2023-09-25 18:46:34 -05:00
|
|
|
return port_names;
|
|
|
|
}
|
2023-09-25 18:50:30 -05:00
|
|
|
return result->second;
|
2023-09-25 18:46:34 -05:00
|
|
|
}
|
|
|
|
|
2020-11-10 15:32:24 -06:00
|
|
|
/************************************************************************
|
|
|
|
* Public Accessors
|
|
|
|
***********************************************************************/
|
2022-10-06 19:08:50 -05:00
|
|
|
std::string TileAnnotation::global_port_name(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
return global_port_names_[global_port_id];
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
std::vector<std::string> TileAnnotation::global_port_tile_names(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
return global_port_tile_names_[global_port_id];
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
std::vector<BasicPort> TileAnnotation::global_port_tile_ports(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
return global_port_tile_ports_[global_port_id];
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
std::vector<vtr::Point<size_t>> TileAnnotation::global_port_tile_coordinates(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
2021-01-09 19:47:12 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
return global_port_tile_coordinates_[global_port_id];
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
bool TileAnnotation::global_port_is_clock(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
return global_port_is_clock_[global_port_id];
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
bool TileAnnotation::global_port_is_set(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
return global_port_is_set_[global_port_id];
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
bool TileAnnotation::global_port_is_reset(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
return global_port_is_reset_[global_port_id];
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
size_t TileAnnotation::global_port_default_value(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
return global_port_default_values_[global_port_id];
|
|
|
|
}
|
|
|
|
|
2024-06-29 19:35:47 -05:00
|
|
|
bool TileAnnotation::global_port_thru_dedicated_network(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
|
|
|
return !global_port_clock_arch_tree_name(global_port_id).empty();
|
|
|
|
}
|
|
|
|
|
2023-03-01 00:36:41 -06:00
|
|
|
std::string TileAnnotation::global_port_clock_arch_tree_name(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
return global_port_clock_arch_tree_names_[global_port_id];
|
|
|
|
}
|
|
|
|
|
2023-09-25 19:22:26 -05:00
|
|
|
bool TileAnnotation::is_tile_port_to_merge(const std::string& tile_name,
|
|
|
|
const std::string& port_name) const {
|
2023-09-25 19:21:58 -05:00
|
|
|
const auto& result = tile_ports_to_merge_.find(tile_name);
|
|
|
|
if (result == tile_ports_to_merge_.end()) {
|
|
|
|
return false;
|
|
|
|
}
|
2023-09-25 23:13:11 -05:00
|
|
|
return result->second.end() !=
|
2023-09-25 19:22:26 -05:00
|
|
|
std::find(result->second.begin(), result->second.end(), port_name);
|
2023-09-25 19:21:58 -05:00
|
|
|
}
|
|
|
|
|
2020-11-10 15:32:24 -06:00
|
|
|
/************************************************************************
|
|
|
|
* Public Mutators
|
|
|
|
***********************************************************************/
|
2022-10-06 19:08:50 -05:00
|
|
|
TileGlobalPortId TileAnnotation::create_global_port(
|
|
|
|
const std::string& port_name) {
|
2020-11-11 14:59:24 -06:00
|
|
|
/* Ensure that the name is unique */
|
2022-10-06 19:08:50 -05:00
|
|
|
std::map<std::string, TileGlobalPortId>::iterator it =
|
|
|
|
global_port_name2ids_.find(port_name);
|
2020-11-11 14:59:24 -06:00
|
|
|
if (it != global_port_name2ids_.end()) {
|
|
|
|
return TileGlobalPortId::INVALID();
|
|
|
|
}
|
|
|
|
|
2020-11-10 15:32:24 -06:00
|
|
|
/* This is a legal name. we can create a new id */
|
|
|
|
TileGlobalPortId port_id = TileGlobalPortId(global_port_ids_.size());
|
|
|
|
global_port_ids_.push_back(port_id);
|
|
|
|
global_port_names_.push_back(port_name);
|
2021-01-09 19:47:12 -06:00
|
|
|
global_port_tile_names_.emplace_back();
|
|
|
|
global_port_tile_ports_.emplace_back();
|
|
|
|
global_port_tile_coordinates_.emplace_back();
|
2020-11-10 15:32:24 -06:00
|
|
|
global_port_is_clock_.push_back(false);
|
2023-03-01 00:36:41 -06:00
|
|
|
global_port_clock_arch_tree_names_.emplace_back();
|
2020-11-10 15:32:24 -06:00
|
|
|
global_port_is_set_.push_back(false);
|
|
|
|
global_port_is_reset_.push_back(false);
|
|
|
|
global_port_default_values_.push_back(0);
|
|
|
|
|
2020-11-11 14:59:24 -06:00
|
|
|
/* Register in the name-to-id map */
|
|
|
|
global_port_name2ids_[port_name] = port_id;
|
|
|
|
|
2020-11-10 15:32:24 -06:00
|
|
|
return port_id;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void TileAnnotation::add_global_port_tile_information(
|
|
|
|
const TileGlobalPortId& global_port_id, const std::string& tile_name,
|
|
|
|
const BasicPort& tile_port, const vtr::Point<size_t>& tile_coord) {
|
2021-01-09 19:47:12 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
global_port_tile_names_[global_port_id].push_back(tile_name);
|
|
|
|
global_port_tile_ports_[global_port_id].push_back(tile_port);
|
|
|
|
global_port_tile_coordinates_[global_port_id].push_back(tile_coord);
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void TileAnnotation::set_global_port_is_clock(
|
|
|
|
const TileGlobalPortId& global_port_id, const bool& is_clock) {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
global_port_is_clock_[global_port_id] = is_clock;
|
|
|
|
}
|
|
|
|
|
2023-03-01 00:36:41 -06:00
|
|
|
void TileAnnotation::set_global_port_clock_arch_tree_name(
|
|
|
|
const TileGlobalPortId& global_port_id, const std::string& clock_tree_name) {
|
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
global_port_clock_arch_tree_names_[global_port_id] = clock_tree_name;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void TileAnnotation::set_global_port_is_set(
|
|
|
|
const TileGlobalPortId& global_port_id, const bool& is_set) {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
global_port_is_set_[global_port_id] = is_set;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void TileAnnotation::set_global_port_is_reset(
|
|
|
|
const TileGlobalPortId& global_port_id, const bool& is_reset) {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
global_port_is_reset_[global_port_id] = is_reset;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void TileAnnotation::set_global_port_default_value(
|
|
|
|
const TileGlobalPortId& global_port_id, const size_t& default_value) {
|
2020-11-10 15:32:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
global_port_default_values_[global_port_id] = default_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
2022-10-06 19:08:50 -05:00
|
|
|
* Internal invalidators/validators
|
2020-11-10 15:32:24 -06:00
|
|
|
***********************************************************************/
|
|
|
|
/* Validators */
|
2022-10-06 19:08:50 -05:00
|
|
|
bool TileAnnotation::valid_global_port_id(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
|
|
|
return (size_t(global_port_id) < global_port_ids_.size()) &&
|
|
|
|
(global_port_id == global_port_ids_[global_port_id]);
|
2020-11-10 15:32:24 -06:00
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
bool TileAnnotation::valid_global_port_attributes(
|
|
|
|
const TileGlobalPortId& global_port_id) const {
|
2020-11-11 14:59:24 -06:00
|
|
|
VTR_ASSERT(valid_global_port_id(global_port_id));
|
|
|
|
|
|
|
|
int attribute_counter = 0;
|
|
|
|
|
|
|
|
if (true == global_port_is_clock_[global_port_id]) {
|
|
|
|
attribute_counter++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (true == global_port_is_reset_[global_port_id]) {
|
|
|
|
attribute_counter++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (true == global_port_is_set_[global_port_id]) {
|
|
|
|
attribute_counter++;
|
|
|
|
}
|
|
|
|
|
|
|
|
return ((0 == attribute_counter) || (1 == attribute_counter));
|
|
|
|
}
|
|
|
|
|
2023-09-25 18:51:01 -05:00
|
|
|
int TileAnnotation::add_merge_subtile_ports(const std::string& tile_name,
|
|
|
|
const std::string& port_name) {
|
2023-09-25 18:46:34 -05:00
|
|
|
auto result = tile_ports_to_merge_.find(tile_name);
|
|
|
|
if (result == tile_ports_to_merge_.end()) {
|
|
|
|
/* Empty list: add a new element */
|
|
|
|
tile_ports_to_merge_[tile_name].push_back(port_name);
|
|
|
|
} else {
|
|
|
|
/* Check if the port name is already in the list, if yes, error out */
|
2023-09-25 18:51:01 -05:00
|
|
|
if (result->second.end() ==
|
|
|
|
std::find(result->second.begin(), result->second.end(), port_name)) {
|
2023-09-25 18:46:34 -05:00
|
|
|
tile_ports_to_merge_[tile_name].push_back(port_name);
|
|
|
|
} else {
|
2023-09-25 18:51:01 -05:00
|
|
|
VTR_LOG_ERROR(
|
|
|
|
"Port '%s' has already been defined twice for tile '%s' to be merged!",
|
|
|
|
port_name.c_str(), tile_name.c_str());
|
2023-09-25 18:46:34 -05:00
|
|
|
return CMD_EXEC_FATAL_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return CMD_EXEC_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
} // namespace openfpga
|