diff options
Diffstat (limited to 'kernel/rtlil.cc')
| -rw-r--r-- | kernel/rtlil.cc | 8 | 
1 files changed, 5 insertions, 3 deletions
| diff --git a/kernel/rtlil.cc b/kernel/rtlil.cc index d4aebcda9..b3214579d 100644 --- a/kernel/rtlil.cc +++ b/kernel/rtlil.cc @@ -33,6 +33,8 @@ std::vector<int> RTLIL::IdString::global_refcount_storage_;  std::vector<char*> RTLIL::IdString::global_id_storage_;  dict<char*, int, hash_cstr_ops> RTLIL::IdString::global_id_index_;  std::vector<int> RTLIL::IdString::global_free_idx_list_; +int RTLIL::IdString::last_created_idx_[8]; +int RTLIL::IdString::last_created_idx_ptr_;  RTLIL::Const::Const()  { @@ -758,7 +760,7 @@ namespace {  		void check()  		{ -			if (cell->type.substr(0, 1) != "$" || cell->type.substr(0, 3) == "$__" || cell->type.substr(0, 8) == "$paramod" || +			if (cell->type.substr(0, 1) != "$" || cell->type.substr(0, 3) == "$__" || cell->type.substr(0, 8) == "$paramod" || cell->type.substr(0,10) == "$fmcombine" ||  					cell->type.substr(0, 9) == "$verific$" || cell->type.substr(0, 7) == "$array:" || cell->type.substr(0, 8) == "$extern:")  				return; @@ -2358,7 +2360,7 @@ void RTLIL::Cell::check()  void RTLIL::Cell::fixup_parameters(bool set_a_signed, bool set_b_signed)  { -	if (type.substr(0, 1) != "$" || type.substr(0, 2) == "$_" || type.substr(0, 8) == "$paramod" || +	if (type.substr(0, 1) != "$" || type.substr(0, 2) == "$_" || type.substr(0, 8) == "$paramod" || type.substr(0,10) == "$fmcombine" ||  			type.substr(0, 9) == "$verific$" || type.substr(0, 7) == "$array:" || type.substr(0, 8) == "$extern:")  		return; @@ -3235,7 +3237,7 @@ void RTLIL::SigSpec::extend_u0(int width, bool is_signed)  		remove(width, width_ - width);  	if (width_ < width) { -		RTLIL::SigBit padding = width_ > 0 ? (*this)[width_ - 1] : RTLIL::State::S0; +		RTLIL::SigBit padding = width_ > 0 ? (*this)[width_ - 1] : RTLIL::State::Sx;  		if (!is_signed)  			padding = RTLIL::State::S0;  		while (width_ < width) | 
