From 169ffcd2fbd037aa1d827515af5a95a28299b832 Mon Sep 17 00:00:00 2001 From: Miodrag Milanovic Date: Wed, 2 Feb 2022 10:08:23 +0100 Subject: unify cycles counting and cleanup --- passes/sat/sim.cc | 71 +++++++++++++++++++++++++++---------------------------- 1 file changed, 35 insertions(+), 36 deletions(-) (limited to 'passes/sat') diff --git a/passes/sat/sim.cc b/passes/sat/sim.cc index bb1b1dfa3..3c8d03cba 100644 --- a/passes/sat/sim.cc +++ b/passes/sat/sim.cc @@ -921,7 +921,8 @@ struct SimWorker : SimShared { if (debug) log("\n===== %d =====\n", 10*cycle + 5); - + else + log("Simulating cycle %d.\n", (cycle*2)+1); set_inports(clock, State::S0); set_inports(clockn, State::S1); @@ -931,7 +932,7 @@ struct SimWorker : SimShared if (debug) log("\n===== %d =====\n", 10*cycle + 10); else - log("Simulating cycle %d.\n", cycle+1); + log("Simulating cycle %d.\n", (cycle*2)+2); set_inports(clock, State::S1); set_inports(clockn, State::S0); @@ -1034,42 +1035,40 @@ struct SimWorker : SimShared if (stopCountgetAllEdges(fst_clock, startCount, stopCount); - if (cycles_set && ((size_t)(numcycles *2) < edges.size())) - edges.erase(edges.begin() + (numcycles*2), edges.end()); - - if ((startCount == stopCount) && writeback) { - log("Update initial state with values from [%zu%s]\n", startCount, fst->getTimescaleString()); - if (edges.empty()) - edges.push_back(startCount); - fst->reconstructAllAtTimes(edges); - top->setInitState(startCount); + auto samples = fst->getAllEdges(fst_clock, startCount, stopCount); + + // Limit to number of cycles if provided + if (cycles_set && ((size_t)(numcycles *2) < samples.size())) + samples.erase(samples.begin() + (numcycles*2), samples.end()); + + // Add setup time (start time) + if (samples.empty() || samples.front()!=startCount) + samples.insert(samples.begin(), startCount); + + fst->reconstructAllAtTimes(samples); + bool initial = true; + int cycle = 0; + log("Co-simulation from %zu%s to %zu%s\n", startCount, fst->getTimescaleString(), stopCount, fst->getTimescaleString()); + for(auto &time : samples) { + log("Co-simulating cycle %d [%zu%s].\n", cycle, time, fst->getTimescaleString()); + for(auto &item : inputs) { + std::string v = fst->valueAt(item.second, time); + top->set_state(item.first, Const::from_string(v)); + } + if (initial) { + top->setInitState(time); + initial = false; + } + update(); + + bool status = top->checkSignals(time); + if (status) + log_error("Signal difference\n"); + cycle++; + } + if (writeback) { pool wbmods; top->writeback(wbmods); - } else { - if (edges.empty()) - log_error("No clock edges found in given time range\n"); - fst->reconstructAllAtTimes(edges); - bool initial = false; - int cycle = 0; - log("Co-simulation from %zu%s to %zu%s\n", startCount, fst->getTimescaleString(), stopCount, fst->getTimescaleString()); - for(auto &time : edges) { - log("Co-simulating cycle %d [%zu%s].\n", cycle+1, time, fst->getTimescaleString()); - for(auto &item : inputs) { - std::string v = fst->valueAt(item.second, time); - top->set_state(item.first, Const::from_string(v)); - } - if (!initial) { - top->setInitState(time); - initial = true; - } - update(); - - bool status = top->checkSignals(time); - if (status) - log_error("Signal difference\n"); - cycle++; - } } } }; -- cgit v1.2.3