2020-01-22 21:20:10 -06:00
|
|
|
/********************************************************************
|
|
|
|
* Build the OpenFPGA shell interface
|
|
|
|
*******************************************************************/
|
2020-01-23 14:24:35 -06:00
|
|
|
/* Header file from vtrutil library */
|
2020-01-22 21:20:10 -06:00
|
|
|
#include "vtr_log.h"
|
2020-01-23 14:24:35 -06:00
|
|
|
|
|
|
|
/* Header file from libopenfpgashell library */
|
2020-01-22 21:20:10 -06:00
|
|
|
#include "command_parser.h"
|
|
|
|
#include "command_echo.h"
|
|
|
|
#include "shell.h"
|
|
|
|
|
2020-01-23 14:24:35 -06:00
|
|
|
/* Header file from openfpga */
|
2020-01-22 21:20:10 -06:00
|
|
|
#include "vpr_main.h"
|
|
|
|
|
2020-01-23 14:24:35 -06:00
|
|
|
#include "openfpga_title.h"
|
|
|
|
#include "openfpga_context.h"
|
2020-01-22 21:20:10 -06:00
|
|
|
|
2020-01-23 14:24:35 -06:00
|
|
|
using namespace openfpga;
|
2020-01-22 21:20:10 -06:00
|
|
|
|
2020-01-23 14:24:35 -06:00
|
|
|
/********************************************************************
|
|
|
|
* Main function to start OpenFPGA shell interface
|
|
|
|
*******************************************************************/
|
2020-01-22 21:20:10 -06:00
|
|
|
int main(int argc, char** argv) {
|
2020-01-23 14:24:35 -06:00
|
|
|
|
2020-01-22 21:20:10 -06:00
|
|
|
/* Create the command to launch shell in different modes */
|
|
|
|
Command start_cmd("OpenFPGA");
|
|
|
|
/* Add two options:
|
|
|
|
* '--interactive', -i': launch the interactive mode
|
|
|
|
* '--file', -f': launch the script mode
|
|
|
|
*/
|
|
|
|
CommandOptionId opt_interactive = start_cmd.add_option("interactive", false, "Launch OpenFPGA in interactive mode");
|
|
|
|
start_cmd.set_option_short_name(opt_interactive, "i");
|
|
|
|
|
|
|
|
CommandOptionId opt_script_mode = start_cmd.add_option("file", false, "Launch OpenFPGA in script mode");
|
|
|
|
start_cmd.set_option_require_value(opt_script_mode, OPT_STRING);
|
|
|
|
start_cmd.set_option_short_name(opt_script_mode, "f");
|
|
|
|
|
|
|
|
CommandOptionId opt_help = start_cmd.add_option("help", false, "Help desk");
|
|
|
|
start_cmd.set_option_short_name(opt_help, "h");
|
|
|
|
|
|
|
|
/* Create a shell object
|
|
|
|
* Add two commands, which are
|
2020-01-23 14:24:35 -06:00
|
|
|
* 1. exit
|
|
|
|
* 2. help. This must the last to add
|
2020-01-22 21:20:10 -06:00
|
|
|
*/
|
2020-01-23 14:24:35 -06:00
|
|
|
Shell<OpenfpgaContext> shell("OpenFPGA");
|
2020-01-22 21:20:10 -06:00
|
|
|
|
2020-01-23 14:24:35 -06:00
|
|
|
shell.add_title(create_openfpga_title());
|
2020-01-22 21:20:10 -06:00
|
|
|
|
2020-01-23 14:24:35 -06:00
|
|
|
/* Add a new class of commands */
|
|
|
|
ShellCommandClassId arith_cmd_class = shell.add_command_class("VPR");
|
2020-01-22 21:20:10 -06:00
|
|
|
|
|
|
|
/* Create a macro command of 'vpr' which will call the main engine of vpr
|
|
|
|
*/
|
|
|
|
Command shell_cmd_vpr("vpr");
|
2020-01-23 14:24:35 -06:00
|
|
|
ShellCommandId shell_cmd_vpr_id = shell.add_command(shell_cmd_vpr, "Start VPR core engine to pack, place and route a BLIF design on a FPGA architecture");
|
2020-01-22 21:20:10 -06:00
|
|
|
shell.set_command_class(shell_cmd_vpr_id, arith_cmd_class);
|
|
|
|
shell.set_command_execute_function(shell_cmd_vpr_id, vpr::vpr);
|
|
|
|
|
|
|
|
/* Add a new class of commands */
|
|
|
|
ShellCommandClassId basic_cmd_class = shell.add_command_class("Basic");
|
|
|
|
|
|
|
|
Command shell_cmd_exit("exit");
|
|
|
|
ShellCommandId shell_cmd_exit_id = shell.add_command(shell_cmd_exit, "Exit the shell");
|
|
|
|
shell.set_command_class(shell_cmd_exit_id, basic_cmd_class);
|
|
|
|
shell.set_command_execute_function(shell_cmd_exit_id, [shell](){shell.exit();});
|
|
|
|
|
|
|
|
/* Note: help must be the last to add because the linking to execute function will do a snapshot on the shell */
|
|
|
|
Command shell_cmd_help("help");
|
|
|
|
ShellCommandId shell_cmd_help_id = shell.add_command(shell_cmd_help, "Launch help desk");
|
|
|
|
shell.set_command_class(shell_cmd_help_id, basic_cmd_class);
|
|
|
|
shell.set_command_execute_function(shell_cmd_help_id, [shell](){shell.print_commands();});
|
|
|
|
|
|
|
|
/* Create the data base for the shell */
|
2020-01-23 14:24:35 -06:00
|
|
|
OpenfpgaContext openfpga_context;
|
2020-01-22 21:20:10 -06:00
|
|
|
|
|
|
|
/* Parse the option, to avoid issues, we use the command name to replace the argv[0] */
|
|
|
|
std::vector<std::string> cmd_opts;
|
|
|
|
cmd_opts.push_back(start_cmd.name());
|
|
|
|
for (int iarg = 1; iarg < argc; ++iarg) {
|
|
|
|
cmd_opts.push_back(std::string(argv[iarg]));
|
|
|
|
}
|
|
|
|
|
|
|
|
CommandContext start_cmd_context(start_cmd);
|
|
|
|
if (false == parse_command(cmd_opts, start_cmd, start_cmd_context)) {
|
|
|
|
/* Parse fail: Echo the command */
|
|
|
|
print_command_options(start_cmd);
|
|
|
|
} else {
|
|
|
|
/* Parse succeed. Start a shell */
|
|
|
|
if (true == start_cmd_context.option_enable(start_cmd, opt_interactive)) {
|
2020-01-23 14:24:35 -06:00
|
|
|
shell.run_interactive_mode(openfpga_context);
|
2020-01-22 21:20:10 -06:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (true == start_cmd_context.option_enable(start_cmd, opt_script_mode)) {
|
|
|
|
shell.run_script_mode(start_cmd_context.option_value(start_cmd, opt_script_mode).c_str(),
|
2020-01-23 14:24:35 -06:00
|
|
|
openfpga_context);
|
2020-01-22 21:20:10 -06:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
/* Reach here there is something wrong, show the help desk */
|
|
|
|
print_command_options(start_cmd);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|