for (unsigned i = 0; i < flopNum; i++)
mergeability.emplace_back(parse_xaiger_literal(f));
}
+ else if (c == 's') {
+ uint32_t dataSize YS_ATTRIBUTE(unused) = parse_xaiger_literal(f);
+ flopNum = parse_xaiger_literal(f);
+ log_assert(dataSize == (flopNum+1) * sizeof(uint32_t));
+ initial_state.reserve(flopNum);
+ for (unsigned i = 0; i < flopNum; i++)
+ initial_state.emplace_back(parse_xaiger_literal(f));
+ }
else if (c == 'n') {
parse_xaiger_literal(f);
f >> s;
}
}
+ dict<int, Wire*> mergeability_to_clock;
for (uint32_t i = 0; i < flopNum; i++) {
RTLIL::Wire *d = outputs[outputs.size() - flopNum + i];
log_assert(d);
log_assert(q->port_input);
q->port_input = false;
- auto ff = module->addCell(NEW_ID, ID($__ABC9_FF_));
+ Cell* ff;
+ int clock_index = mergeability[i];
+ if (clock_index < 0) {
+ ff = module->addCell(NEW_ID, ID($_DFF_N_));
+ clock_index = -clock_index;
+ }
+ else if (clock_index > 0)
+ ff = module->addCell(NEW_ID, ID($_DFF_P_));
+ else log_abort();
+ auto r = mergeability_to_clock.insert(clock_index);
+ if (r.second)
+ r.first->second = module->addWire(NEW_ID);
+ ff->setPort(ID::C, r.first->second);
ff->setPort(ID::D, d);
ff->setPort(ID::Q, q);
- ff->attributes[ID::abc9_mergeability] = mergeability[i];
+ ff->attributes[ID::abc9_init] = initial_state[i];
}
dict<RTLIL::IdString, std::pair<int,int>> wideports_cache;
std::vector<RTLIL::Wire*> outputs;
std::vector<RTLIL::Wire*> bad_properties;
std::vector<RTLIL::Cell*> boxes;
- std::vector<int> mergeability;
+ std::vector<int> mergeability, initial_state;
AigerReader(RTLIL::Design *design, std::istream &f, RTLIL::IdString module_name, RTLIL::IdString clk_name, std::string map_filename, bool wideports);
void parse_aiger();