2020-01-23 20:10:53 -06:00
/********************************************************************
* Add commands to the OpenFPGA shell interface ,
* in purpose of setting up OpenFPGA core engine , including :
* - read_openfpga_arch : read OpenFPGA architecture file
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# include "openfpga_read_arch.h"
2020-01-27 16:31:12 -06:00
# include "openfpga_link_arch.h"
2020-02-05 22:50:52 -06:00
# include "openfpga_pb_pin_fixup.h"
2020-02-06 18:14:29 -06:00
# include "openfpga_lut_truth_table_fixup.h"
2020-01-29 17:23:41 -06:00
# include "check_netlist_naming_conflict.h"
2020-02-12 16:49:47 -06:00
# include "openfpga_build_fabric.h"
2020-01-23 20:10:53 -06:00
# include "openfpga_setup_command.h"
/* begin namespace openfpga */
namespace openfpga {
void add_openfpga_setup_commands ( openfpga : : Shell < OpenfpgaContext > & shell ) {
2020-01-29 17:23:41 -06:00
/* Get the unique id of 'vpr' command which is to be used in creating the dependency graph */
const ShellCommandId & shell_cmd_vpr_id = shell . command ( std : : string ( " vpr " ) ) ;
2020-01-23 20:10:53 -06:00
/* Add a new class of commands */
ShellCommandClassId openfpga_setup_cmd_class = shell . add_command_class ( " OpenFPGA setup " ) ;
2020-01-29 17:23:41 -06:00
/********************************
* Command ' read_openfpga_arch '
*/
2020-01-23 20:10:53 -06:00
Command shell_cmd_read_arch ( " read_openfpga_arch " ) ;
/* Add an option '--file' in short '-f'*/
CommandOptionId read_arch_opt_file = shell_cmd_read_arch . add_option ( " file " , true , " file path to the architecture XML " ) ;
shell_cmd_read_arch . set_option_short_name ( read_arch_opt_file , " f " ) ;
shell_cmd_read_arch . set_option_require_value ( read_arch_opt_file , openfpga : : OPT_STRING ) ;
2020-01-23 21:58:15 -06:00
/* Add command 'read_openfpga_arch' to the Shell */
2020-01-23 20:10:53 -06:00
ShellCommandId shell_cmd_read_arch_id = shell . add_command ( shell_cmd_read_arch , " read OpenFPGA architecture file " ) ;
shell . set_command_class ( shell_cmd_read_arch_id , openfpga_setup_cmd_class ) ;
shell . set_command_execute_function ( shell_cmd_read_arch_id , read_arch ) ;
2020-01-23 21:58:15 -06:00
2020-01-29 17:23:41 -06:00
/********************************
* Command ' write_openfpga_arch '
*/
2020-01-23 21:58:15 -06:00
Command shell_cmd_write_arch ( " write_openfpga_arch " ) ;
/* Add an option '--file' in short '-f'*/
CommandOptionId write_arch_opt_file = shell_cmd_write_arch . add_option ( " file " , true , " file path to the architecture XML " ) ;
shell_cmd_write_arch . set_option_short_name ( write_arch_opt_file , " f " ) ;
shell_cmd_write_arch . set_option_require_value ( write_arch_opt_file , openfpga : : OPT_STRING ) ;
/* Add command 'write_openfpga_arch' to the Shell */
ShellCommandId shell_cmd_write_arch_id = shell . add_command ( shell_cmd_write_arch , " write OpenFPGA architecture file " ) ;
shell . set_command_class ( shell_cmd_write_arch_id , openfpga_setup_cmd_class ) ;
shell . set_command_const_execute_function ( shell_cmd_write_arch_id , write_arch ) ;
2020-01-27 16:31:12 -06:00
/* The 'write_openfpga_arch' command should NOT be executed before 'read_openfpga_arch' */
2020-01-24 17:57:14 -06:00
shell . set_command_dependency ( shell_cmd_write_arch_id , std : : vector < ShellCommandId > ( 1 , shell_cmd_read_arch_id ) ) ;
2020-01-27 16:31:12 -06:00
2020-01-29 17:23:41 -06:00
/********************************
* Command ' link_openfpga_arch '
*/
2020-01-27 16:31:12 -06:00
Command shell_cmd_link_openfpga_arch ( " link_openfpga_arch " ) ;
2020-01-31 12:36:58 -06:00
/* Add an option '--verbose' */
shell_cmd_link_openfpga_arch . add_option ( " verbose " , false , " Show verbose outputs " ) ;
2020-01-27 16:31:12 -06:00
/* Add command 'link_openfpga_arch' to the Shell */
ShellCommandId shell_cmd_link_openfpga_arch_id = shell . add_command ( shell_cmd_link_openfpga_arch , " Bind OpenFPGA architecture to VPR " ) ;
shell . set_command_class ( shell_cmd_link_openfpga_arch_id , openfpga_setup_cmd_class ) ;
shell . set_command_execute_function ( shell_cmd_link_openfpga_arch_id , link_arch ) ;
/* The 'link_openfpga_arch' command should NOT be executed before 'read_openfpga_arch' and 'vpr' */
std : : vector < ShellCommandId > cmd_dependency_link_openfpga_arch ;
cmd_dependency_link_openfpga_arch . push_back ( shell_cmd_read_arch_id ) ;
cmd_dependency_link_openfpga_arch . push_back ( shell_cmd_vpr_id ) ;
shell . set_command_dependency ( shell_cmd_link_openfpga_arch_id , cmd_dependency_link_openfpga_arch ) ;
2020-01-29 17:23:41 -06:00
/*******************************************
* Command ' check_netlist_naming_conflict '
*/
Command shell_cmd_check_netlist_naming_conflict ( " check_netlist_naming_conflict " ) ;
2020-01-31 12:36:58 -06:00
/* Add an option '--fix' */
2020-01-29 18:49:33 -06:00
shell_cmd_check_netlist_naming_conflict . add_option ( " fix " , false , " Apply correction to any conflicts found " ) ;
2020-01-29 17:23:41 -06:00
/* Add an option '--report' */
CommandOptionId check_netlist_opt_rpt = shell_cmd_check_netlist_naming_conflict . add_option ( " report " , false , " Output a report file about what any correction applied " ) ;
shell_cmd_check_netlist_naming_conflict . set_option_require_value ( check_netlist_opt_rpt , openfpga : : OPT_STRING ) ;
/* Add command 'check_netlist_naming_conflict' to the Shell */
ShellCommandId shell_cmd_check_netlist_naming_conflict_id = shell . add_command ( shell_cmd_check_netlist_naming_conflict , " Check any block/net naming in users' BLIF netlist violates the syntax of fabric generator " ) ;
shell . set_command_class ( shell_cmd_check_netlist_naming_conflict_id , openfpga_setup_cmd_class ) ;
shell . set_command_execute_function ( shell_cmd_check_netlist_naming_conflict_id , check_netlist_naming_conflict ) ;
2020-02-05 22:50:52 -06:00
/* The 'link_openfpga_arch' command should NOT be executed before 'vpr' */
2020-01-29 17:23:41 -06:00
std : : vector < ShellCommandId > cmd_dependency_check_netlist_naming_conflict ( 1 , shell_cmd_vpr_id ) ;
shell . set_command_dependency ( shell_cmd_link_openfpga_arch_id , cmd_dependency_check_netlist_naming_conflict ) ;
2020-02-05 22:50:52 -06:00
/********************************
* Command ' pb_pin_fixup '
*/
Command shell_cmd_pb_pin_fixup ( " pb_pin_fixup " ) ;
/* Add an option '--verbose' */
shell_cmd_pb_pin_fixup . add_option ( " verbose " , false , " Show verbose outputs " ) ;
/* Add command 'pb_pin_fixup' to the Shell */
ShellCommandId shell_cmd_pb_pin_fixup_id = shell . add_command ( shell_cmd_pb_pin_fixup , " Fix up the packing results due to pin swapping during routing stage " ) ;
shell . set_command_class ( shell_cmd_pb_pin_fixup_id , openfpga_setup_cmd_class ) ;
shell . set_command_execute_function ( shell_cmd_pb_pin_fixup_id , pb_pin_fixup ) ;
/* The 'pb_pin_fixup' command should NOT be executed before 'read_openfpga_arch' and 'vpr' */
std : : vector < ShellCommandId > cmd_dependency_pb_pin_fixup ;
cmd_dependency_pb_pin_fixup . push_back ( shell_cmd_read_arch_id ) ;
cmd_dependency_pb_pin_fixup . push_back ( shell_cmd_vpr_id ) ;
shell . set_command_dependency ( shell_cmd_pb_pin_fixup_id , cmd_dependency_pb_pin_fixup ) ;
2020-02-06 18:14:29 -06:00
/********************************
* Command ' lut_truth_table_fixup '
*/
Command shell_cmd_lut_truth_table_fixup ( " lut_truth_table_fixup " ) ;
/* Add an option '--verbose' */
shell_cmd_lut_truth_table_fixup . add_option ( " verbose " , false , " Show verbose outputs " ) ;
/* Add command 'lut_truth_table_fixup' to the Shell */
ShellCommandId shell_cmd_lut_truth_table_fixup_id = shell . add_command ( shell_cmd_lut_truth_table_fixup , " Fix up the truth table of Look-Up Tables due to pin swapping during packing stage " ) ;
shell . set_command_class ( shell_cmd_lut_truth_table_fixup_id , openfpga_setup_cmd_class ) ;
shell . set_command_execute_function ( shell_cmd_lut_truth_table_fixup_id , lut_truth_table_fixup ) ;
2020-02-11 18:40:37 -06:00
/* The 'lut_truth_table_fixup' command should NOT be executed before 'read_openfpga_arch' and 'vpr' */
2020-02-06 18:14:29 -06:00
std : : vector < ShellCommandId > cmd_dependency_lut_truth_table_fixup ;
cmd_dependency_lut_truth_table_fixup . push_back ( shell_cmd_read_arch_id ) ;
cmd_dependency_lut_truth_table_fixup . push_back ( shell_cmd_vpr_id ) ;
shell . set_command_dependency ( shell_cmd_lut_truth_table_fixup_id , cmd_dependency_lut_truth_table_fixup ) ;
2020-02-11 18:40:37 -06:00
/********************************
2020-02-12 16:49:47 -06:00
* Command ' build_fabric '
2020-02-11 18:40:37 -06:00
*/
2020-02-12 16:49:47 -06:00
Command shell_cmd_build_fabric ( " build_fabric " ) ;
2020-02-11 18:40:37 -06:00
/* Add an option '--verbose' */
2020-02-12 16:49:47 -06:00
shell_cmd_build_fabric . add_option ( " compress_routing " , false , " Compress the number of unique routing modules by identifying the unique GSBs " ) ;
shell_cmd_build_fabric . add_option ( " duplicate_grid_pin " , false , " Duplicate the pins on the same side of a grid " ) ;
shell_cmd_build_fabric . add_option ( " verbose " , false , " Show verbose outputs " ) ;
2020-02-11 18:40:37 -06:00
/* Add command 'compact_routing_hierarchy' to the Shell */
2020-02-12 16:49:47 -06:00
ShellCommandId shell_cmd_build_fabric_id = shell . add_command ( shell_cmd_build_fabric , " Build the FPGA fabric in a graph of modules " ) ;
shell . set_command_class ( shell_cmd_build_fabric_id , openfpga_setup_cmd_class ) ;
shell . set_command_execute_function ( shell_cmd_build_fabric_id , build_fabric ) ;
/* The 'build_fabric' command should NOT be executed before 'link_openfpga_arch' */
std : : vector < ShellCommandId > cmd_dependency_build_fabric ;
2020-02-11 18:40:37 -06:00
cmd_dependency_lut_truth_table_fixup . push_back ( shell_cmd_link_openfpga_arch_id ) ;
2020-02-12 16:49:47 -06:00
shell . set_command_dependency ( shell_cmd_build_fabric_id , cmd_dependency_build_fabric ) ;
2020-01-23 20:10:53 -06:00
}
} /* end namespace openfpga */