Forward searching the config bit + some minor refactor
This commit is contained in:
parent
9882394c8b
commit
0d9f1a3c6b
|
@ -119,7 +119,7 @@ static void read_xml_overwrite_bitstream_setting(
|
|||
get_attribute(xml_bit, "value", loc_data).as_string();
|
||||
if (value_attr != "0" && value_attr != "1") {
|
||||
archfpga_throw(loc_data.filename_c_str(), loc_data.line(xml_bit),
|
||||
"Invalid value of overwrite_bitstream bit");
|
||||
"Invalid value of overwrite_bitstream bit. Expect [0|1]");
|
||||
}
|
||||
/* Add to bit */
|
||||
bitstream_setting.add_overwrite_bitstream(path_attr, value_attr == "1");
|
||||
|
|
|
@ -5,6 +5,7 @@
|
|||
|
||||
#include <algorithm>
|
||||
|
||||
#include "arch_error.h"
|
||||
#include "bitstream_manager_utils.h"
|
||||
#include "openfpga_tokenizer.h"
|
||||
#include "vtr_assert.h"
|
||||
|
@ -300,39 +301,73 @@ void BitstreamManager::add_output_net_id_to_block(
|
|||
|
||||
void BitstreamManager::overwrite_bitstream(const std::string& path,
|
||||
const bool& value) {
|
||||
ConfigBlockId block;
|
||||
StringToken tokenizer(path);
|
||||
bool bad_format = true;
|
||||
size_t index = path.rfind("[");
|
||||
std::string bit_string = "";
|
||||
if (index != std::string::npos && path[path.size() - 1] == ']') {
|
||||
bit_string = path.substr(index + 1, path.size() - index - 2);
|
||||
bad_format = bit_string.size() == 0;
|
||||
auto iter = bit_string.begin();
|
||||
while (!bad_format && iter != bit_string.end()) {
|
||||
bad_format = !std::isdigit(*iter);
|
||||
iter++;
|
||||
}
|
||||
}
|
||||
if (bad_format) {
|
||||
archfpga_throw(__FILE__, __LINE__,
|
||||
"overwrite_bitstream bit path '%s' does not match format "
|
||||
"<full path in the hierarchy of FPGA fabric>[bit index]",
|
||||
path.c_str());
|
||||
} else {
|
||||
size_t bit = (size_t)(std::stoi(bit_string));
|
||||
StringToken tokenizer(path.substr(0, index));
|
||||
std::vector<std::string> blocks = tokenizer.split(".");
|
||||
std::reverse(blocks.begin(), blocks.end());
|
||||
std::string current_block_name = "";
|
||||
bool match = false;
|
||||
for (size_t i = 0; i < bit_values_.size() && !match; i++) {
|
||||
block = bit_parent_blocks_[ConfigBitId(i)];
|
||||
if (valid_block_id(block)) {
|
||||
size_t index = find_bitstream_manager_config_bit_index_in_parent_block(
|
||||
*this, ConfigBitId(i));
|
||||
current_block_name =
|
||||
block_name(block) + ("[" + std::to_string(index) + "]");
|
||||
if (current_block_name == blocks[0]) {
|
||||
match = true;
|
||||
for (size_t b = 1; b < blocks.size() && match; b++) {
|
||||
block = block_parent(block);
|
||||
if (valid_block_id(block)) {
|
||||
if (block_name(block) != blocks[b]) {
|
||||
match = false;
|
||||
std::vector<ConfigBlockId> block_ids;
|
||||
ConfigBlockId block_id = ConfigBlockId::INVALID();
|
||||
size_t found = 0;
|
||||
for (size_t i = 0; i < blocks.size(); i++) {
|
||||
if (i == 0) {
|
||||
block_ids = find_bitstream_manager_top_blocks(*this);
|
||||
} else {
|
||||
block_ids = block_children(block_id);
|
||||
}
|
||||
// Reset
|
||||
block_id = ConfigBlockId::INVALID();
|
||||
// Find the one from the list that match the name
|
||||
for (auto id : block_ids) {
|
||||
if (block_name(id) == blocks[i]) {
|
||||
block_id = id;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (block_id != ConfigBlockId::INVALID()) {
|
||||
// Found one that match the name
|
||||
found++;
|
||||
if (found == blocks.size()) {
|
||||
// Last one, no more child must end here
|
||||
if (block_children(block_id).size() == 0) {
|
||||
std::vector<ConfigBitId> ids = block_bits(block_id);
|
||||
if (bit < ids.size()) {
|
||||
VTR_ASSERT(valid_bit_id(ids[bit]));
|
||||
bit_values_[ids[bit]] = value ? '1' : '0';
|
||||
} else {
|
||||
// No configuration bits at all or out of range, invalidate
|
||||
found = 0;
|
||||
}
|
||||
} else {
|
||||
match = false;
|
||||
// There are more child, hence the path still no end, invalidate
|
||||
found = 0;
|
||||
}
|
||||
}
|
||||
if (match) {
|
||||
if (!valid_block_id(block_parent(block))) {
|
||||
bit_values_[ConfigBitId(i)] = value ? '1' : '0';
|
||||
} else {
|
||||
match = false;
|
||||
}
|
||||
// Cannot match the name, just stop
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (found != blocks.size()) {
|
||||
archfpga_throw(__FILE__, __LINE__,
|
||||
"Failed to find path '%s' to overwrite bitstream",
|
||||
path.c_str());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -69,13 +69,19 @@ int call_external_command(const Command& cmd,
|
|||
return CMD_EXEC_FATAL_ERROR;
|
||||
}
|
||||
|
||||
// Refer https://pubs.opengroup.org/onlinepubs/009695399/functions/system.html
|
||||
// Refer
|
||||
// https://pubs.opengroup.org/onlinepubs/009695399/functions/waitpid.html
|
||||
int status = system(cmd_ss.c_str());
|
||||
if (status & 0xFF) {
|
||||
// First 8 bits are system signals
|
||||
return 1;
|
||||
if (WIFEXITED(status)) {
|
||||
// This is normal program exit, WEXITSTATUS() will help you shift the status
|
||||
// accordingly (status >> 8)
|
||||
// Becareful if the final status is 2 or beyond, program will not error
|
||||
// as it is treated as CMD_EXEC_MINOR_ERROR
|
||||
return WEXITSTATUS(status);
|
||||
}
|
||||
// real return was actually shifted 8 bits
|
||||
return status >> 8;
|
||||
// Program maybe terminated because of various killed or stopped signal
|
||||
return CMD_EXEC_FATAL_ERROR;
|
||||
}
|
||||
|
||||
} /* end namespace openfpga */
|
||||
|
|
|
@ -100,7 +100,6 @@ else :
|
|||
gtree = ET.parse("golden/fabric_bitstream.xml")
|
||||
tree = ET.parse("fabric_bitstream.xml")
|
||||
bitstream_annotation = read_bitstream_annotation_xml("bitstream_annotation.xml")
|
||||
status = 0
|
||||
checked_count = 0
|
||||
for gregion, region in zip(gtree.getroot(), tree.getroot()) :
|
||||
for gbit, bit in zip(gregion, region) :
|
||||
|
|
Loading…
Reference in New Issue