mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Add support for GHDL modfloor operator
This commit is contained in:
		
							parent
							
								
									086c2f3224
								
							
						
					
					
						commit
						24b895778a
					
				
					 2 changed files with 22 additions and 1 deletions
				
			
		|  | @ -1575,6 +1575,27 @@ value<BitsY> mod_ss(const value<BitsA> &a, const value<BitsB> &b) { | ||||||
| 	return divmod_ss<BitsY>(a, b).second; | 	return divmod_ss<BitsY>(a, b).second; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | template<size_t BitsY, size_t BitsA, size_t BitsB> | ||||||
|  | CXXRTL_ALWAYS_INLINE | ||||||
|  | value<BitsY> modfloor_uu(const value<BitsA> &a, const value<BitsB> &b) { | ||||||
|  | 	return divmod_uu<BitsY>(a, b).second; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // GHDL Modfloor operator. Returns r=a mod b, such that r has the same sign as b and
 | ||||||
|  | // a=b*N+r where N is some integer
 | ||||||
|  | // In practical terms, when a and b have different signs and the remainder returned by divmod_ss is not 0
 | ||||||
|  | // then return the remainder + b
 | ||||||
|  | template<size_t BitsY, size_t BitsA, size_t BitsB> | ||||||
|  | CXXRTL_ALWAYS_INLINE | ||||||
|  | value<BitsY> modfloor_ss(const value<BitsA> &a, const value<BitsB> &b) { | ||||||
|  | 	value<BitsY> r; | ||||||
|  | 	r = divmod_ss<BitsY>(a, b).second; | ||||||
|  | 	if((b.is_neg() != a.is_neg()) && !r.is_zero()) | ||||||
|  | 		return add_ss<BitsY>(b, r); | ||||||
|  | 	return r; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| // Memory helper
 | // Memory helper
 | ||||||
| struct memory_index { | struct memory_index { | ||||||
| 	bool valid; | 	bool valid; | ||||||
|  |  | ||||||
|  | @ -185,7 +185,7 @@ bool is_binary_cell(RTLIL::IdString type) | ||||||
| 		ID($and), ID($or), ID($xor), ID($xnor), ID($logic_and), ID($logic_or), | 		ID($and), ID($or), ID($xor), ID($xnor), ID($logic_and), ID($logic_or), | ||||||
| 		ID($shl), ID($sshl), ID($shr), ID($sshr), ID($shift), ID($shiftx), | 		ID($shl), ID($sshl), ID($shr), ID($sshr), ID($shift), ID($shiftx), | ||||||
| 		ID($eq), ID($ne), ID($eqx), ID($nex), ID($gt), ID($ge), ID($lt), ID($le), | 		ID($eq), ID($ne), ID($eqx), ID($nex), ID($gt), ID($ge), ID($lt), ID($le), | ||||||
| 		ID($add), ID($sub), ID($mul), ID($div), ID($mod)); | 		ID($add), ID($sub), ID($mul), ID($div), ID($mod), ID($modfloor)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool is_extending_cell(RTLIL::IdString type) | bool is_extending_cell(RTLIL::IdString type) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue