read_vcd id->values

Signed-off-by: James Cherry <cherry@parallaxsw.com>
This commit is contained in:
James Cherry 2022-10-25 18:00:40 -07:00
parent 20ed9e5537
commit bd4e4e77a1
1 changed files with 18 additions and 44 deletions

View File

@ -61,12 +61,11 @@ private:
void makeVarIdMap();
void appendVarValue(string id,
char value);
size_t varMaxValueCount();
VarTime varMinTimeDelta();
string getToken();
string readStmtString();
vector<string> readStmtTokens();
VcdValues &values(VcdVar &var);
gzFile stream_;
string token_;
@ -83,7 +82,7 @@ private:
vector<VcdVar> vars_;
size_t max_var_name_length_;
int max_var_width_;
map<string, VcdVar*> id_var_map_;
map<string, VcdValues> id_values_map_;
VarTime time_;
VarTime time_max_;
};
@ -100,18 +99,12 @@ public:
VarType type() const { return type_; }
int width() const { return width_; }
const string& id() const { return id_; }
void pushValue(VarTime time,
char value);
void pushBusValue(VarTime time,
VarTime bus_value);
VcdValues values() { return values_; }
private:
string name_;
VarType type_;
int width_;
string id_;
VcdValues values_;
};
class VcdValue
@ -268,15 +261,13 @@ VcdReader::parseUpscope()
readStmtTokens();
}
// vars_ grows so the map has to be built after the vars.
// Make entries for each ID used by variables.
void
VcdReader::makeVarIdMap()
{
for (VcdVar &var : vars_) {
const string &id = var.id();
// Use the first variable definition which has the highest scope.
if (id_var_map_.find(id) == id_var_map_.end())
id_var_map_[id] = &var;
id_values_map_[id].clear();
}
}
@ -306,12 +297,12 @@ VcdReader::parseVarValues()
char *end;
int64_t bus_value = strtol(bin.c_str(), &end, 2);
string id = getToken();
auto var_itr = id_var_map_.find(id);
if (var_itr == id_var_map_.end())
auto values_itr = id_values_map_.find(id);
if (values_itr == id_values_map_.end())
report_->fileError(804, filename_, stmt_line_,
"unknown variable %s", id.c_str());
VcdVar *var = var_itr->second;
var->pushBusValue(time_, bus_value);
VcdValues &values = values_itr->second;
values.push_back(VcdValue(time_, '\0', bus_value));
}
}
token = getToken();
@ -323,29 +314,27 @@ void
VcdReader::appendVarValue(string id,
char value)
{
auto var_itr = id_var_map_.find(id);
if (var_itr == id_var_map_.end())
auto values_itr = id_values_map_.find(id);
if (values_itr == id_values_map_.end())
report_->fileError(805, filename_, stmt_line_,
"Unknown variable %s", id.c_str());
VcdVar *var = var_itr->second;
var->pushValue(time_, value);
VcdValues &values = values_itr->second;
values.push_back(VcdValue(time_, value, 0));
}
size_t
VcdReader::varMaxValueCount()
VcdValues &
VcdReader::values(VcdVar &var)
{
size_t max_count = 0;
for (VcdVar &var : vars_)
max_count = max(max_count, var.values().size());
return max_count;
return id_values_map_[var.id()];
}
VarTime
VcdReader::varMinTimeDelta()
{
VarTime min_delta = std::numeric_limits<VarTime>::max();
for (VcdVar &var : vars_) {
const VcdValues &var_values = var.values();
const VcdValues &var_values = values(var);
if (!var_values.empty()) {
VarTime prev_time = var_values[0].time();
for (const VcdValue &value : var_values) {
@ -425,8 +414,7 @@ VcdReader::reportWaveforms()
printf(" %-*s",
static_cast<int>(max_var_name_length_),
var.name().c_str());
// WRONG - copies vector
VcdValues var_values = var.values();
const VcdValues &var_values = values(var);
if (!var_values.empty()) {
size_t value_index = 0;
VcdValue var_value = var_values[value_index];
@ -485,20 +473,6 @@ VcdVar::VcdVar(string name,
{
}
void
VcdVar::pushValue(VarTime time,
char value)
{
values_.push_back(VcdValue(time, value, 0));
}
void
VcdVar::pushBusValue(VarTime time,
int64_t bus_value)
{
values_.push_back(VcdValue(time, '\0', bus_value));
}
VcdValue::VcdValue(VarTime time,
char value,
uint64_t bus_value) :