mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-31 11:42:30 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			60 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <cassert>
 | |
| #include <cstdint>
 | |
| 
 | |
| #include "cxxrtl/cxxrtl.h"
 | |
| 
 | |
| int main()
 | |
| {
 | |
|     {
 | |
|         // shl exceeding Bits should be masked
 | |
|         cxxrtl::value<6> a(1u);
 | |
|         cxxrtl::value<6> b(8u);
 | |
|         cxxrtl::value<6> c = a.shl(b);
 | |
|         assert(c.get<uint64_t>() == 0);
 | |
|     }
 | |
| 
 | |
|     {
 | |
|         // sshr of unreasonably large size should sign extend correctly
 | |
|         cxxrtl::value<64> a(0u, 0x80000000u);
 | |
|         cxxrtl::value<64> b(0u, 1u);
 | |
|         cxxrtl::value<64> c = a.sshr(b);
 | |
|         assert(c.get<uint64_t>() == 0xffffffffffffffffu);
 | |
|     }
 | |
| 
 | |
|     {
 | |
|         // sshr of exteeding Bits should sign extend correctly
 | |
|         cxxrtl::value<8> a(0x80u);
 | |
|         cxxrtl::value<8> b(10u);
 | |
|         cxxrtl::value<8> c = a.sshr(b);
 | |
|         assert(c.get<uint64_t>() == 0xffu);
 | |
|     }
 | |
| 
 | |
|     {
 | |
|         // Sign extension should occur correctly
 | |
|         cxxrtl::value<64> a(0x23456789u, 0x8abcdef1u);
 | |
|         cxxrtl::value<8> b(32u);
 | |
|         cxxrtl::value<64> c = a.sshr(b);
 | |
|         assert(c.get<uint64_t>() == 0xffffffff8abcdef1u);
 | |
|     }
 | |
| 
 | |
|     {
 | |
|         // ctlz should work with Bits that are a multiple of chunk size
 | |
|         cxxrtl::value<32> a(0x00040000u);
 | |
|         assert(a.ctlz() == 13);
 | |
|     }
 | |
| 
 | |
|     {
 | |
|         // bmux clears top bits of result
 | |
|         cxxrtl::value<8> val(0x1fu);
 | |
|         cxxrtl::value<1> sel(0u);
 | |
|         assert(val.template bmux<4>(sel).get<uint64_t>() == 0xfu);
 | |
|     }
 | |
| 
 | |
|     {
 | |
|         // stream operator smoke test
 | |
|         cxxrtl::value<8> val(0x1fu);
 | |
|         std::ostringstream oss;
 | |
|         oss << val;
 | |
|         assert(oss.str() == "8'1f");
 | |
|     }
 | |
| }
 |