mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	This is per fmt's (effective) use, as it turns out, so we're not losing any fidelity in the comparison.
		
			
				
	
	
		
			44 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include "fuzztest/fuzztest.h"
 | |
| #include "gtest/gtest.h"
 | |
| 
 | |
| #include <sstream>
 | |
| #include "backends/cxxrtl/cxxrtl.h"
 | |
| #include "libs/bigint/BigUnsigned.hh"
 | |
| 
 | |
| using namespace cxxrtl_yosys;
 | |
| 
 | |
| void Formats128BitIntegers(chunk_t x0, chunk_t x1, chunk_t x2, chunk_t x3, bool signed_)
 | |
| {
 | |
|   // Compare output to BigUnsigned.
 | |
|   value<128> v;
 | |
|   v = v.blit<127, 64>(value<64>{x1, x0});
 | |
|   v = v.blit<63, 0>(value<64>{x3, x2});
 | |
| 
 | |
|   std::ostringstream oss;
 | |
|   oss << value_formatted<128>(v, false, false, ' ', 0, 10, signed_, false, false);
 | |
|   auto actual = oss.str();
 | |
| 
 | |
|   BigUnsigned u;
 | |
|   bool negative = signed_ && v.is_neg();
 | |
|   if (negative)
 | |
|     v = v.neg();
 | |
|   u.bitShiftLeft(v.slice<127, 64>().val().get<uint64_t>(), 64);
 | |
|   u.bitOr(u, v.slice<63, 0>().val().get<uint64_t>());
 | |
| 
 | |
|   std::string expected;
 | |
| 
 | |
|   if (u.isZero()) {
 | |
|     expected = "0";
 | |
|   } else {
 | |
|     while (!u.isZero()) {
 | |
|       expected += '0' + (u % 10).toInt();
 | |
|       u /= 10;
 | |
|     }
 | |
|     if (negative)
 | |
|       expected += '-';
 | |
|     std::reverse(expected.begin(), expected.end());
 | |
|   }
 | |
| 
 | |
|   EXPECT_EQ(actual, expected);
 | |
| }
 | |
| FUZZ_TEST(CxxrtlDivisionFuzz, Formats128BitIntegers);
 |