2022-10-06 19:08:50 -05:00
|
|
|
#include "config_protocol.h"
|
|
|
|
|
2020-01-18 22:19:20 -06:00
|
|
|
#include "vtr_assert.h"
|
2021-09-23 16:25:25 -05:00
|
|
|
#include "vtr_log.h"
|
2020-01-18 22:19:20 -06:00
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
* Member functions for class ConfigProtocol
|
|
|
|
***********************************************************************/
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
* Constructors
|
|
|
|
***********************************************************************/
|
2022-10-06 19:08:50 -05:00
|
|
|
ConfigProtocol::ConfigProtocol() { return; }
|
2020-01-18 22:19:20 -06:00
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
* Public Accessors
|
|
|
|
***********************************************************************/
|
2022-10-06 19:08:50 -05:00
|
|
|
e_config_protocol_type ConfigProtocol::type() const { return type_; }
|
2020-01-18 22:19:20 -06:00
|
|
|
|
|
|
|
std::string ConfigProtocol::memory_model_name() const {
|
|
|
|
return memory_model_name_;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
CircuitModelId ConfigProtocol::memory_model() const { return memory_model_; }
|
2020-01-18 22:19:20 -06:00
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
int ConfigProtocol::num_regions() const { return num_regions_; }
|
2020-09-28 14:51:43 -05:00
|
|
|
|
2021-09-23 16:25:25 -05:00
|
|
|
e_blwl_protocol_type ConfigProtocol::bl_protocol_type() const {
|
|
|
|
return bl_protocol_type_;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string ConfigProtocol::bl_memory_model_name() const {
|
|
|
|
return bl_memory_model_name_;
|
|
|
|
}
|
|
|
|
|
|
|
|
CircuitModelId ConfigProtocol::bl_memory_model() const {
|
|
|
|
return bl_memory_model_;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
size_t ConfigProtocol::bl_num_banks() const { return bl_num_banks_; }
|
2021-09-28 16:20:35 -05:00
|
|
|
|
2021-09-23 16:25:25 -05:00
|
|
|
e_blwl_protocol_type ConfigProtocol::wl_protocol_type() const {
|
|
|
|
return wl_protocol_type_;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string ConfigProtocol::wl_memory_model_name() const {
|
|
|
|
return wl_memory_model_name_;
|
|
|
|
}
|
|
|
|
|
|
|
|
CircuitModelId ConfigProtocol::wl_memory_model() const {
|
|
|
|
return wl_memory_model_;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
size_t ConfigProtocol::wl_num_banks() const { return wl_num_banks_; }
|
2021-09-28 16:20:35 -05:00
|
|
|
|
2020-01-18 22:19:20 -06:00
|
|
|
/************************************************************************
|
|
|
|
* Public Mutators
|
|
|
|
***********************************************************************/
|
|
|
|
void ConfigProtocol::set_type(const e_config_protocol_type& type) {
|
|
|
|
type_ = type;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void ConfigProtocol::set_memory_model_name(
|
|
|
|
const std::string& memory_model_name) {
|
2020-01-18 22:19:20 -06:00
|
|
|
memory_model_name_ = memory_model_name;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ConfigProtocol::set_memory_model(const CircuitModelId& memory_model) {
|
|
|
|
memory_model_ = memory_model;
|
|
|
|
}
|
2020-09-28 14:51:43 -05:00
|
|
|
|
|
|
|
void ConfigProtocol::set_num_regions(const int& num_regions) {
|
|
|
|
num_regions_ = num_regions;
|
|
|
|
}
|
2021-09-23 16:25:25 -05:00
|
|
|
|
|
|
|
void ConfigProtocol::set_bl_protocol_type(const e_blwl_protocol_type& type) {
|
|
|
|
if (CONFIG_MEM_QL_MEMORY_BANK != type_) {
|
2022-10-06 19:08:50 -05:00
|
|
|
VTR_LOG_ERROR(
|
|
|
|
"BL protocol type is only applicable for configuration protocol '%d'",
|
|
|
|
CONFIG_PROTOCOL_TYPE_STRING[type_]);
|
2021-09-23 16:25:25 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
bl_protocol_type_ = type;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void ConfigProtocol::set_bl_memory_model_name(
|
|
|
|
const std::string& memory_model_name) {
|
2021-09-23 16:25:25 -05:00
|
|
|
if (BLWL_PROTOCOL_SHIFT_REGISTER != bl_protocol_type_) {
|
2022-10-06 19:08:50 -05:00
|
|
|
VTR_LOG_ERROR(
|
|
|
|
"BL protocol memory model is only applicable when '%d' is defined",
|
|
|
|
BLWL_PROTOCOL_TYPE_STRING[bl_protocol_type_]);
|
2021-09-23 16:25:25 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
bl_memory_model_name_ = memory_model_name;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ConfigProtocol::set_bl_memory_model(const CircuitModelId& memory_model) {
|
|
|
|
if (BLWL_PROTOCOL_SHIFT_REGISTER != bl_protocol_type_) {
|
2022-10-06 19:08:50 -05:00
|
|
|
VTR_LOG_ERROR(
|
|
|
|
"BL protocol memory model is only applicable when '%d' is defined",
|
|
|
|
BLWL_PROTOCOL_TYPE_STRING[bl_protocol_type_]);
|
2021-09-23 16:25:25 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
bl_memory_model_ = memory_model;
|
|
|
|
}
|
|
|
|
|
2021-09-28 16:20:35 -05:00
|
|
|
void ConfigProtocol::set_bl_num_banks(const size_t& num_banks) {
|
|
|
|
if (BLWL_PROTOCOL_SHIFT_REGISTER != bl_protocol_type_) {
|
2022-10-06 19:08:50 -05:00
|
|
|
VTR_LOG_ERROR(
|
|
|
|
"BL protocol memory model is only applicable when '%d' is defined",
|
|
|
|
BLWL_PROTOCOL_TYPE_STRING[bl_protocol_type_]);
|
2021-09-28 16:20:35 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
bl_num_banks_ = num_banks;
|
|
|
|
}
|
|
|
|
|
2021-09-23 16:25:25 -05:00
|
|
|
void ConfigProtocol::set_wl_protocol_type(const e_blwl_protocol_type& type) {
|
|
|
|
if (CONFIG_MEM_QL_MEMORY_BANK != type_) {
|
2022-10-06 19:08:50 -05:00
|
|
|
VTR_LOG_ERROR(
|
|
|
|
"WL protocol type is only applicable for configuration protocol '%d'",
|
|
|
|
CONFIG_PROTOCOL_TYPE_STRING[type_]);
|
2021-09-23 16:25:25 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
wl_protocol_type_ = type;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void ConfigProtocol::set_wl_memory_model_name(
|
|
|
|
const std::string& memory_model_name) {
|
2021-09-23 16:25:25 -05:00
|
|
|
if (BLWL_PROTOCOL_SHIFT_REGISTER != wl_protocol_type_) {
|
2022-10-06 19:08:50 -05:00
|
|
|
VTR_LOG_ERROR(
|
|
|
|
"WL protocol memory model is only applicable when '%d' is defined",
|
|
|
|
BLWL_PROTOCOL_TYPE_STRING[wl_protocol_type_]);
|
2021-09-23 16:25:25 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
wl_memory_model_name_ = memory_model_name;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ConfigProtocol::set_wl_memory_model(const CircuitModelId& memory_model) {
|
|
|
|
if (BLWL_PROTOCOL_SHIFT_REGISTER != wl_protocol_type_) {
|
2022-10-06 19:08:50 -05:00
|
|
|
VTR_LOG_ERROR(
|
|
|
|
"WL protocol memory model is only applicable when '%d' is defined",
|
|
|
|
BLWL_PROTOCOL_TYPE_STRING[wl_protocol_type_]);
|
2021-09-23 16:25:25 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
wl_memory_model_ = memory_model;
|
|
|
|
}
|
2021-09-28 16:20:35 -05:00
|
|
|
|
|
|
|
void ConfigProtocol::set_wl_num_banks(const size_t& num_banks) {
|
|
|
|
if (BLWL_PROTOCOL_SHIFT_REGISTER != wl_protocol_type_) {
|
2022-10-06 19:08:50 -05:00
|
|
|
VTR_LOG_ERROR(
|
|
|
|
"WL protocol memory model is only applicable when '%d' is defined",
|
|
|
|
BLWL_PROTOCOL_TYPE_STRING[wl_protocol_type_]);
|
2021-09-28 16:20:35 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
wl_num_banks_ = num_banks;
|
|
|
|
}
|