aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2015-10-29 01:13:24 +0100
committerClifford Wolf <clifford@clifford.at>2015-10-29 01:13:24 +0100
commitb8cf8e19a2e899d08e7a8e339f831af016d3a315 (patch)
treecc72eced5e685f53128702497a5460cd6b8de384
parent7ea81c43da97953de68f61fafb277e6f6a83e631 (diff)
downloadicestorm-b8cf8e19a2e899d08e7a8e339f831af016d3a315.tar.gz
icestorm-b8cf8e19a2e899d08e7a8e339f831af016d3a315.tar.bz2
icestorm-b8cf8e19a2e899d08e7a8e339f831af016d3a315.zip
icetime progress
-rw-r--r--icetime/Makefile2
-rw-r--r--icetime/icetime.cc39
2 files changed, 29 insertions, 12 deletions
diff --git a/icetime/Makefile b/icetime/Makefile
index f35dd8e..faf4188 100644
--- a/icetime/Makefile
+++ b/icetime/Makefile
@@ -27,7 +27,7 @@ test0 test1 test2 test3 test4 test5 test6 test7 test8 test9: icetime
run0 run1 run2 run3 run4 run5 run6 run7 run8 run9: icetime
./icetime -P tq144 -p $(subst run,test,$@).pcf $(subst run,test,$@).txt $(subst run,test,$@)_out.v
-show0 show1 show2 show3 show4 show5 show6 show7 show8 show9:
+show0 show1 show2 show3 show4 show5 show6 show7 show8 show9: icetime
bash show.sh $(subst show,test,$@)
xdot $(subst show,test,$@).dot
diff --git a/icetime/icetime.cc b/icetime/icetime.cc
index a0f356e..a9ecb85 100644
--- a/icetime/icetime.cc
+++ b/icetime/icetime.cc
@@ -1008,10 +1008,26 @@ struct make_interconn_worker_t
create_cells(*cursor);
}
+ static std::string graph_seg_name(const net_segment_t &seg)
+ {
+ std::string str = stringf("seg_%d_%d_%s", seg.x, seg.y, seg.name.c_str());
+ for (auto &ch : str)
+ if (ch == '/') ch = '_';
+ return str;
+ }
+
+ static std::string graph_cell_name(const net_segment_t &seg)
+ {
+ std::string str = stringf("cell_%d_%d_%s", seg.x, seg.y, seg.name.c_str());
+ for (auto &ch : str)
+ if (ch == '/') ch = '_';
+ return str;
+ }
+
void show_seg_tree_worker(FILE *f, const net_segment_t &src, std::vector<std::string> &global_lines)
{
- fprintf(f, " seg_%d_%d_%s [ shape=octagon, label=\"%d %d\\n%s\" ];\n",
- src.x, src.y, src.name.c_str(), src.x, src.y, src.name.c_str());
+ fprintf(f, " %s [ shape=octagon, label=\"%d %d\\n%s\" ];\n",
+ graph_seg_name(src).c_str(), src.x, src.y, src.name.c_str());
std::vector<net_segment_t> other_net_children;
@@ -1020,8 +1036,8 @@ struct make_interconn_worker_t
other_net_children.push_back(child);
} else
show_seg_tree_worker(f, child, global_lines);
- global_lines.push_back(stringf(" seg_%d_%d_%s -> seg_%d_%d_%s;\n",
- src.x, src.y, src.name.c_str(), child.x, child.y, child.name.c_str()));
+ global_lines.push_back(stringf(" %s -> %s;\n",
+ graph_seg_name(src).c_str(), graph_seg_name(child).c_str()));
}
if (!other_net_children.empty()) {
@@ -1035,12 +1051,12 @@ struct make_interconn_worker_t
if (cell_log.count(src)) {
auto &cell = cell_log.at(src);
- global_lines.push_back(stringf(" cell_%d_%d_%s [ label=\"%s\" ];\n",
- src.x, src.y, src.name.c_str(), cell.second.c_str()));
- global_lines.push_back(stringf(" seg_%d_%d_%s -> cell_%d_%d_%s;\n",
- cell.first.x, cell.first.y, cell.first.name.c_str(), src.x, src.y, src.name.c_str()));
- global_lines.push_back(stringf(" cell_%d_%d_%s -> seg_%d_%d_%s;\n",
- src.x, src.y, src.name.c_str(), src.x, src.y, src.name.c_str()));
+ global_lines.push_back(stringf(" %s [ label=\"%s\" ];\n",
+ graph_cell_name(src).c_str(), cell.second.c_str()));
+ global_lines.push_back(stringf(" %s -> %s;\n",
+ graph_seg_name(cell.first).c_str(), graph_cell_name(src).c_str()));
+ global_lines.push_back(stringf(" %s -> %s;\n",
+ graph_cell_name(src).c_str(), graph_seg_name(src).c_str()));
}
}
@@ -1053,8 +1069,9 @@ struct make_interconn_worker_t
show_seg_tree_worker(f, src, global_lines);
fprintf(f, " }\n");
- for (auto &line : global_lines)
+ for (auto &line : global_lines) {
fprintf(f, "%s", line.c_str());
+ }
}
};