CIRCT 23.0.0git
Loading...
Searching...
No Matches
BMCTrace.cpp
Go to the documentation of this file.
1//===- BMCTrace.cpp -------------------------------------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
10
11#include "llvm/ADT/SmallString.h"
12
13#include <cassert>
14
15circt::bmc::BMCTrace::BMCTrace(llvm::StringRef topName) : topName(topName) {}
16
17size_t circt::bmc::BMCTrace::addSignal(llvm::StringRef name, unsigned width) {
18 signals.push_back({name.str(), width});
19 for (auto &step : recorded)
20 step.resize(signals.size());
21 return signals.size() - 1;
22}
23
25 if (step >= recorded.size())
26 recorded.resize(step + 1, Step(signals.size()));
27}
28
29void circt::bmc::BMCTrace::record(size_t step, size_t signal, Handle handle) {
30 assert(signal < signals.size() && "signal index out of range");
31 ensureStep(step);
32 recorded[step][signal] = handle;
33}
34
35std::optional<circt::bmc::BMCTrace::Handle>
36circt::bmc::BMCTrace::lookup(size_t step, size_t signal) const {
37 if (step >= recorded.size() || signal >= signals.size())
38 return std::nullopt;
39 return recorded[step][signal];
40}
41
42bool circt::bmc::BMCTrace::printTextTrace(llvm::raw_ostream &os,
43 Evaluator evaluate) const {
44 os << "counterexample for " << topName << ":\n";
45 for (size_t step = 0, e = recorded.size(); step != e; ++step) {
46 os << "cycle " << step << ":\n";
47 for (size_t signal = 0, numSignals = signals.size(); signal != numSignals;
48 ++signal) {
49 auto handle = recorded[step][signal];
50 if (!handle)
51 return false;
52 auto value = evaluate(*handle, signals[signal].width);
53 if (!value || value->getBitWidth() != signals[signal].width)
54 return false;
55 llvm::SmallString<40> str;
56 value->toString(str, /*Radix=*/16, /*Signed=*/false,
57 /*formatAsCLiteral=*/false, /*UpperCase=*/false);
58 os << " " << signals[signal].name << " = 0x" << str << "\n";
59 }
60 }
61 return true;
62}
assert(baseType &&"element must be base type")
bool printTextTrace(llvm::raw_ostream &os, Evaluator evaluate) const
Render the trace as cycle-by-cycle text using the provided evaluator to materialize values from recor...
Definition BMCTrace.cpp:42
void ensureStep(size_t step)
Definition BMCTrace.cpp:24
BMCTrace(llvm::StringRef topName="bmc")
Create an empty trace for the given top-level design/module name.
Definition BMCTrace.cpp:15
const void * Handle
Opaque per-signal value reference recorded for a specific cycle.
Definition BMCTrace.h:31
size_t addSignal(llvm::StringRef name, unsigned width)
Register a signal to be tracked and return its stable index.
Definition BMCTrace.cpp:17
std::vector< std::optional< Handle > > Step
Per-cycle storage for all tracked signals.
Definition BMCTrace.h:65
llvm::function_ref< std::optional< llvm::APInt >(Handle, unsigned width)> Evaluator
Callback used to materialize a recorded handle into a concrete value when formatting a trace.
Definition BMCTrace.h:36
void record(size_t step, size_t signal, Handle handle)
Record the value handle for a tracked signal at the given cycle.
Definition BMCTrace.cpp:29
std::optional< Handle > lookup(size_t step, size_t signal) const
Return the recorded handle for a signal at a given cycle, if present.
Definition BMCTrace.cpp:36