[Tool] Now activity file is not a manadatory input of openfpga tools

This commit is contained in:
tangxifan 2021-01-29 11:33:40 -07:00
parent 78ad9cd000
commit 4b77a3a574
4 changed files with 13 additions and 9 deletions

View File

@ -237,6 +237,12 @@ int annotate_simulation_setting(const AtomContext& atom_ctx,
*/ */
VTR_LOG("User specified the number of operating clock cycles to be inferred from signal activities\n"); VTR_LOG("User specified the number of operating clock cycles to be inferred from signal activities\n");
/* Error out if net activity is not defined */
if (true == net_activity.empty()) {
VTR_LOG_ERROR("Signal activities are not defined!\nPlease check if activity file is given and properly generated!\n");
return CMD_EXEC_FATAL_ERROR;
}
/* Use a fixed simulation window size now. TODO: this could be specified by users */ /* Use a fixed simulation window size now. TODO: this could be specified by users */
size_t num_clock_cycles = recommend_num_sim_clock_cycle(atom_ctx, size_t num_clock_cycles = recommend_num_sim_clock_cycle(atom_ctx,
net_activity, net_activity,

View File

@ -67,7 +67,6 @@ class OpenfpgaContext : public Context {
const openfpga::FabricBitstream& fabric_bitstream() const { return fabric_bitstream_; } const openfpga::FabricBitstream& fabric_bitstream() const { return fabric_bitstream_; }
const openfpga::IoLocationMap& io_location_map() const { return io_location_map_; } const openfpga::IoLocationMap& io_location_map() const { return io_location_map_; }
const openfpga::FabricGlobalPortInfo& fabric_global_port_info() const { return fabric_global_port_info_; } const openfpga::FabricGlobalPortInfo& fabric_global_port_info() const { return fabric_global_port_info_; }
const std::unordered_map<AtomNetId, t_net_power>& net_activity() const { return net_activity_; }
const openfpga::NetlistManager& verilog_netlists() const { return verilog_netlists_; } const openfpga::NetlistManager& verilog_netlists() const { return verilog_netlists_; }
const openfpga::NetlistManager& spice_netlists() const { return spice_netlists_; } const openfpga::NetlistManager& spice_netlists() const { return spice_netlists_; }
public: /* Public mutators */ public: /* Public mutators */
@ -88,7 +87,6 @@ class OpenfpgaContext : public Context {
openfpga::FabricBitstream& mutable_fabric_bitstream() { return fabric_bitstream_; } openfpga::FabricBitstream& mutable_fabric_bitstream() { return fabric_bitstream_; }
openfpga::IoLocationMap& mutable_io_location_map() { return io_location_map_; } openfpga::IoLocationMap& mutable_io_location_map() { return io_location_map_; }
openfpga::FabricGlobalPortInfo& mutable_fabric_global_port_info() { return fabric_global_port_info_; } openfpga::FabricGlobalPortInfo& mutable_fabric_global_port_info() { return fabric_global_port_info_; }
std::unordered_map<AtomNetId, t_net_power>& mutable_net_activity() { return net_activity_; }
openfpga::NetlistManager& mutable_verilog_netlists() { return verilog_netlists_; } openfpga::NetlistManager& mutable_verilog_netlists() { return verilog_netlists_; }
openfpga::NetlistManager& mutable_spice_netlists() { return spice_netlists_; } openfpga::NetlistManager& mutable_spice_netlists() { return spice_netlists_; }
private: /* Internal data */ private: /* Internal data */
@ -138,9 +136,6 @@ class OpenfpgaContext : public Context {
openfpga::NetlistManager verilog_netlists_; openfpga::NetlistManager verilog_netlists_;
openfpga::NetlistManager spice_netlists_; openfpga::NetlistManager spice_netlists_;
/* Net activities of users' implementation */
std::unordered_map<AtomNetId, t_net_power> net_activity_;
/* Flow status */ /* Flow status */
openfpga::FlowManager flow_manager_; openfpga::FlowManager flow_manager_;
}; };

View File

@ -148,8 +148,11 @@ int link_arch(OpenfpgaContext& openfpga_ctx,
* should be inferred from FPGA implmentation * should be inferred from FPGA implmentation
* - When FPGA-SPICE is enabled * - When FPGA-SPICE is enabled
*/ */
openfpga_ctx.mutable_net_activity() = read_activity(g_vpr_ctx.atom().nlist, std::unordered_map<AtomNetId, t_net_power> net_activity;
cmd_context.option_value(cmd, opt_activity_file).c_str()); if (true == cmd_context.option_enable(cmd, opt_activity_file)) {
net_activity = read_activity(g_vpr_ctx.atom().nlist,
cmd_context.option_value(cmd, opt_activity_file).c_str());
}
/* TODO: Annotate the number of clock cycles and clock frequency by following VPR results /* TODO: Annotate the number of clock cycles and clock frequency by following VPR results
* We SHOULD create a new simulation setting for OpenFPGA use only * We SHOULD create a new simulation setting for OpenFPGA use only
@ -160,7 +163,7 @@ int link_arch(OpenfpgaContext& openfpga_ctx,
*/ */
//openfpga_ctx.mutable_simulation_setting() = openfpga_ctx.mutable_arch().sim_setting; //openfpga_ctx.mutable_simulation_setting() = openfpga_ctx.mutable_arch().sim_setting;
if (CMD_EXEC_FATAL_ERROR == annotate_simulation_setting(g_vpr_ctx.atom(), if (CMD_EXEC_FATAL_ERROR == annotate_simulation_setting(g_vpr_ctx.atom(),
openfpga_ctx.net_activity(), net_activity,
openfpga_ctx.mutable_simulation_setting())) { openfpga_ctx.mutable_simulation_setting())) {
return CMD_EXEC_FATAL_ERROR; return CMD_EXEC_FATAL_ERROR;
} }

View File

@ -125,7 +125,7 @@ ShellCommandId add_openfpga_link_arch_command(openfpga::Shell<OpenfpgaContext>&
Command shell_cmd("link_openfpga_arch"); Command shell_cmd("link_openfpga_arch");
/* Add an option '--activity_file'*/ /* Add an option '--activity_file'*/
CommandOptionId opt_act_file = shell_cmd.add_option("activity_file", true, "file path to the signal activity"); CommandOptionId opt_act_file = shell_cmd.add_option("activity_file", false, "file path to the signal activity");
shell_cmd.set_option_require_value(opt_act_file, openfpga::OPT_STRING); shell_cmd.set_option_require_value(opt_act_file, openfpga::OPT_STRING);
/* Add an option '--sort_gsb_chan_node_in_edges'*/ /* Add an option '--sort_gsb_chan_node_in_edges'*/