/****************************************************************************** * This files includes declarations for most utilized functions * for data structures for module management. ******************************************************************************/ #ifndef MODULE_MANAGER_UTILS_H #define MODULE_MANAGER_UTILS_H /******************************************************************** * Include header files that are required by function declaration *******************************************************************/ #include #include /* Headers from readarch library */ #include "physical_types.h" /* Headers from openfpgautil library */ #include "openfpga_port.h" /* Headers from readarchopenfpga library */ #include "circuit_library.h" #include "circuit_types.h" #include "config_protocol.h" #include "decoder_library.h" #include "fabric_key.h" #include "module_manager.h" #include "vpr_device_annotation.h" /******************************************************************** * Function declaration *******************************************************************/ /* begin namespace openfpga */ namespace openfpga { constexpr std::array MODULE_IO_PORT_TYPES = {ModuleManager::MODULE_GPIN_PORT, ModuleManager::MODULE_GPOUT_PORT, ModuleManager::MODULE_GPIO_PORT}; void reserve_module_manager_module_nets(ModuleManager& module_manager, const ModuleId& module); size_t count_module_manager_module_configurable_children( const ModuleManager& module_manager, const ModuleId& module, const ModuleManager::e_config_child_type& config_child_type); std::pair find_module_manager_instance_module_info( const ModuleManager& module_manager, const ModuleId& parent, const std::string& instance_name); ModuleId add_circuit_model_to_module_manager( ModuleManager& module_manager, const CircuitLibrary& circuit_lib, const CircuitModelId& circuit_model, const std::string& module_name); ModuleId add_circuit_model_to_module_manager( ModuleManager& module_manager, const CircuitLibrary& circuit_lib, const CircuitModelId& circuit_model); void add_reserved_sram_ports_to_module_manager(ModuleManager& module_manager, const ModuleId& module_id, const size_t& port_size); void add_formal_verification_sram_ports_to_module_manager( ModuleManager& module_manager, const ModuleId& module_id, const CircuitLibrary& circuit_lib, const CircuitModelId& sram_model, const std::string& preproc_flag, const size_t& port_size); void add_sram_ports_to_module_manager( ModuleManager& module_manager, const ModuleId& module_id, const CircuitLibrary& circuit_lib, const CircuitModelId& sram_model, const e_config_protocol_type sram_orgz_type, const size_t& num_config_bits); void add_pb_sram_ports_to_module_manager( ModuleManager& module_manager, const ModuleId& module_id, const CircuitLibrary& circuit_lib, const CircuitModelId& sram_model, const e_config_protocol_type sram_orgz_type, const size_t& num_config_bits, const uint32_t defined_num_wl = 0); void add_primitive_pb_type_ports_to_module_manager( ModuleManager& module_manager, const ModuleId& module_id, t_pb_type* cur_pb_type, const VprDeviceAnnotation& vpr_device_annotation); void add_pb_type_ports_to_module_manager(ModuleManager& module_manager, const ModuleId& module_id, t_pb_type* cur_pb_type); bool module_net_is_local_wire(const ModuleManager& module_manager, const ModuleId& module_id, const ModuleNetId& module_net); bool module_net_include_output_short_connection( const ModuleManager& module_manager, const ModuleId& module_id, const ModuleNetId& module_net); bool module_net_include_local_short_connection( const ModuleManager& module_manager, const ModuleId& module_id, const ModuleNetId& module_net); void add_primitive_pb_type_module_nets( ModuleManager& module_manager, const ModuleId& pb_type_module, const ModuleId& child_module, const size_t& child_instance_id, const CircuitLibrary& circuit_lib, t_pb_type* cur_pb_type, const VprDeviceAnnotation& vpr_device_annotation); void add_module_nets_between_logic_and_memory_sram_bus( ModuleManager& module_manager, const ModuleId& parent_module, const ModuleId& logic_module, const size_t& logic_instance_id, const ModuleId& memory_module, const size_t& memory_instance_id, const CircuitLibrary& circuit_lib, const CircuitModelId& logic_model); void add_module_nets_cmos_flatten_memory_config_bus( ModuleManager& module_manager, const ModuleId& parent_module, const e_config_protocol_type& sram_orgz_type, const e_circuit_model_port_type& config_port_type, const ModuleManager::e_config_child_type& config_child_type); void add_module_nets_cmos_memory_bank_bl_config_bus( ModuleManager& module_manager, const ModuleId& parent_module, const e_config_protocol_type& sram_orgz_type, const e_circuit_model_port_type& config_port_type, const ModuleManager::e_config_child_type& config_child_type); void add_module_nets_cmos_memory_bank_wl_config_bus( ModuleManager& module_manager, const ModuleId& parent_module, const e_config_protocol_type& sram_orgz_type, const e_circuit_model_port_type& config_port_type, const ModuleManager::e_config_child_type& config_child_type); void add_module_nets_cmos_memory_chain_config_bus( ModuleManager& module_manager, const ModuleId& parent_module, const e_config_protocol_type& sram_orgz_type, const ModuleManager::e_config_child_type& config_child_type); void add_module_nets_cmos_memory_frame_config_bus( ModuleManager& module_manager, DecoderLibrary& decoder_lib, const ModuleId& parent_module, const ModuleManager::e_config_child_type& config_child_type); void add_module_nets_memory_config_bus( ModuleManager& module_manager, DecoderLibrary& decoder_lib, const ModuleId& parent_module, const e_config_protocol_type& sram_orgz_type, const e_circuit_model_design_tech& mem_tech, const ModuleManager::e_config_child_type& config_child_type); void add_pb_module_nets_memory_config_bus( ModuleManager& module_manager, DecoderLibrary& decoder_lib, const ModuleId& parent_module, const e_config_protocol_type& sram_orgz_type, const e_circuit_model_design_tech& mem_tech, const ModuleManager::e_config_child_type& config_child_type); size_t find_module_num_shared_config_bits(const ModuleManager& module_manager, const ModuleId& module_id); size_t find_module_num_config_bits( const ModuleManager& module_manager, const ModuleId& module_id, const CircuitLibrary& circuit_lib, const CircuitModelId& sram_model, const e_config_protocol_type& sram_orgz_type); void add_module_global_input_ports_from_child_modules( ModuleManager& module_manager, const ModuleId& module_id, const std::vector& port_name_to_ignore = std::vector()); void add_module_global_output_ports_from_child_modules( ModuleManager& module_manager, const ModuleId& module_id); void add_module_global_ports_from_child_modules( ModuleManager& module_manager, const ModuleId& module_id, const std::vector& port_name_to_ignore = std::vector()); void add_module_gpio_ports_from_child_modules(ModuleManager& module_manager, const ModuleId& module_id); size_t find_module_num_shared_config_bits_from_child_modules( ModuleManager& module_manager, const ModuleId& module_id); size_t find_module_num_config_bits_from_child_modules( ModuleManager& module_manager, const ModuleId& module_id, const CircuitLibrary& circuit_lib, const CircuitModelId& sram_model, const e_config_protocol_type& sram_orgz_type, const ModuleManager::e_config_child_type& config_child_type); ModuleNetId create_module_source_pin_net(ModuleManager& module_manager, const ModuleId& cur_module_id, const ModuleId& src_module_id, const size_t& src_instance_id, const ModulePortId& src_module_port_id, const size_t& src_pin_id); void add_module_bus_nets( ModuleManager& module_manager, const ModuleId& cur_module_id, const ModuleId& src_module_id, const size_t& src_instance_id, const ModulePortId& src_module_port_id, const ModuleId& des_module_id, const size_t& des_instance_id, const ModulePortId& des_module_port_id); } /* end namespace openfpga */ #endif