2020-02-28 12:14:50 -06:00
/********************************************************************
* Add commands to the OpenFPGA shell interface ,
* in purpose of generate SDC files
* - write_pnr_sdc : generate SDC to constrain the back - end flow for FPGA fabric
* - write_analysis_sdc : TODO : generate SDC based on users ' implementations
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# include "openfpga_sdc.h"
# include "openfpga_sdc_command.h"
/* begin namespace openfpga */
namespace openfpga {
/********************************************************************
* - Add a command to Shell environment : generate PnR SDC
* - Add associated options
* - Add command dependency
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static
2020-03-02 11:39:19 -06:00
ShellCommandId add_openfpga_write_pnr_sdc_command ( openfpga : : Shell < OpenfpgaContext > & shell ,
const ShellCommandClassId & cmd_class_id ,
const std : : vector < ShellCommandId > & dependent_cmds ) {
2020-02-28 12:14:50 -06:00
Command shell_cmd ( " write_pnr_sdc " ) ;
/* Add an option '--file' in short '-f'*/
CommandOptionId output_opt = shell_cmd . add_option ( " file " , true , " Specify the output directory for SDC files " ) ;
shell_cmd . set_option_short_name ( output_opt , " f " ) ;
shell_cmd . set_option_require_value ( output_opt , openfpga : : OPT_STRING ) ;
2020-05-02 15:17:07 -05:00
/* Add an option '--flatten_name' */
2020-05-02 16:52:17 -05:00
shell_cmd . add_option ( " flatten_names " , false , " Use flatten names (no wildcards) in SDC files " ) ;
2020-05-02 15:17:07 -05:00
2020-05-02 19:31:37 -05:00
/* Add an option '--hierarchical' */
shell_cmd . add_option ( " hierarchical " , false , " Output SDC files hierachically (without full path in hierarchy) " ) ;
2020-05-05 16:35:41 -05:00
/* Add an option '--output_hierarchy' */
shell_cmd . add_option ( " output_hierarchy " , false , " Output hierachy of Multiple-Instance-Blocks (MIBs) to plain text file. This is applied to constrain timing for grid, SBs and CBs " ) ;
2020-05-05 13:31:11 -05:00
/* Add an option '--time_unit' */
2020-05-05 17:14:08 -05:00
CommandOptionId time_unit_opt = shell_cmd . add_option ( " time_unit " , false , " Specify the time unit in SDC files. Acceptable is [a|f|p|n|u|m|k|M]s " ) ;
2020-05-05 13:31:11 -05:00
shell_cmd . set_option_require_value ( time_unit_opt , openfpga : : OPT_STRING ) ;
2020-02-28 12:14:50 -06:00
/* Add an option '--constrain_global_port' */
shell_cmd . add_option ( " constrain_global_port " , false , " Constrain all the global ports of FPGA fabric " ) ;
2020-03-25 15:38:13 -05:00
/* Add an option '--constrain_non_clock_global_port' */
shell_cmd . add_option ( " constrain_non_clock_global_port " , false , " Constrain all the non-clock global ports as clock ports of FPGA fabric " ) ;
2020-02-28 12:14:50 -06:00
/* Add an option '--constrain_grid' */
shell_cmd . add_option ( " constrain_grid " , false , " Constrain all the grids of FPGA fabric " ) ;
/* Add an option '--constrain_sb' */
shell_cmd . add_option ( " constrain_sb " , false , " Constrain all the switch blocks of FPGA fabric " ) ;
/* Add an option '--constrain_cb' */
shell_cmd . add_option ( " constrain_cb " , false , " Constrain all the connection blocks of FPGA fabric " ) ;
/* Add an option '--constrain_configurable_memory_outputs' */
shell_cmd . add_option ( " constrain_configurable_memory_outputs " , false , " Constrain all the outputs of configurable memories of FPGA fabric " ) ;
/* Add an option '--constrain_routing_multiplexer_outputs' */
shell_cmd . add_option ( " constrain_routing_multiplexer_outputs " , false , " Constrain all the outputs of routing multiplexer of FPGA fabric " ) ;
/* Add an option '--constrain_switch_block_outputs' */
shell_cmd . add_option ( " constrain_switch_block_outputs " , false , " Constrain all the outputs of switch blocks of FPGA fabric " ) ;
2020-03-25 16:55:30 -05:00
/* Add an option '--constrain_zero_delay_paths' */
shell_cmd . add_option ( " constrain_zero_delay_paths " , false , " Constrain zero-delay paths in FPGA fabric " ) ;
2022-01-25 17:51:28 -06:00
/* Add an option '--no_time_stamp' */
shell_cmd . add_option ( " no_time_stamp " , false , " Do not print time stamp in output files " ) ;
2020-02-28 12:14:50 -06:00
/* Add an option '--verbose' */
shell_cmd . add_option ( " verbose " , false , " Enable verbose output " ) ;
/* Add command 'write_fabric_verilog' to the Shell */
ShellCommandId shell_cmd_id = shell . add_command ( shell_cmd , " generate SDC files to constrain the backend flow for FPGA fabric " ) ;
shell . set_command_class ( shell_cmd_id , cmd_class_id ) ;
2020-05-14 20:59:39 -05:00
shell . set_command_const_execute_function ( shell_cmd_id , write_pnr_sdc ) ;
2020-02-28 12:14:50 -06:00
2020-03-02 11:39:19 -06:00
/* Add command dependency to the Shell */
shell . set_command_dependency ( shell_cmd_id , dependent_cmds ) ;
return shell_cmd_id ;
2020-02-28 12:14:50 -06:00
}
2020-05-12 21:44:53 -05:00
/********************************************************************
* - Add a command to Shell environment : generate PnR SDC for configuration chain
* - Add associated options
* - Add command dependency
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static
ShellCommandId add_openfpga_write_configuration_chain_sdc_command ( openfpga : : Shell < OpenfpgaContext > & shell ,
const ShellCommandClassId & cmd_class_id ,
const std : : vector < ShellCommandId > & dependent_cmds ) {
Command shell_cmd ( " write_configuration_chain_sdc " ) ;
/* Add an option '--file' in short '-f'*/
CommandOptionId output_opt = shell_cmd . add_option ( " file " , true , " Specify the SDC file to constrain configuration chain " ) ;
shell_cmd . set_option_short_name ( output_opt , " f " ) ;
shell_cmd . set_option_require_value ( output_opt , openfpga : : OPT_STRING ) ;
/* Add an option '--time_unit' */
CommandOptionId time_unit_opt = shell_cmd . add_option ( " time_unit " , false , " Specify the time unit in SDC files. Acceptable is [a|f|p|n|u|m|k|M]s " ) ;
shell_cmd . set_option_require_value ( time_unit_opt , openfpga : : OPT_STRING ) ;
/* Add an option '--min_delay' */
CommandOptionId min_dly_opt = shell_cmd . add_option ( " min_delay " , false , " Specify the minimum delay to be used. " ) ;
shell_cmd . set_option_require_value ( min_dly_opt , openfpga : : OPT_STRING ) ;
/* Add an option '--max_delay' */
CommandOptionId max_dly_opt = shell_cmd . add_option ( " max_delay " , false , " Specify the maximum delay to be used. " ) ;
shell_cmd . set_option_require_value ( max_dly_opt , openfpga : : OPT_STRING ) ;
2022-01-25 17:51:28 -06:00
/* Add an option '--no_time_stamp' */
shell_cmd . add_option ( " no_time_stamp " , false , " Do not print time stamp in output files " ) ;
2020-05-12 21:44:53 -05:00
/* Add command 'write_configuration_chain_sdc' to the Shell */
ShellCommandId shell_cmd_id = shell . add_command ( shell_cmd , " generate SDC files to constrain the configuration chain for FPGA fabric " ) ;
shell . set_command_class ( shell_cmd_id , cmd_class_id ) ;
shell . set_command_const_execute_function ( shell_cmd_id , write_configuration_chain_sdc ) ;
/* Add command dependency to the Shell */
shell . set_command_dependency ( shell_cmd_id , dependent_cmds ) ;
return shell_cmd_id ;
}
2020-05-14 17:53:15 -05:00
/********************************************************************
* - Add a command to Shell environment : generate PnR SDC for configure ports
* - Add associated options
* - Add command dependency
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static
ShellCommandId add_openfpga_write_sdc_disable_timing_configure_ports_command ( openfpga : : Shell < OpenfpgaContext > & shell ,
const ShellCommandClassId & cmd_class_id ,
const std : : vector < ShellCommandId > & dependent_cmds ) {
Command shell_cmd ( " write_sdc_disable_timing_configure_ports " ) ;
/* Add an option '--file' in short '-f'*/
CommandOptionId output_opt = shell_cmd . add_option ( " file " , true , " Specify the output directory " ) ;
shell_cmd . set_option_short_name ( output_opt , " f " ) ;
shell_cmd . set_option_require_value ( output_opt , openfpga : : OPT_STRING ) ;
/* Add an option '--flatten_name' */
shell_cmd . add_option ( " flatten_names " , false , " Use flatten names (no wildcards) in SDC files " ) ;
2022-01-25 17:51:28 -06:00
/* Add an option '--no_time_stamp' */
shell_cmd . add_option ( " no_time_stamp " , false , " Do not print time stamp in output files " ) ;
2020-05-17 20:36:57 -05:00
/* Add an option '--verbose' */
shell_cmd . add_option ( " verbose " , false , " Enable verbose outputs " ) ;
2020-05-14 17:53:15 -05:00
/* Add command 'write_configuration_chain_sdc' to the Shell */
ShellCommandId shell_cmd_id = shell . add_command ( shell_cmd , " generate SDC files to disable timing for configure ports across FPGA fabric " ) ;
shell . set_command_class ( shell_cmd_id , cmd_class_id ) ;
shell . set_command_const_execute_function ( shell_cmd_id , write_sdc_disable_timing_configure_ports ) ;
/* Add command dependency to the Shell */
shell . set_command_dependency ( shell_cmd_id , dependent_cmds ) ;
return shell_cmd_id ;
}
2020-03-02 20:54:18 -06:00
/********************************************************************
* - Add a command to Shell environment : generate PnR SDC
* - Add associated options
* - Add command dependency
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static
ShellCommandId add_openfpga_write_analysis_sdc_command ( openfpga : : Shell < OpenfpgaContext > & shell ,
const ShellCommandClassId & cmd_class_id ,
const std : : vector < ShellCommandId > & dependent_cmds ) {
Command shell_cmd ( " write_analysis_sdc " ) ;
/* Add an option '--file' in short '-f'*/
CommandOptionId output_opt = shell_cmd . add_option ( " file " , true , " Specify the output directory for SDC files " ) ;
shell_cmd . set_option_short_name ( output_opt , " f " ) ;
shell_cmd . set_option_require_value ( output_opt , openfpga : : OPT_STRING ) ;
/* Add an option '--verbose' */
shell_cmd . add_option ( " verbose " , false , " Enable verbose output " ) ;
2020-05-02 15:17:07 -05:00
/* Add an option '--flatten_name' */
2020-05-02 16:52:17 -05:00
shell_cmd . add_option ( " flatten_names " , false , " Use flatten names (no wildcards) in SDC files " ) ;
2020-05-02 19:31:37 -05:00
2020-05-05 13:31:11 -05:00
/* Add an option '--time_unit' */
CommandOptionId time_unit_opt = shell_cmd . add_option ( " time_unit " , false , " Specify the time unit in SDC files. Acceptable is [a|f|p|n|u|m|kM]s " ) ;
shell_cmd . set_option_require_value ( time_unit_opt , openfpga : : OPT_STRING ) ;
2022-01-25 17:51:28 -06:00
/* Add an option '--no_time_stamp' */
shell_cmd . add_option ( " no_time_stamp " , false , " Do not print time stamp in output files " ) ;
2020-03-02 20:54:18 -06:00
/* Add command 'write_fabric_verilog' to the Shell */
ShellCommandId shell_cmd_id = shell . add_command ( shell_cmd , " generate SDC files for timing analysis a PnRed FPGA fabric mapped by a benchmark " ) ;
shell . set_command_class ( shell_cmd_id , cmd_class_id ) ;
2020-05-14 20:59:39 -05:00
shell . set_command_const_execute_function ( shell_cmd_id , write_analysis_sdc ) ;
2020-03-02 20:54:18 -06:00
/* Add command dependency to the Shell */
shell . set_command_dependency ( shell_cmd_id , dependent_cmds ) ;
return shell_cmd_id ;
}
2020-02-28 12:14:50 -06:00
void add_openfpga_sdc_commands ( openfpga : : Shell < OpenfpgaContext > & shell ) {
/* Get the unique id of 'build_fabric' command which is to be used in creating the dependency graph */
2020-03-02 11:39:19 -06:00
const ShellCommandId & build_fabric_id = shell . command ( std : : string ( " build_fabric " ) ) ;
2020-02-28 12:14:50 -06:00
/* Add a new class of commands */
ShellCommandClassId openfpga_sdc_cmd_class = shell . add_command_class ( " FPGA-SDC " ) ;
/********************************
2020-03-02 11:39:19 -06:00
* Command ' write_pnr_sdc '
2020-02-28 12:14:50 -06:00
*/
2020-03-02 11:39:19 -06:00
/* The 'write_pnr_sdc' command should NOT be executed before 'build_fabric' */
std : : vector < ShellCommandId > pnr_sdc_cmd_dependency ;
pnr_sdc_cmd_dependency . push_back ( build_fabric_id ) ;
2020-02-28 12:14:50 -06:00
add_openfpga_write_pnr_sdc_command ( shell ,
openfpga_sdc_cmd_class ,
2020-03-02 11:39:19 -06:00
pnr_sdc_cmd_dependency ) ;
2020-03-02 20:54:18 -06:00
2020-05-12 21:44:53 -05:00
/********************************
* Command ' write_configuration_chain_sdc '
*/
/* The 'write_configuration_chain_sdc' command should NOT be executed before 'build_fabric' */
std : : vector < ShellCommandId > cc_sdc_cmd_dependency ;
cc_sdc_cmd_dependency . push_back ( build_fabric_id ) ;
add_openfpga_write_configuration_chain_sdc_command ( shell ,
openfpga_sdc_cmd_class ,
cc_sdc_cmd_dependency ) ;
2020-05-14 17:53:15 -05:00
/********************************
* Command ' write_sdc_disable_timing_configure_ports '
*/
/* The 'write_sdc_disable_timing_configure_ports' command should NOT be executed before 'build_fabric' */
std : : vector < ShellCommandId > config_port_sdc_cmd_dependency ;
config_port_sdc_cmd_dependency . push_back ( build_fabric_id ) ;
add_openfpga_write_sdc_disable_timing_configure_ports_command ( shell ,
openfpga_sdc_cmd_class ,
config_port_sdc_cmd_dependency ) ;
2020-03-02 20:54:18 -06:00
/********************************
* Command ' write_analysis_sdc '
*/
/* The 'write_analysis_sdc' command should NOT be executed before 'build_fabric' */
std : : vector < ShellCommandId > analysis_sdc_cmd_dependency ;
analysis_sdc_cmd_dependency . push_back ( build_fabric_id ) ;
add_openfpga_write_analysis_sdc_command ( shell ,
openfpga_sdc_cmd_class ,
analysis_sdc_cmd_dependency ) ;
2020-02-28 12:14:50 -06:00
}
} /* end namespace openfpga */