mirror of https://github.com/YosysHQ/yosys.git
Merge pull request #4232 from povik/mem-ui-fixes
opt_mem, memory_*: Refuse to operate in presence of processes
This commit is contained in:
commit
6dc5da3ed9
|
@ -39,6 +39,9 @@ struct MemoryCollectPass : public Pass {
|
|||
log_header(design, "Executing MEMORY_COLLECT pass (generating $mem cells).\n");
|
||||
extra_args(args, 1, design);
|
||||
for (auto module : design->selected_modules()) {
|
||||
if (module->has_processes_warn())
|
||||
continue;
|
||||
|
||||
for (auto &mem : Mem::get_selected_memories(module)) {
|
||||
if (!mem.packed) {
|
||||
mem.packed = true;
|
||||
|
|
|
@ -2229,6 +2229,9 @@ struct MemoryLibMapPass : public Pass {
|
|||
Library lib = parse_library(lib_files, defines);
|
||||
|
||||
for (auto module : design->selected_modules()) {
|
||||
if (module->has_processes_warn())
|
||||
continue;
|
||||
|
||||
MapWorker worker(module);
|
||||
auto mems = Mem::get_selected_memories(module);
|
||||
for (auto &mem : mems)
|
||||
|
|
|
@ -493,6 +493,9 @@ struct MemoryMapPass : public Pass {
|
|||
extra_args(args, argidx, design);
|
||||
|
||||
for (auto mod : design->selected_modules()) {
|
||||
if (mod->has_processes_warn())
|
||||
continue;
|
||||
|
||||
MemoryMapWorker worker(design, mod);
|
||||
worker.attr_icase = attr_icase;
|
||||
worker.attributes = attributes;
|
||||
|
|
|
@ -50,7 +50,7 @@ struct MemoryMemxPass : public Pass {
|
|||
}
|
||||
|
||||
void execute(std::vector<std::string> args, RTLIL::Design *design) override {
|
||||
log_header(design, "Executing MEMORY_MEMX pass (converting $mem cells to logic and flip-flops).\n");
|
||||
log_header(design, "Executing MEMORY_MEMX pass (emit soft logic for out-of-bounds handling).\n");
|
||||
extra_args(args, 1, design);
|
||||
|
||||
for (auto module : design->selected_modules())
|
||||
|
|
|
@ -46,6 +46,9 @@ struct MemoryNarrowPass : public Pass {
|
|||
extra_args(args, argidx, design);
|
||||
|
||||
for (auto module : design->selected_modules()) {
|
||||
if (module->has_processes_warn())
|
||||
continue;
|
||||
|
||||
for (auto &mem : Mem::get_selected_memories(module))
|
||||
{
|
||||
bool wide = false;
|
||||
|
|
|
@ -558,8 +558,12 @@ struct MemorySharePass : public Pass {
|
|||
extra_args(args, argidx, design);
|
||||
MemoryShareWorker msw(design, flag_widen, flag_sat);
|
||||
|
||||
for (auto module : design->selected_modules())
|
||||
for (auto module : design->selected_modules()) {
|
||||
if (module->has_processes_warn())
|
||||
continue;
|
||||
|
||||
msw(module);
|
||||
}
|
||||
}
|
||||
} MemorySharePass;
|
||||
|
||||
|
|
|
@ -52,6 +52,9 @@ struct OptMemPass : public Pass {
|
|||
|
||||
int total_count = 0;
|
||||
for (auto module : design->selected_modules()) {
|
||||
if (module->has_processes_warn())
|
||||
continue;
|
||||
|
||||
SigMap sigmap(module);
|
||||
FfInitVals initvals(&sigmap, module);
|
||||
for (auto &mem : Mem::get_selected_memories(module)) {
|
||||
|
|
Loading…
Reference in New Issue