mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-25 00:44:37 +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
				
			
		|  | @ -951,15 +951,7 @@ RTLIL::Const AstNode::asAttrConst() const | |||
| { | ||||
| 	log_assert(type == AST_CONSTANT); | ||||
| 
 | ||||
| 	RTLIL::Const val; | ||||
| 	val.bits = bits; | ||||
| 
 | ||||
| 	if (is_string) { | ||||
| 		val.flags |= RTLIL::CONST_FLAG_STRING; | ||||
| 		log_assert(val.decode_string() == str); | ||||
| 	} | ||||
| 
 | ||||
| 	return val; | ||||
| 	return is_string ? RTLIL::Const(str) : RTLIL::Const(bits); | ||||
| } | ||||
| 
 | ||||
| RTLIL::Const AstNode::asParaConst() const | ||||
|  | @ -1005,7 +997,7 @@ uint64_t AstNode::asInt(bool is_signed) | |||
| 		uint64_t ret = 0; | ||||
| 
 | ||||
| 		for (int i = 0; i < 64; i++) | ||||
| 			if (v.bits.at(i) == RTLIL::State::S1) | ||||
| 			if (v.at(i) == RTLIL::State::S1) | ||||
| 				ret |= uint64_t(1) << i; | ||||
| 
 | ||||
| 		return ret; | ||||
|  | @ -1023,15 +1015,15 @@ double AstNode::asReal(bool is_signed) | |||
| 	{ | ||||
| 		RTLIL::Const val(bits); | ||||
| 
 | ||||
| 		bool is_negative = is_signed && !val.bits.empty() && val.bits.back() == RTLIL::State::S1; | ||||
| 		bool is_negative = is_signed && !val.empty() && val.back() == RTLIL::State::S1; | ||||
| 		if (is_negative) | ||||
| 			val = const_neg(val, val, false, false, val.bits.size()); | ||||
| 			val = const_neg(val, val, false, false, val.size()); | ||||
| 
 | ||||
| 		double v = 0; | ||||
| 		for (size_t i = 0; i < val.bits.size(); i++) | ||||
| 		for (size_t i = 0; i < val.size(); i++) | ||||
| 			// IEEE Std 1800-2012 Par 6.12.2: Individual bits that are x or z in
 | ||||
| 			// the net or the variable shall be treated as zero upon conversion.
 | ||||
| 			if (val.bits.at(i) == RTLIL::State::S1) | ||||
| 			if (val.at(i) == RTLIL::State::S1) | ||||
| 				v += exp2(i); | ||||
| 		if (is_negative) | ||||
| 			v *= -1; | ||||
|  | @ -1054,15 +1046,15 @@ RTLIL::Const AstNode::realAsConst(int width) | |||
| #else | ||||
| 	if (!std::isfinite(v)) { | ||||
| #endif | ||||
| 		result.bits = std::vector<RTLIL::State>(width, RTLIL::State::Sx); | ||||
| 		result = std::vector<RTLIL::State>(width, RTLIL::State::Sx); | ||||
| 	} else { | ||||
| 		bool is_negative = v < 0; | ||||
| 		if (is_negative) | ||||
| 			v *= -1; | ||||
| 		for (int i = 0; i < width; i++, v /= 2) | ||||
| 			result.bits.push_back((fmod(floor(v), 2) != 0) ? RTLIL::State::S1 : RTLIL::State::S0); | ||||
| 			result.bits().push_back((fmod(floor(v), 2) != 0) ? RTLIL::State::S1 : RTLIL::State::S0); | ||||
| 		if (is_negative) | ||||
| 			result = const_neg(result, result, false, false, result.bits.size()); | ||||
| 			result = const_neg(result, result, false, false, result.size()); | ||||
| 	} | ||||
| 	return result; | ||||
| } | ||||
|  | @ -1767,16 +1759,7 @@ static std::string serialize_param_value(const RTLIL::Const &val) { | |||
| 		res.push_back('r'); | ||||
| 	res += stringf("%d", GetSize(val)); | ||||
| 	res.push_back('\''); | ||||
| 	for (int i = GetSize(val) - 1; i >= 0; i--) { | ||||
| 		switch (val.bits[i]) { | ||||
| 			case RTLIL::State::S0: res.push_back('0'); break; | ||||
| 			case RTLIL::State::S1: res.push_back('1'); break; | ||||
| 			case RTLIL::State::Sx: res.push_back('x'); break; | ||||
| 			case RTLIL::State::Sz: res.push_back('z'); break; | ||||
| 			case RTLIL::State::Sa: res.push_back('?'); break; | ||||
| 			case RTLIL::State::Sm: res.push_back('m'); break; | ||||
| 		} | ||||
| 	} | ||||
| 	res.append(val.as_string("?")); | ||||
| 	return res; | ||||
| } | ||||
| 
 | ||||
|  | @ -1868,7 +1851,7 @@ std::string AstModule::derive_common(RTLIL::Design *design, const dict<RTLIL::Id | |||
| 		} else if ((it->second.flags & RTLIL::CONST_FLAG_STRING) != 0) | ||||
| 			child->children[0] = AstNode::mkconst_str(it->second.decode_string()); | ||||
| 		else | ||||
| 			child->children[0] = AstNode::mkconst_bits(it->second.bits, (it->second.flags & RTLIL::CONST_FLAG_SIGNED) != 0); | ||||
| 			child->children[0] = AstNode::mkconst_bits(it->second.to_bits(), (it->second.flags & RTLIL::CONST_FLAG_SIGNED) != 0); | ||||
| 		rewritten.insert(it->first); | ||||
| 	} | ||||
| 
 | ||||
|  | @ -1881,7 +1864,7 @@ std::string AstModule::derive_common(RTLIL::Design *design, const dict<RTLIL::Id | |||
| 			if ((param.second.flags & RTLIL::CONST_FLAG_STRING) != 0) | ||||
| 				defparam->children.push_back(AstNode::mkconst_str(param.second.decode_string())); | ||||
| 			else | ||||
| 				defparam->children.push_back(AstNode::mkconst_bits(param.second.bits, (param.second.flags & RTLIL::CONST_FLAG_SIGNED) != 0)); | ||||
| 				defparam->children.push_back(AstNode::mkconst_bits(param.second.to_bits(), (param.second.flags & RTLIL::CONST_FLAG_SIGNED) != 0)); | ||||
| 			new_ast->children.push_back(defparam); | ||||
| 		} | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue