mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	rtlil: represent Const strings as std::string
This commit is contained in:
		
							parent
							
								
									61ed9b6263
								
							
						
					
					
						commit
						785bd44da7
					
				
					 90 changed files with 947 additions and 643 deletions
				
			
		|  | @ -191,7 +191,7 @@ void dump_const(std::ostream &f, const RTLIL::Const &data, int width = -1, int o | |||
| { | ||||
| 	bool set_signed = (data.flags & RTLIL::CONST_FLAG_SIGNED) != 0; | ||||
| 	if (width < 0) | ||||
| 		width = data.bits.size() - offset; | ||||
| 		width = data.size() - offset; | ||||
| 	if (width == 0) { | ||||
| 		// See IEEE 1364-2005 Clause 5.1.14.
 | ||||
| 		f << "{0{1'b0}}"; | ||||
|  | @ -199,14 +199,14 @@ void dump_const(std::ostream &f, const RTLIL::Const &data, int width = -1, int o | |||
| 	} | ||||
| 	if (nostr) | ||||
| 		goto dump_hex; | ||||
| 	if ((data.flags & RTLIL::CONST_FLAG_STRING) == 0 || width != (int)data.bits.size()) { | ||||
| 	if ((data.flags & RTLIL::CONST_FLAG_STRING) == 0 || width != (int)data.size()) { | ||||
| 		if (width == 32 && !no_decimal && !nodec) { | ||||
| 			int32_t val = 0; | ||||
| 			for (int i = offset+width-1; i >= offset; i--) { | ||||
| 				log_assert(i < (int)data.bits.size()); | ||||
| 				if (data.bits[i] != State::S0 && data.bits[i] != State::S1) | ||||
| 				log_assert(i < (int)data.size()); | ||||
| 				if (data[i] != State::S0 && data[i] != State::S1) | ||||
| 					goto dump_hex; | ||||
| 				if (data.bits[i] == State::S1) | ||||
| 				if (data[i] == State::S1) | ||||
| 					val |= 1 << (i - offset); | ||||
| 			} | ||||
| 			if (decimal) | ||||
|  | @ -221,8 +221,8 @@ void dump_const(std::ostream &f, const RTLIL::Const &data, int width = -1, int o | |||
| 				goto dump_bin; | ||||
| 			vector<char> bin_digits, hex_digits; | ||||
| 			for (int i = offset; i < offset+width; i++) { | ||||
| 				log_assert(i < (int)data.bits.size()); | ||||
| 				switch (data.bits[i]) { | ||||
| 				log_assert(i < (int)data.size()); | ||||
| 				switch (data[i]) { | ||||
| 				case State::S0: bin_digits.push_back('0'); break; | ||||
| 				case State::S1: bin_digits.push_back('1'); break; | ||||
| 				case RTLIL::Sx: bin_digits.push_back('x'); break; | ||||
|  | @ -275,8 +275,8 @@ void dump_const(std::ostream &f, const RTLIL::Const &data, int width = -1, int o | |||
| 			if (width == 0) | ||||
| 				f << stringf("0"); | ||||
| 			for (int i = offset+width-1; i >= offset; i--) { | ||||
| 				log_assert(i < (int)data.bits.size()); | ||||
| 				switch (data.bits[i]) { | ||||
| 				log_assert(i < (int)data.size()); | ||||
| 				switch (data[i]) { | ||||
| 				case State::S0: f << stringf("0"); break; | ||||
| 				case State::S1: f << stringf("1"); break; | ||||
| 				case RTLIL::Sx: f << stringf("x"); break; | ||||
|  | @ -318,10 +318,10 @@ void dump_reg_init(std::ostream &f, SigSpec sig) | |||
| 
 | ||||
| 	for (auto bit : active_sigmap(sig)) { | ||||
| 		if (active_initdata.count(bit)) { | ||||
| 			initval.bits.push_back(active_initdata.at(bit)); | ||||
| 			initval.bits().push_back(active_initdata.at(bit)); | ||||
| 			gotinit = true; | ||||
| 		} else { | ||||
| 			initval.bits.push_back(State::Sx); | ||||
| 			initval.bits().push_back(State::Sx); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
|  | @ -751,7 +751,7 @@ void dump_memory(std::ostream &f, std::string indent, Mem &mem) | |||
| 					if (port.wide_log2) { | ||||
| 						Const addr_lo; | ||||
| 						for (int i = 0; i < port.wide_log2; i++) | ||||
| 							addr_lo.bits.push_back(State(sub >> i & 1)); | ||||
| 							addr_lo.bits().push_back(State(sub >> i & 1)); | ||||
| 						os << "{"; | ||||
| 						os << temp_id; | ||||
| 						os << ", "; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue