/******************************************************************** * This file includes functions that outputs routing circuit definition * to XML format *******************************************************************/ /* Headers from system goes first */ #include #include /* 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_routing_circuit.h" /******************************************************************** * Write switch circuit model definition in XML format *******************************************************************/ static void write_xml_routing_component_circuit(std::fstream& fp, const char* fname, const std::string& routing_component_name, const CircuitLibrary& circuit_lib, const std::map& switch2circuit) { /* Validate the file stream */ openfpga::check_file_stream(fname, fp); /* Iterate over the mapping */ for (std::map::const_iterator it = switch2circuit.begin(); it != switch2circuit.end(); ++it) { fp << "\t\t" << "<" << routing_component_name; write_xml_attribute(fp, "name", it->first.c_str()); write_xml_attribute(fp, "circuit_model_name", circuit_lib.model_name(it->second).c_str()); fp << "/>" << "\n"; } } /******************************************************************** * Write switch circuit model definition in XML format *******************************************************************/ static void write_xml_direct_component_circuit(std::fstream& fp, const char* fname, const std::string& direct_tag_name, const CircuitLibrary& circuit_lib, const ArchDirect& arch_direct, const ArchDirectId& direct_id) { /* Validate the file stream */ openfpga::check_file_stream(fname, fp); /* Iterate over the mapping */ fp << "\t\t" << "<" << direct_tag_name; write_xml_attribute(fp, "name", arch_direct.name(direct_id).c_str()); write_xml_attribute(fp, "circuit_model_name", circuit_lib.model_name(arch_direct.circuit_model(direct_id)).c_str()); write_xml_attribute(fp, "type", DIRECT_TYPE_STRING[arch_direct.type(direct_id)]); write_xml_attribute(fp, "x_dir", DIRECT_DIRECTION_STRING[arch_direct.x_dir(direct_id)]); write_xml_attribute(fp, "y_dir", DIRECT_DIRECTION_STRING[arch_direct.y_dir(direct_id)]); fp << "/>" << "\n"; } /******************************************************************** * Write Connection block circuit models in XML format *******************************************************************/ void write_xml_cb_switch_circuit(std::fstream& fp, const char* fname, const CircuitLibrary& circuit_lib, const std::map& switch2circuit) { /* Validate the file stream */ openfpga::check_file_stream(fname, fp); /* Write the root node */ fp << "\t" << "" << "\n"; /* Write each switch circuit definition */ write_xml_routing_component_circuit(fp, fname, std::string("switch"), circuit_lib, switch2circuit); /* Finish writing the root node */ fp << "\t" << "" << "\n"; } /******************************************************************** * Write Switch block circuit models in XML format *******************************************************************/ void write_xml_sb_switch_circuit(std::fstream& fp, const char* fname, const CircuitLibrary& circuit_lib, const std::map& switch2circuit) { /* Validate the file stream */ openfpga::check_file_stream(fname, fp); /* Write the root node */ fp << "\t" << "" << "\n"; /* Write each switch circuit definition */ write_xml_routing_component_circuit(fp, fname, std::string("switch"), circuit_lib, switch2circuit); /* Finish writing the root node */ fp << "\t" << "" << "\n"; } /******************************************************************** * Write routing segment circuit models in XML format *******************************************************************/ void write_xml_routing_segment_circuit(std::fstream& fp, const char* fname, const CircuitLibrary& circuit_lib, const std::map& seg2circuit) { /* Validate the file stream */ openfpga::check_file_stream(fname, fp); /* Write the root node */ fp << "\t" << "" << "\n"; /* Write each routing segment circuit definition */ write_xml_routing_component_circuit(fp, fname, std::string("segment"), circuit_lib, seg2circuit); /* Finish writing the root node */ fp << "\t" << "" << "\n"; } /******************************************************************** * Write direction connection circuit models in XML format *******************************************************************/ void write_xml_direct_circuit(std::fstream& fp, const char* fname, const CircuitLibrary& circuit_lib, const ArchDirect& arch_direct) { /* If the direct2circuit is empty, we do not output XML */ if (0 == arch_direct.directs().size()) { return; } /* Validate the file stream */ openfpga::check_file_stream(fname, fp); /* Write the root node */ fp << "\t" << "" << "\n"; /* Write each direct connection circuit definition */ for (const ArchDirectId& direct_id : arch_direct.directs()) { write_xml_direct_component_circuit(fp, fname, std::string("direct"), circuit_lib, arch_direct, direct_id); } /* Finish writing the root node */ fp << "\t" << "" << "\n"; }