2020-02-11 18:40:37 -06:00
|
|
|
/********************************************************************
|
|
|
|
* This file includes functions to compress the hierachy of routing architecture
|
|
|
|
*******************************************************************/
|
|
|
|
/* Headers from vtrutil library */
|
|
|
|
#include "vtr_time.h"
|
|
|
|
#include "vtr_log.h"
|
|
|
|
|
2020-04-08 17:18:05 -05:00
|
|
|
/* Headers from openfpgashell library */
|
|
|
|
#include "command_exit_codes.h"
|
|
|
|
|
2020-02-11 18:40:37 -06:00
|
|
|
#include "device_rr_gsb.h"
|
|
|
|
#include "device_rr_gsb_utils.h"
|
2020-02-12 18:53:23 -06:00
|
|
|
#include "build_device_module.h"
|
2020-05-05 15:36:27 -05:00
|
|
|
#include "fabric_hierarchy_writer.h"
|
2020-06-12 11:41:34 -05:00
|
|
|
#include "fabric_key_writer.h"
|
2020-02-12 16:49:47 -06:00
|
|
|
#include "openfpga_build_fabric.h"
|
2020-02-11 18:40:37 -06:00
|
|
|
|
|
|
|
/* Include global variables of VPR */
|
|
|
|
#include "globals.h"
|
|
|
|
|
|
|
|
/* begin namespace openfpga */
|
|
|
|
namespace openfpga {
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Identify the unique GSBs from the Device RR GSB arrays
|
|
|
|
* This function should only be called after the GSB builder is done
|
|
|
|
*******************************************************************/
|
2020-02-12 16:49:47 -06:00
|
|
|
static
|
2020-02-26 20:58:18 -06:00
|
|
|
void compress_routing_hierarchy(OpenfpgaContext& openfpga_ctx,
|
2020-02-12 16:49:47 -06:00
|
|
|
const bool& verbose_output) {
|
2020-02-11 18:40:37 -06:00
|
|
|
vtr::ScopedStartFinishTimer timer("Identify unique General Switch Blocks (GSBs)");
|
|
|
|
|
|
|
|
/* Build unique module lists */
|
2020-02-26 20:58:18 -06:00
|
|
|
openfpga_ctx.mutable_device_rr_gsb().build_unique_module(g_vpr_ctx.device().rr_graph);
|
2020-02-11 18:40:37 -06:00
|
|
|
|
|
|
|
/* Report the stats */
|
|
|
|
VTR_LOGV(verbose_output,
|
2020-03-21 19:07:00 -05:00
|
|
|
"Detected %lu unique X-direction connection blocks from a total of %d (compression rate=%.2f%)\n",
|
2020-02-26 20:58:18 -06:00
|
|
|
openfpga_ctx.device_rr_gsb().get_num_cb_unique_module(CHANX),
|
|
|
|
find_device_rr_gsb_num_cb_modules(openfpga_ctx.device_rr_gsb(), CHANX),
|
2020-03-22 17:13:04 -05:00
|
|
|
100. * ((float)find_device_rr_gsb_num_cb_modules(openfpga_ctx.device_rr_gsb(), CHANX) / (float)openfpga_ctx.device_rr_gsb().get_num_cb_unique_module(CHANX) - 1.));
|
2020-02-11 18:40:37 -06:00
|
|
|
|
|
|
|
VTR_LOGV(verbose_output,
|
2020-03-21 19:07:00 -05:00
|
|
|
"Detected %lu unique Y-direction connection blocks from a total of %d (compression rate=%.2f%)\n",
|
2020-02-26 20:58:18 -06:00
|
|
|
openfpga_ctx.device_rr_gsb().get_num_cb_unique_module(CHANY),
|
|
|
|
find_device_rr_gsb_num_cb_modules(openfpga_ctx.device_rr_gsb(), CHANY),
|
2020-03-22 17:13:04 -05:00
|
|
|
100. * ((float)find_device_rr_gsb_num_cb_modules(openfpga_ctx.device_rr_gsb(), CHANY) / (float)openfpga_ctx.device_rr_gsb().get_num_cb_unique_module(CHANY) - 1.));
|
2020-02-11 18:40:37 -06:00
|
|
|
|
|
|
|
VTR_LOGV(verbose_output,
|
2020-03-21 19:07:00 -05:00
|
|
|
"Detected %lu unique switch blocks from a total of %d (compression rate=%.2f%)\n",
|
2020-02-26 20:58:18 -06:00
|
|
|
openfpga_ctx.device_rr_gsb().get_num_sb_unique_module(),
|
|
|
|
find_device_rr_gsb_num_sb_modules(openfpga_ctx.device_rr_gsb()),
|
2020-03-22 17:13:04 -05:00
|
|
|
100. * ((float)find_device_rr_gsb_num_sb_modules(openfpga_ctx.device_rr_gsb()) / (float)openfpga_ctx.device_rr_gsb().get_num_sb_unique_module() - 1.));
|
2020-02-11 18:40:37 -06:00
|
|
|
|
2020-03-21 19:07:00 -05:00
|
|
|
VTR_LOG("Detected %lu unique general switch blocks from a total of %d (compression rate=%.2f%)\n",
|
|
|
|
openfpga_ctx.device_rr_gsb().get_num_gsb_unique_module(),
|
|
|
|
find_device_rr_gsb_num_gsb_modules(openfpga_ctx.device_rr_gsb()),
|
2020-03-22 17:13:04 -05:00
|
|
|
100. * ((float)find_device_rr_gsb_num_gsb_modules(openfpga_ctx.device_rr_gsb()) / (float)openfpga_ctx.device_rr_gsb().get_num_gsb_unique_module() - 1.));
|
2020-02-12 16:49:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Build the module graph for FPGA device
|
|
|
|
*******************************************************************/
|
2020-04-08 17:18:05 -05:00
|
|
|
int build_fabric(OpenfpgaContext& openfpga_ctx,
|
|
|
|
const Command& cmd, const CommandContext& cmd_context) {
|
2020-02-12 16:49:47 -06:00
|
|
|
|
|
|
|
CommandOptionId opt_compress_routing = cmd.option("compress_routing");
|
2020-02-13 16:27:16 -06:00
|
|
|
CommandOptionId opt_duplicate_grid_pin = cmd.option("duplicate_grid_pin");
|
2020-06-12 11:41:34 -05:00
|
|
|
CommandOptionId opt_write_fabric_key = cmd.option("write_fabric_key");
|
2020-02-12 16:49:47 -06:00
|
|
|
CommandOptionId opt_verbose = cmd.option("verbose");
|
|
|
|
|
|
|
|
if (true == cmd_context.option_enable(cmd, opt_compress_routing)) {
|
2020-02-26 20:58:18 -06:00
|
|
|
compress_routing_hierarchy(openfpga_ctx, cmd_context.option_enable(cmd, opt_verbose));
|
2020-03-22 16:26:15 -05:00
|
|
|
/* Update flow manager to enable compress routing */
|
|
|
|
openfpga_ctx.mutable_flow_manager().set_compress_routing(true);
|
2020-02-12 16:49:47 -06:00
|
|
|
}
|
2020-02-11 18:40:37 -06:00
|
|
|
|
2020-02-12 18:53:23 -06:00
|
|
|
VTR_LOG("\n");
|
|
|
|
|
2020-02-26 20:58:18 -06:00
|
|
|
openfpga_ctx.mutable_module_graph() = build_device_module_graph(openfpga_ctx.mutable_io_location_map(),
|
2020-05-25 23:15:16 -05:00
|
|
|
openfpga_ctx.mutable_decoder_lib(),
|
2020-02-26 20:58:18 -06:00
|
|
|
const_cast<const OpenfpgaContext&>(openfpga_ctx),
|
2020-05-25 23:15:16 -05:00
|
|
|
g_vpr_ctx.device(),
|
2020-02-26 20:58:18 -06:00
|
|
|
cmd_context.option_enable(cmd, opt_compress_routing),
|
|
|
|
cmd_context.option_enable(cmd, opt_duplicate_grid_pin),
|
|
|
|
cmd_context.option_enable(cmd, opt_verbose));
|
2020-04-08 17:18:05 -05:00
|
|
|
|
2020-06-12 11:41:34 -05:00
|
|
|
/* Output fabric key if user requested */
|
|
|
|
if (true == cmd_context.option_enable(cmd, opt_write_fabric_key)) {
|
|
|
|
std::string fkey_fname = cmd_context.option_value(cmd, opt_write_fabric_key);
|
|
|
|
VTR_ASSERT(false == fkey_fname.empty());
|
|
|
|
write_fabric_key_to_xml_file(openfpga_ctx.module_graph(),
|
|
|
|
fkey_fname,
|
|
|
|
cmd_context.option_enable(cmd, opt_verbose));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-04-08 17:18:05 -05:00
|
|
|
/* TODO: should identify the error code from internal function execution */
|
|
|
|
return CMD_EXEC_SUCCESS;
|
2020-02-11 18:40:37 -06:00
|
|
|
}
|
|
|
|
|
2020-05-05 15:36:27 -05:00
|
|
|
/********************************************************************
|
|
|
|
* Build the module graph for FPGA device
|
|
|
|
*******************************************************************/
|
|
|
|
int write_fabric_hierarchy(const OpenfpgaContext& openfpga_ctx,
|
|
|
|
const Command& cmd, const CommandContext& cmd_context) {
|
|
|
|
|
|
|
|
CommandOptionId opt_verbose = cmd.option("verbose");
|
|
|
|
|
|
|
|
/* Check the option '--file' is enabled or not
|
|
|
|
* Actually, it must be enabled as the shell interface will check
|
|
|
|
* before reaching this fuction
|
|
|
|
*/
|
|
|
|
CommandOptionId opt_file = cmd.option("file");
|
|
|
|
VTR_ASSERT(true == cmd_context.option_enable(cmd, opt_file));
|
|
|
|
VTR_ASSERT(false == cmd_context.option_value(cmd, opt_file).empty());
|
|
|
|
|
2020-05-05 17:40:41 -05:00
|
|
|
/* Default depth requirement, will not stop until the leaf */
|
|
|
|
int depth = -1;
|
|
|
|
CommandOptionId opt_depth = cmd.option("depth");
|
|
|
|
if (true == cmd_context.option_enable(cmd, opt_depth)) {
|
|
|
|
depth = std::atoi(cmd_context.option_value(cmd, opt_depth).c_str());
|
|
|
|
/* Error out if we have negative depth */
|
|
|
|
if (0 > depth) {
|
|
|
|
VTR_LOG_ERROR("Invalid depth '%d' which should be 0 or a positive number!\n",
|
|
|
|
depth);
|
|
|
|
return CMD_EXEC_FATAL_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-05 15:36:27 -05:00
|
|
|
std::string hie_file_name = cmd_context.option_value(cmd, opt_file);
|
|
|
|
|
|
|
|
/* Write hierarchy to a file */
|
|
|
|
return write_fabric_hierarchy_to_text_file(openfpga_ctx.module_graph(),
|
|
|
|
hie_file_name,
|
2020-05-05 17:40:41 -05:00
|
|
|
size_t(depth),
|
2020-05-05 15:36:27 -05:00
|
|
|
cmd_context.option_enable(cmd, opt_verbose));
|
|
|
|
}
|
|
|
|
|
2020-02-11 18:40:37 -06:00
|
|
|
} /* end namespace openfpga */
|