diff options
| author | Clifford Wolf <clifford@clifford.at> | 2013-08-06 15:53:09 +0200 | 
|---|---|---|
| committer | Clifford Wolf <clifford@clifford.at> | 2013-08-06 15:53:09 +0200 | 
| commit | 653750faac4a2bf17440851c2ec7207a6a8ddcaa (patch) | |
| tree | 85919f7407a2e4326f25282df4b49fdaac021084 | |
| parent | 6efca9ea5a64cd2440c9736c4db863e78d14b5c6 (diff) | |
| download | yosys-653750faac4a2bf17440851c2ec7207a6a8ddcaa.tar.gz yosys-653750faac4a2bf17440851c2ec7207a6a8ddcaa.tar.bz2 yosys-653750faac4a2bf17440851c2ec7207a6a8ddcaa.zip | |
Small bugfixes in freduce pass
| -rw-r--r-- | passes/sat/freduce.cc | 18 | 
1 files changed, 14 insertions, 4 deletions
| diff --git a/passes/sat/freduce.cc b/passes/sat/freduce.cc index 0416cd00a..b822405f7 100644 --- a/passes/sat/freduce.cc +++ b/passes/sat/freduce.cc @@ -28,7 +28,7 @@  #include <string.h>  #include <algorithm> -#define NUM_INITIAL_RANDOM_TEST_VECTORS 3 +#define NUM_INITIAL_RANDOM_TEST_VECTORS 10  namespace { @@ -141,8 +141,11 @@ struct FreduceHelper  	restart:  		std::map<RTLIL::Const, RTLIL::SigSpec> reverse_map; -		for (auto &it : node_to_data) +		for (auto &it : node_to_data) { +			if (node_result.count(it.first) && node_result.at(it.first).is_fully_const()) +				continue;  			reverse_map[it.second].append(it.first); +		}  		for (auto &it : reverse_map)  		{ @@ -295,8 +298,10 @@ struct FreduceHelper  				continue;  			for (auto &conn : cell->connections)  				if (ct.cell_output(cell->type, conn.first)) { -					conn.second.expand(); -					for (auto &c : conn.second.chunks) { +					RTLIL::SigSpec sig = sigmap(conn.second); +					sig.expand(); +					bool did_something = false; +					for (auto &c : sig.chunks) {  						if (c.wire == NULL || !groups_unlink.check_any(c))  							continue;  						c.wire = new RTLIL::Wire; @@ -304,6 +309,11 @@ struct FreduceHelper  						module->add(c.wire);  						assert(c.width == 1);  						c.offset = 0; +						did_something = true; +					} +					if (did_something) { +						sig.optimize(); +						conn.second = sig;  					}  				}  		} | 
