2021-02-01 18:43:46 -06:00
|
|
|
/********************************************************************
|
|
|
|
* This file includes functions that outputs a bitstream setting to XML format
|
|
|
|
*******************************************************************/
|
|
|
|
/* Headers from system goes first */
|
|
|
|
#include <string>
|
|
|
|
#include <algorithm>
|
|
|
|
|
|
|
|
/* Headers from vtr util library */
|
|
|
|
#include "vtr_assert.h"
|
|
|
|
#include "vtr_log.h"
|
|
|
|
#include "openfpga_digest.h"
|
|
|
|
|
|
|
|
/* Headers from readarchopenfpga library */
|
|
|
|
#include "write_xml_utils.h"
|
|
|
|
#include "write_xml_bitstream_setting.h"
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Generate the full hierarchy name for a pb_type in bitstream setting
|
|
|
|
*******************************************************************/
|
|
|
|
static
|
|
|
|
std::string generate_bitstream_setting_pb_type_hierarchy_name(const openfpga::BitstreamSetting& bitstream_setting,
|
|
|
|
const BitstreamPbTypeSettingId& bitstream_pb_type_setting_id) {
|
|
|
|
/* Iterate over the parent_pb_type and modes names, they should well match */
|
|
|
|
VTR_ASSERT_SAFE(bitstream_setting.parent_pb_type_names(bitstream_pb_type_setting_id).size() == bitstream_setting.parent_mode_names(bitstream_pb_type_setting_id).size());
|
|
|
|
|
|
|
|
std::string hie_name;
|
|
|
|
|
|
|
|
for (size_t i = 0 ; i < bitstream_setting.parent_pb_type_names(bitstream_pb_type_setting_id).size(); ++i) {
|
|
|
|
hie_name += bitstream_setting.parent_pb_type_names(bitstream_pb_type_setting_id)[i];
|
|
|
|
hie_name += std::string("[");
|
|
|
|
hie_name += bitstream_setting.parent_mode_names(bitstream_pb_type_setting_id)[i];
|
|
|
|
hie_name += std::string("]");
|
|
|
|
hie_name += std::string(".");
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Add the leaf pb_type */
|
|
|
|
hie_name += bitstream_setting.pb_type_name(bitstream_pb_type_setting_id);
|
|
|
|
|
|
|
|
return hie_name;
|
|
|
|
}
|
|
|
|
|
2021-04-19 14:42:12 -05:00
|
|
|
/********************************************************************
|
|
|
|
* Generate the full hierarchy name for an interconnect in bitstream setting
|
|
|
|
*******************************************************************/
|
|
|
|
static
|
|
|
|
std::string generate_bitstream_setting_interconnect_hierarchy_name(const openfpga::BitstreamSetting& bitstream_setting,
|
|
|
|
const BitstreamInterconnectSettingId& bitstream_interc_setting_id) {
|
|
|
|
/* Iterate over the parent_pb_type and modes names, they should well match */
|
|
|
|
VTR_ASSERT_SAFE(bitstream_setting.parent_pb_type_names(bitstream_interc_setting_id).size() == bitstream_setting.parent_mode_names(bitstream_interc_setting_id).size());
|
|
|
|
|
|
|
|
std::string hie_name;
|
|
|
|
|
|
|
|
for (size_t i = 0 ; i < bitstream_setting.parent_pb_type_names(bitstream_interc_setting_id).size(); ++i) {
|
|
|
|
hie_name += bitstream_setting.parent_pb_type_names(bitstream_interc_setting_id)[i];
|
|
|
|
hie_name += std::string("[");
|
|
|
|
hie_name += bitstream_setting.parent_mode_names(bitstream_interc_setting_id)[i];
|
|
|
|
hie_name += std::string("]");
|
|
|
|
hie_name += std::string(".");
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Add the leaf pb_type */
|
|
|
|
hie_name += bitstream_setting.interconnect_name(bitstream_interc_setting_id);
|
|
|
|
|
|
|
|
return hie_name;
|
|
|
|
}
|
|
|
|
|
2021-02-01 18:43:46 -06:00
|
|
|
/********************************************************************
|
|
|
|
* A writer to output a bitstream pb_type setting to XML format
|
|
|
|
*******************************************************************/
|
|
|
|
static
|
|
|
|
void write_xml_bitstream_pb_type_setting(std::fstream& fp,
|
|
|
|
const char* fname,
|
|
|
|
const openfpga::BitstreamSetting& bitstream_setting,
|
|
|
|
const BitstreamPbTypeSettingId& bitstream_pb_type_setting_id) {
|
|
|
|
/* Validate the file stream */
|
|
|
|
openfpga::check_file_stream(fname, fp);
|
|
|
|
|
2021-02-01 19:04:21 -06:00
|
|
|
fp << "\t" << "<pb_type";
|
2021-02-01 18:43:46 -06:00
|
|
|
|
|
|
|
/* Generate the full hierarchy name of the pb_type */
|
|
|
|
write_xml_attribute(fp, "name", generate_bitstream_setting_pb_type_hierarchy_name(bitstream_setting, bitstream_pb_type_setting_id).c_str());
|
|
|
|
|
|
|
|
write_xml_attribute(fp, "source", bitstream_setting.pb_type_bitstream_source(bitstream_pb_type_setting_id).c_str());
|
|
|
|
write_xml_attribute(fp, "content", bitstream_setting.pb_type_bitstream_content(bitstream_pb_type_setting_id).c_str());
|
2021-03-10 21:45:48 -06:00
|
|
|
write_xml_attribute(fp, "is_mode_select_bitstream", bitstream_setting.is_mode_select_bitstream(bitstream_pb_type_setting_id));
|
|
|
|
write_xml_attribute(fp, "bitstream_offset", bitstream_setting.bitstream_offset(bitstream_pb_type_setting_id));
|
2021-02-01 18:43:46 -06:00
|
|
|
|
|
|
|
fp << "/>" << "\n";
|
|
|
|
}
|
|
|
|
|
2021-04-19 14:42:12 -05:00
|
|
|
/********************************************************************
|
|
|
|
* A writer to output a bitstream interconnect setting to XML format
|
|
|
|
*******************************************************************/
|
|
|
|
static
|
|
|
|
void write_xml_bitstream_interconnect_setting(std::fstream& fp,
|
|
|
|
const char* fname,
|
|
|
|
const openfpga::BitstreamSetting& bitstream_setting,
|
|
|
|
const BitstreamInterconnectSettingId& bitstream_interc_setting_id) {
|
|
|
|
/* Validate the file stream */
|
|
|
|
openfpga::check_file_stream(fname, fp);
|
|
|
|
|
|
|
|
fp << "\t" << "<pb_type";
|
|
|
|
|
|
|
|
/* Generate the full hierarchy name of the pb_type */
|
|
|
|
write_xml_attribute(fp, "name", generate_bitstream_setting_interconnect_hierarchy_name(bitstream_setting, bitstream_interc_setting_id).c_str());
|
|
|
|
|
|
|
|
write_xml_attribute(fp, "default_path", bitstream_setting.default_path(bitstream_interc_setting_id).c_str());
|
|
|
|
|
|
|
|
fp << "/>" << "\n";
|
|
|
|
}
|
|
|
|
|
2021-02-01 18:43:46 -06:00
|
|
|
/********************************************************************
|
|
|
|
* A writer to output a bitstream setting to XML format
|
|
|
|
*******************************************************************/
|
|
|
|
void write_xml_bitstream_setting(std::fstream& fp,
|
|
|
|
const char* fname,
|
|
|
|
const openfpga::BitstreamSetting& bitstream_setting) {
|
|
|
|
/* Validate the file stream */
|
|
|
|
openfpga::check_file_stream(fname, fp);
|
|
|
|
|
|
|
|
/* Write the root node <openfpga_bitstream_setting>
|
|
|
|
*/
|
|
|
|
fp << "<openfpga_bitstream_setting>" << "\n";
|
|
|
|
|
2021-04-19 14:42:12 -05:00
|
|
|
/* Write pb_type -related settings */
|
2021-02-01 18:43:46 -06:00
|
|
|
for (const auto& bitstream_pb_type_setting_id : bitstream_setting.pb_type_settings()) {
|
|
|
|
write_xml_bitstream_pb_type_setting(fp, fname, bitstream_setting, bitstream_pb_type_setting_id);
|
|
|
|
}
|
|
|
|
|
2021-04-19 14:42:12 -05:00
|
|
|
/* Write interconnect -related settings */
|
|
|
|
for (const auto& bitstream_interc_setting_id : bitstream_setting.interconnect_settings()) {
|
|
|
|
write_xml_bitstream_interconnect_setting(fp, fname, bitstream_setting, bitstream_interc_setting_id);
|
|
|
|
}
|
|
|
|
|
2021-02-01 18:43:46 -06:00
|
|
|
/* Write the root node <openfpga_bitstream_setting> */
|
|
|
|
fp << "</openfpga_bitstream_setting>" << "\n";
|
|
|
|
}
|