mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 09:24:37 +00:00 
			
		
		
		
	kernel/rtlil: Add SigBit operator[](int offset) to SigChunk
				
					
				
			This is already supported by `SigSpec` and since both `SigChunk` and `SigSpec` implement `extract` which is the multi-bit variant of this, there is no good reason for `SigChunk` to not support `SigBit operator[](int offset)`.
This commit is contained in:
		
							parent
							
								
									c73c8a39cf
								
							
						
					
					
						commit
						f24e2536c6
					
				
					 2 changed files with 15 additions and 0 deletions
				
			
		|  | @ -3754,6 +3754,20 @@ RTLIL::SigChunk RTLIL::SigChunk::extract(int offset, int length) const | ||||||
| 	return ret; | 	return ret; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | RTLIL::SigBit RTLIL::SigChunk::operator[](int offset) const | ||||||
|  | { | ||||||
|  | 	log_assert(offset >= 0); | ||||||
|  | 	log_assert(offset <= width); | ||||||
|  | 	RTLIL::SigBit ret; | ||||||
|  | 	if (wire) { | ||||||
|  | 		ret.wire = wire; | ||||||
|  | 		ret.offset = this->offset + offset; | ||||||
|  | 	} else { | ||||||
|  | 		ret.data = data[offset]; | ||||||
|  | 	} | ||||||
|  | 	return ret; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool RTLIL::SigChunk::operator <(const RTLIL::SigChunk &other) const | bool RTLIL::SigChunk::operator <(const RTLIL::SigChunk &other) const | ||||||
| { | { | ||||||
| 	if (wire && other.wire) | 	if (wire && other.wire) | ||||||
|  |  | ||||||
|  | @ -769,6 +769,7 @@ struct RTLIL::SigChunk | ||||||
| 	SigChunk(const RTLIL::SigBit &bit); | 	SigChunk(const RTLIL::SigBit &bit); | ||||||
| 
 | 
 | ||||||
| 	RTLIL::SigChunk extract(int offset, int length) const; | 	RTLIL::SigChunk extract(int offset, int length) const; | ||||||
|  | 	RTLIL::SigBit operator[](int offset) const; | ||||||
| 	inline int size() const { return width; } | 	inline int size() const { return width; } | ||||||
| 	inline bool is_wire() const { return wire != NULL; } | 	inline bool is_wire() const { return wire != NULL; } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue