2020-02-14 12:07:04 -06:00
|
|
|
#ifndef BUILD_TOP_MODULE_MEMORY_H
|
|
|
|
#define BUILD_TOP_MODULE_MEMORY_H
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Include header files that are required by function declaration
|
|
|
|
*******************************************************************/
|
|
|
|
|
|
|
|
#include <map>
|
2022-10-06 19:08:50 -05:00
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "build_top_module_memory_utils.h"
|
2020-02-14 12:07:04 -06:00
|
|
|
#include "circuit_library.h"
|
2022-10-06 19:08:50 -05:00
|
|
|
#include "circuit_types.h"
|
2020-09-28 19:13:07 -05:00
|
|
|
#include "config_protocol.h"
|
2020-05-26 20:34:45 -05:00
|
|
|
#include "decoder_library.h"
|
2020-02-14 12:07:04 -06:00
|
|
|
#include "device_grid.h"
|
|
|
|
#include "device_rr_gsb.h"
|
2020-06-12 14:03:11 -05:00
|
|
|
#include "fabric_key.h"
|
2021-09-29 22:21:46 -05:00
|
|
|
#include "memory_bank_shift_register_banks.h"
|
2022-10-06 19:08:50 -05:00
|
|
|
#include "module_manager.h"
|
|
|
|
#include "vtr_ndmatrix.h"
|
|
|
|
#include "vtr_vector.h"
|
2020-02-14 12:07:04 -06:00
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Function declaration
|
|
|
|
*******************************************************************/
|
|
|
|
|
|
|
|
/* begin namespace openfpga */
|
|
|
|
namespace openfpga {
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void organize_top_module_memory_modules(
|
|
|
|
ModuleManager& module_manager, const ModuleId& top_module,
|
|
|
|
const CircuitLibrary& circuit_lib, const ConfigProtocol& config_protocol,
|
|
|
|
const CircuitModelId& sram_model, const DeviceGrid& grids,
|
2023-08-08 18:28:19 -05:00
|
|
|
const size_t& layer,
|
2022-10-06 19:08:50 -05:00
|
|
|
const vtr::Matrix<size_t>& grid_instance_ids,
|
|
|
|
const DeviceRRGSB& device_rr_gsb, const vtr::Matrix<size_t>& sb_instance_ids,
|
|
|
|
const std::map<t_rr_type, vtr::Matrix<size_t>>& cb_instance_ids,
|
|
|
|
const bool& compact_routing_hierarchy);
|
2020-02-14 12:07:04 -06:00
|
|
|
|
2023-07-24 14:13:45 -05:00
|
|
|
void build_top_module_configurable_regions(
|
|
|
|
ModuleManager& module_manager, const ModuleId& top_module,
|
|
|
|
const ConfigProtocol& config_protocol);
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void shuffle_top_module_configurable_children(
|
|
|
|
ModuleManager& module_manager, const ModuleId& top_module,
|
|
|
|
const ConfigProtocol& config_protocol);
|
2020-06-12 12:16:53 -05:00
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
int load_top_module_memory_modules_from_fabric_key(
|
|
|
|
ModuleManager& module_manager, const ModuleId& top_module,
|
|
|
|
const CircuitLibrary& circuit_lib, const ConfigProtocol& config_protocol,
|
|
|
|
const FabricKey& fabric_key);
|
2020-06-12 14:03:11 -05:00
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
TopModuleNumConfigBits find_top_module_regional_num_config_bit(
|
|
|
|
const ModuleManager& module_manager, const ModuleId& top_module,
|
|
|
|
const CircuitLibrary& circuit_lib, const CircuitModelId& sram_model,
|
|
|
|
const e_config_protocol_type& config_protocol_type);
|
2020-10-28 13:37:09 -05:00
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void add_top_module_sram_ports(
|
|
|
|
ModuleManager& module_manager, const ModuleId& module_id,
|
|
|
|
const CircuitLibrary& circuit_lib, const CircuitModelId& sram_model,
|
|
|
|
const ConfigProtocol& config_protocol,
|
|
|
|
const MemoryBankShiftRegisterBanks& blwl_sr_banks,
|
|
|
|
const TopModuleNumConfigBits& num_config_bits);
|
2020-05-30 16:49:15 -05:00
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void add_top_module_nets_memory_config_bus(
|
|
|
|
ModuleManager& module_manager, DecoderLibrary& decoder_lib,
|
|
|
|
MemoryBankShiftRegisterBanks& blwl_sr_banks, const ModuleId& parent_module,
|
|
|
|
const CircuitLibrary& circuit_lib, const ConfigProtocol& config_protocol,
|
|
|
|
const e_circuit_model_design_tech& mem_tech,
|
|
|
|
const TopModuleNumConfigBits& num_config_bits);
|
2020-02-14 12:07:04 -06:00
|
|
|
|
|
|
|
} /* end namespace openfpga */
|
|
|
|
|
|
|
|
#endif
|