3
0
Fork 0
mirror of https://github.com/YosysHQ/yosys synced 2025-10-26 17:29:23 +00:00

Added $sop support to BLIF back-end

This commit is contained in:
Clifford Wolf 2016-06-18 12:28:49 +02:00
parent 3380281e15
commit 5ffad4e073

View file

@ -338,9 +338,8 @@ struct BlifDumper
auto &inputs = cell->getPort("\\A"); auto &inputs = cell->getPort("\\A");
auto width = cell->parameters.at("\\WIDTH").as_int(); auto width = cell->parameters.at("\\WIDTH").as_int();
log_assert(inputs.size() == width); log_assert(inputs.size() == width);
for (int i = width-1; i >= 0; i--) { for (int i = width-1; i >= 0; i--)
f << stringf(" %s", cstr(inputs.extract(i, 1))); f << stringf(" %s", cstr(inputs.extract(i, 1)));
}
auto &output = cell->getPort("\\Y"); auto &output = cell->getPort("\\Y");
log_assert(output.size() == 1); log_assert(output.size() == 1);
f << stringf(" %s", cstr(output)); f << stringf(" %s", cstr(output));
@ -356,6 +355,34 @@ struct BlifDumper
continue; continue;
} }
if (!config->icells_mode && cell->type == "$sop") {
f << stringf(".names");
auto &inputs = cell->getPort("\\A");
auto width = cell->parameters.at("\\WIDTH").as_int();
auto depth = cell->parameters.at("\\DEPTH").as_int();
vector<State> table = cell->parameters.at("\\TABLE").bits;
while (GetSize(table) < 2*width*depth)
table.push_back(State::S0);
log_assert(inputs.size() == width);
for (int i = 0; i < width; i++)
f << stringf(" %s", cstr(inputs.extract(i, 1)));
auto &output = cell->getPort("\\Y");
log_assert(output.size() == 1);
f << stringf(" %s", cstr(output));
f << stringf("\n");
for (int i = 0; i < depth; i++) {
for (int j = 0; j < width; j++) {
bool pat0 = table.at(2*width*i + 2*j + 0) == State::S1;
bool pat1 = table.at(2*width*i + 2*j + 1) == State::S1;
if (pat0 && !pat1) f << "0";
else if (!pat0 && pat1) f << "1";
else f << "-";
}
f << " 1\n";
}
continue;
}
f << stringf(".%s %s", subckt_or_gate(cell->type.str()), cstr(cell->type)); f << stringf(".%s %s", subckt_or_gate(cell->type.str()), cstr(cell->type));
for (auto &conn : cell->connections()) for (auto &conn : cell->connections())
for (int i = 0; i < conn.second.size(); i++) { for (int i = 0; i < conn.second.size(); i++) {