OpenFPGA/openfpga/src/base/openfpga_bitstream.cpp

95 lines
3.9 KiB
C++
Raw Normal View History

/********************************************************************
* This file includes functions to build bitstream database
*******************************************************************/
/* Headers from vtrutil library */
#include "vtr_time.h"
#include "vtr_log.h"
/* Headers from openfpgashell library */
#include "command_exit_codes.h"
/* Headers from openfpgautil library */
#include "openfpga_digest.h"
#include "openfpga_reserved_words.h"
/* Headers from fpgabitstream library */
#include "read_xml_arch_bitstream.h"
2020-04-21 13:02:10 -05:00
#include "arch_bitstream_writer.h"
#include "build_device_bitstream.h"
2020-04-21 13:02:10 -05:00
#include "fabric_bitstream_writer.h"
2020-02-26 12:09:23 -06:00
#include "build_fabric_bitstream.h"
#include "openfpga_bitstream.h"
/* Include global variables of VPR */
#include "globals.h"
/* begin namespace openfpga */
namespace openfpga {
/********************************************************************
2020-02-26 12:09:23 -06:00
* A wrapper function to call the build_device_bitstream() in FPGA bitstream
*******************************************************************/
int fpga_bitstream(OpenfpgaContext& openfpga_ctx,
const Command& cmd, const CommandContext& cmd_context) {
CommandOptionId opt_verbose = cmd.option("verbose");
CommandOptionId opt_write_file = cmd.option("write_file");
CommandOptionId opt_read_file = cmd.option("read_file");
if (true == cmd_context.option_enable(cmd, opt_read_file)) {
openfpga_ctx.mutable_bitstream_manager() = read_xml_architecture_bitstream(cmd_context.option_value(cmd, opt_write_file).c_str());
} else {
openfpga_ctx.mutable_bitstream_manager() = build_device_bitstream(g_vpr_ctx,
openfpga_ctx,
cmd_context.option_enable(cmd, opt_verbose));
}
2020-02-26 12:09:23 -06:00
if (true == cmd_context.option_enable(cmd, opt_write_file)) {
std::string src_dir_path = find_path_dir_name(cmd_context.option_value(cmd, opt_write_file));
/* Create directories */
create_directory(src_dir_path);
2020-02-26 12:09:23 -06:00
write_arch_independent_bitstream_to_xml_file(openfpga_ctx.bitstream_manager(),
std::string(FPGA_TOP_MODULE_NAME),
cmd_context.option_value(cmd, opt_write_file));
2020-02-26 12:09:23 -06:00
}
/* TODO: should identify the error code from internal function execution */
return CMD_EXEC_SUCCESS;
2020-02-26 12:09:23 -06:00
}
/********************************************************************
* A wrapper function to call the build_fabric_bitstream() in FPGA bitstream
*******************************************************************/
int build_fabric_bitstream(OpenfpgaContext& openfpga_ctx,
const Command& cmd, const CommandContext& cmd_context) {
2020-02-26 12:09:23 -06:00
CommandOptionId opt_verbose = cmd.option("verbose");
2020-04-21 13:02:10 -05:00
CommandOptionId opt_file = cmd.option("file");
2020-02-26 12:09:23 -06:00
2020-04-21 13:02:10 -05:00
/* Build fabric bitstream here */
2020-02-26 12:09:23 -06:00
openfpga_ctx.mutable_fabric_bitstream() = build_fabric_dependent_bitstream(openfpga_ctx.bitstream_manager(),
openfpga_ctx.module_graph(),
openfpga_ctx.arch().config_protocol,
2020-02-26 12:09:23 -06:00
cmd_context.option_enable(cmd, opt_verbose));
2020-04-21 13:02:10 -05:00
/* Write fabric bitstream if required */
if (true == cmd_context.option_enable(cmd, opt_file)) {
std::string src_dir_path = find_path_dir_name(cmd_context.option_value(cmd, opt_file));
/* Create directories */
create_directory(src_dir_path);
write_fabric_bitstream_to_text_file(openfpga_ctx.bitstream_manager(),
openfpga_ctx.fabric_bitstream(),
cmd_context.option_value(cmd, opt_file));
}
/* TODO: should identify the error code from internal function execution */
return CMD_EXEC_SUCCESS;
}
} /* end namespace openfpga */