blob: ea106def804d9f65a1e4868e0db3a2e6deb67946 [file] [log] [blame]
#include "vpr_tatum_error.h"
#include "globals.h"
std::string format_tatum_error(const tatum::Error& error) {
std::string msg;
msg += "STA Engine: ";
msg += error.what();
const auto& timing_ctx = g_vpr_ctx.timing();
const auto& atom_ctx = g_vpr_ctx.atom();
const auto& cluster_ctx = g_vpr_ctx.clustering();
if (error.node || error.edge) {
msg += " (";
}
if (error.node) {
AtomPinId pin = atom_ctx.lookup.tnode_atom_pin(error.node);
if (pin) {
msg += "Netlist Pin: '" + atom_ctx.nlist.pin_name(pin) + "', ";
const t_pb_graph_pin* gpin = atom_ctx.lookup.atom_pin_pb_graph_pin(pin);
if (gpin) {
msg += "Graph node pin: '" + gpin->to_string() + "', ";
}
AtomBlockId blk = atom_ctx.nlist.pin_block(pin);
if (blk) {
msg += "Netlist Block: '" + atom_ctx.nlist.block_name(blk) + "', ";
ClusterBlockId clb_idx = atom_ctx.lookup.atom_clb(blk);
if (clb_idx) {
const t_pb* pb = cluster_ctx.clb_nlist.block_pb(clb_idx);
if (pb) {
msg += "Cluster: '" + std::string(pb->name) + "', ";
}
}
}
}
msg += "Timing Graph Node: " + std::to_string(size_t(error.node));
}
if (error.edge && error.node) {
msg += "; ";
}
if (error.edge) {
if (timing_ctx.graph) {
tatum::NodeId src_node = timing_ctx.graph->edge_src_node(error.edge);
tatum::NodeId sink_node = timing_ctx.graph->edge_sink_node(error.edge);
AtomPinId src_pin = atom_ctx.lookup.tnode_atom_pin(src_node);
AtomPinId sink_pin = atom_ctx.lookup.tnode_atom_pin(sink_node);
if (src_pin && sink_pin) {
msg += "Between netlist pins ";
msg += "'" + atom_ctx.nlist.pin_name(src_pin) + "' -> '" + atom_ctx.nlist.pin_name(sink_pin) + "'";
AtomNetId src_net = atom_ctx.nlist.pin_net(src_pin);
AtomNetId sink_net = atom_ctx.nlist.pin_net(sink_pin);
if (src_net && src_net == sink_net) {
msg += " via net '" + atom_ctx.nlist.net_name(src_net) + "'";
}
msg += ", ";
}
}
msg += "Timing Graph Edge: " + std::to_string(size_t(error.edge));
}
if (error.node || error.edge) {
msg += ")";
}
return msg;
}