2022-11-23 18:52:22 -06:00
|
|
|
#include "openfpga_shell.h"
|
2022-11-24 23:04:04 -06:00
|
|
|
|
2022-11-23 18:52:22 -06:00
|
|
|
#include "basic_command.h"
|
2022-11-24 23:04:04 -06:00
|
|
|
#include "command_echo.h"
|
|
|
|
#include "command_parser.h"
|
2022-11-23 18:52:22 -06:00
|
|
|
#include "openfpga_bitstream_command.h"
|
|
|
|
#include "openfpga_context.h"
|
|
|
|
#include "openfpga_sdc_command.h"
|
|
|
|
#include "openfpga_setup_command.h"
|
|
|
|
#include "openfpga_spice_command.h"
|
|
|
|
#include "openfpga_title.h"
|
|
|
|
#include "openfpga_verilog_command.h"
|
|
|
|
#include "vpr_command.h"
|
|
|
|
|
|
|
|
OpenfpgaShell::OpenfpgaShell() {
|
2022-11-24 23:04:04 -06:00
|
|
|
shell_.set_name("OpenFPGA");
|
2022-11-23 18:52:22 -06:00
|
|
|
shell_.add_title(create_openfpga_title().c_str());
|
|
|
|
|
|
|
|
/* Add vpr commands */
|
|
|
|
openfpga::add_vpr_commands(shell_);
|
|
|
|
|
|
|
|
/* Add openfpga setup commands */
|
|
|
|
openfpga::add_openfpga_setup_commands(shell_);
|
|
|
|
|
|
|
|
/* Add openfpga verilog commands */
|
|
|
|
openfpga::add_openfpga_verilog_commands(shell_);
|
|
|
|
|
|
|
|
/* Add openfpga bitstream commands */
|
|
|
|
openfpga::add_openfpga_bitstream_commands(shell_);
|
|
|
|
|
|
|
|
/* Add openfpga SPICE commands */
|
|
|
|
openfpga::add_openfpga_spice_commands(shell_);
|
|
|
|
|
|
|
|
/* Add openfpga sdc commands */
|
|
|
|
openfpga::add_openfpga_sdc_commands(shell_);
|
|
|
|
|
|
|
|
/* Add basic commands: exit, help, etc.
|
|
|
|
* Note:
|
|
|
|
* This MUST be the last command group to be added!
|
|
|
|
*/
|
|
|
|
openfpga::add_basic_commands(shell_);
|
|
|
|
}
|
|
|
|
|
|
|
|
int OpenfpgaShell::run_command(const char* cmd_line) {
|
|
|
|
return shell_.execute_command(cmd_line, openfpga_ctx_);
|
|
|
|
}
|
|
|
|
|
|
|
|
void OpenfpgaShell::reset() {
|
|
|
|
/* TODO: reset the shell status */
|
|
|
|
/* TODO: reset the data storage */
|
|
|
|
}
|
|
|
|
|
|
|
|
int OpenfpgaShell::start(int argc, char** argv) {
|
|
|
|
reset();
|
|
|
|
|
|
|
|
/* Create the command to launch shell in different modes */
|
|
|
|
openfpga::Command start_cmd("OpenFPGA");
|
|
|
|
/* Add options to openfpga shell interface */
|
|
|
|
/* '--interactive', -i': launch the interactive mode */
|
|
|
|
openfpga::CommandOptionId opt_interactive = start_cmd.add_option(
|
|
|
|
"interactive", false, "Launch OpenFPGA in interactive mode");
|
|
|
|
start_cmd.set_option_short_name(opt_interactive, "i");
|
|
|
|
|
|
|
|
/* '--file', -f': launch the script mode */
|
|
|
|
openfpga::CommandOptionId opt_script_mode =
|
|
|
|
start_cmd.add_option("file", false, "Launch OpenFPGA in script mode");
|
|
|
|
start_cmd.set_option_require_value(opt_script_mode, openfpga::OPT_STRING);
|
|
|
|
start_cmd.set_option_short_name(opt_script_mode, "f");
|
|
|
|
|
|
|
|
/* '--batch_execution': execute the script in batch mode.
|
|
|
|
* Will exit immediately when fatal errors occurred
|
|
|
|
*/
|
|
|
|
openfpga::CommandOptionId opt_batch_exec =
|
|
|
|
start_cmd.add_option("batch_execution", false,
|
|
|
|
"Launch OpenFPGA in batch mode when running scripts");
|
|
|
|
start_cmd.set_option_short_name(opt_batch_exec, "batch");
|
|
|
|
|
|
|
|
/* '--version', -v': print version information */
|
|
|
|
openfpga::CommandOptionId opt_version =
|
|
|
|
start_cmd.add_option("version", false, "Show OpenFPGA version");
|
|
|
|
start_cmd.set_option_short_name(opt_version, "v");
|
|
|
|
|
|
|
|
/* '--help', -h': print help desk */
|
|
|
|
openfpga::CommandOptionId opt_help =
|
|
|
|
start_cmd.add_option("help", false, "Help desk");
|
|
|
|
start_cmd.set_option_short_name(opt_help, "h");
|
|
|
|
|
|
|
|
/* 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]));
|
|
|
|
}
|
|
|
|
|
|
|
|
openfpga::CommandContext start_cmd_context(start_cmd);
|
|
|
|
if (false == parse_command(cmd_opts, start_cmd, start_cmd_context)) {
|
|
|
|
/* Parse fail: Echo the command */
|
|
|
|
openfpga::print_command_options(start_cmd);
|
|
|
|
} else {
|
|
|
|
/* Parse succeed. Branch on options */
|
|
|
|
/* Show version */
|
|
|
|
if (true == start_cmd_context.option_enable(start_cmd, opt_version)) {
|
|
|
|
print_openfpga_version_info();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
/* Start a shell */
|
|
|
|
if (true == start_cmd_context.option_enable(start_cmd, opt_interactive)) {
|
2022-11-23 19:06:27 -06:00
|
|
|
shell_.run_interactive_mode(openfpga_ctx_);
|
2022-11-23 18:52:22 -06:00
|
|
|
return shell_.exit_code();
|
|
|
|
}
|
|
|
|
|
|
|
|
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(),
|
2022-11-23 19:06:27 -06:00
|
|
|
openfpga_ctx_,
|
2022-11-23 18:52:22 -06:00
|
|
|
start_cmd_context.option_enable(start_cmd, opt_batch_exec));
|
|
|
|
return shell_.exit_code();
|
|
|
|
}
|
|
|
|
/* Reach here there is something wrong, show the help desk */
|
|
|
|
openfpga::print_command_options(start_cmd);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Reach here, it means shell execution has critical errors.
|
|
|
|
* Return a code with fatal errors
|
|
|
|
*/
|
|
|
|
return 1;
|
|
|
|
}
|