From 4bd6f1ee8eb13f94fa7b6d3b87b8f19648ec4d6b Mon Sep 17 00:00:00 2001 From: Clifford Wolf Date: Sun, 24 Mar 2013 17:59:44 +0100 Subject: [PATCH] Changed fsm_expand to merge multiplexers more aggressively --- passes/fsm/fsm_expand.cc | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/passes/fsm/fsm_expand.cc b/passes/fsm/fsm_expand.cc index df3aec85a..0446c113d 100644 --- a/passes/fsm/fsm_expand.cc +++ b/passes/fsm/fsm_expand.cc @@ -42,6 +42,9 @@ struct FsmExpand bool is_cell_merge_candidate(RTLIL::Cell *cell) { + if (cell->type == "$mux" || cell->type == "$pmux" || cell->type == "$safe_pmux") + return cell->connections.at("\\A").width < 2; + RTLIL::SigSpec new_signals; if (cell->connections.count("\\A") > 0) new_signals.append(assign_map(cell->connections["\\A"])); @@ -137,7 +140,7 @@ struct FsmExpand input_sig.sort_and_unify(); input_sig.remove_const(); - assert(input_sig.width <= 4); + assert(input_sig.width <= 4 || cell->type == "$mux" || cell->type == "$pmux" || cell->type == "$safe_pmux"); std::vector truth_tab; for (int i = 0; i < (1 << input_sig.width); i++) {