diff options
author | Clifford Wolf <clifford@clifford.at> | 2013-11-06 13:16:47 +0100 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2013-11-06 13:16:47 +0100 |
commit | 031a91dc947e7b498ee01b480cd8372957cf37a5 (patch) | |
tree | 41223cc443f9982e9a35850c536f5e3bee55b66e /passes | |
parent | f94266bb427111cfea06c64ff42389a08c448264 (diff) | |
download | yosys-031a91dc947e7b498ee01b480cd8372957cf37a5.tar.gz yosys-031a91dc947e7b498ee01b480cd8372957cf37a5.tar.bz2 yosys-031a91dc947e7b498ee01b480cd8372957cf37a5.zip |
Added correct RTL undef handling to eval vloghammer mode
Diffstat (limited to 'passes')
-rw-r--r-- | passes/sat/eval.cc | 20 |
1 files changed, 17 insertions, 3 deletions
diff --git a/passes/sat/eval.cc b/passes/sat/eval.cc index 8e9e1a2a3..26b571e29 100644 --- a/passes/sat/eval.cc +++ b/passes/sat/eval.cc @@ -147,11 +147,12 @@ struct VlogHammerReporter { log("Creating report for pattern %d: %s\n", idx, log_signal(patterns[idx])); std::string input_pattern_list; + RTLIL::SigSpec rtl_sig; for (int mod = 0; mod < int(modules.size()); mod++) { RTLIL::Module *module = modules[mod]; - const char *module_name = module_names[mod].c_str(); + std::string module_name = module_names[mod].c_str(); ConstEval ce(module); std::vector<RTLIL::State> bits(patterns[idx].bits.begin(), patterns[idx].bits.begin() + total_input_width); @@ -178,8 +179,21 @@ struct VlogHammerReporter if (!ce.eval(sig, undef)) log_error("Evaluation of y in module %s failed: sig=%s, undef=%s\n", RTLIL::id2cstr(module->name), log_signal(sig), log_signal(undef)); - log("++RPT++ %d%s %s %s\n", idx, input_pattern_list.c_str(), sig.as_const().as_string().c_str(), module_name); - log("++VAL++ %d %s %s #\n", idx, module_name, sig.as_const().as_string().c_str()); + log("++VAL++ %d %s %s #\n", idx, module_name.c_str(), sig.as_const().as_string().c_str()); + + if (module_name == "rtl") { + rtl_sig = sig; + rtl_sig.expand(); + } else if (rtl_sig.width > 0) { + sig.expand(); + if (rtl_sig.width != sig.width) + log_error("Output (y) has a different width in module %s compared to rtl!\n", RTLIL::id2cstr(module->name)); + for (int i = 0; i < sig.width; i++) + if (rtl_sig.chunks.at(i).data.bits.at(0) == RTLIL::State::Sx) + sig.chunks.at(i).data.bits.at(0) = RTLIL::State::Sx; + } + + log("++RPT++ %d%s %s %s\n", idx, input_pattern_list.c_str(), sig.as_const().as_string().c_str(), module_name.c_str()); } log("++RPT++ ----\n"); |