mirror of
				https://github.com/dolphin-emu/dolphin.git
				synced 2025-10-26 01:49:46 +00:00 
			
		
		
		
	The loops relied on unsigned integer overflow, which is not immediately obvious. Replace them with less clever variants that are clearer. Also implement bn_compare using std::memcmp.
		
			
				
	
	
		
			16 lines
		
	
	
	
		
			558 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			16 lines
		
	
	
	
		
			558 B
		
	
	
	
		
			C
		
	
	
	
	
	
| // Copyright 2014 Dolphin Emulator Project
 | |
| // Licensed under GPLv2+
 | |
| // Refer to the license.txt file included.
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include "Common/CommonTypes.h"
 | |
| 
 | |
| // bignum arithmetic
 | |
| 
 | |
| int bn_compare(const u8* a, const u8* b, int n);
 | |
| void bn_sub_modulus(u8* a, const u8* N, int n);
 | |
| void bn_add(u8* d, const u8* a, const u8* b, const u8* N, int n);
 | |
| void bn_mul(u8* d, const u8* a, const u8* b, const u8* N, int n);
 | |
| void bn_inv(u8* d, const u8* a, const u8* N, int n);  // only for prime N
 | |
| void bn_exp(u8* d, const u8* a, const u8* N, int n, const u8* e, int en);
 |