Paul Bakker 
							
						 
					 
					
						
						
							
						
						fef3c5a652 
					 
					
						
						
							
							Fixed typo in POLARSSL_PKCS1_V15 in rsa.c  
						
						
						
						
					 
					
						2013-12-11 13:36:30 +01:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						27290daf3b 
					 
					
						
						
							
							Check PKCS 1.5 padding in a more constant-time way  
						
						... 
						
						
						
						(Avoid branches that depend on secret data.) 
						
						
					 
					
						2013-11-30 13:36:53 +01:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						ab44d7ecc3 
					 
					
						
						
							
							Check OAEP padding in a more constant-time way  
						
						
						
						
					 
					
						2013-11-30 13:13:05 +01:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						a5cfc35db2 
					 
					
						
						
							
							RSA-OAEP decrypt: reorganise code  
						
						
						
						
					 
					
						2013-11-29 11:58:13 +01:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						b9cfaa0c7f 
					 
					
						
						
							
							Explicit conversions and minor changes to prevent MSVC compiler warnings  
						
						
						
						
					 
					
						2013-10-14 15:50:40 +02:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						ae102995a7 
					 
					
						
						
							
							RSA blinding: lock for a smaller amount of time  
						
						
						
						
					 
					
						2013-10-11 09:19:12 +02:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						4d89c7e184 
					 
					
						
						
							
							RSA blinding: check highly unlikely cases  
						
						
						
						
					 
					
						2013-10-11 09:18:27 +02:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						971f8b84bb 
					 
					
						
						
							
							Fix compile errors with RSA_NO_CRT  
						
						
						
						
					 
					
						2013-10-11 09:18:16 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						c9965dca27 
					 
					
						
						
							
							RSA blinding threading support  
						
						
						
						
					 
					
						2013-09-29 15:02:11 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						3e41fe8938 
					 
					
						
						
							
							Remove printf when RSA selftest is skipped  
						
						
						
						
					 
					
						2013-09-15 17:42:50 +02:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						735b8fcb0b 
					 
					
						
						
							
							Fix blunder in  8a109f1 
						
						
						
						
					 
					
						2013-09-13 12:57:23 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						9013af76a3 
					 
					
						
						
							
							Merged major refactoring of x509write module into development  
						
						... 
						
						
						
						This refactoring adds support for proper CSR writing and X509
certificate generation / signing 
						
						
					 
					
						2013-09-12 11:58:04 +02:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						8a109f106d 
					 
					
						
						
							
							Optimize RSA blinding by caching-updating values  
						
						
						
						
					 
					
						2013-09-10 13:55:36 +02:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						ea53a55c0f 
					 
					
						
						
							
							Refactor to prepare for RSA blinding optimisation  
						
						
						
						
					 
					
						2013-09-10 13:55:35 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						1c3853b953 
					 
					
						
						
							
							oid_get_oid_by_*() now give back oid length as well  
						
						
						
						
					 
					
						2013-09-10 11:43:44 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						f451bac000 
					 
					
						
						
							
							Blinding RSA only active when f_rng is provided  
						
						
						
						
					 
					
						2013-08-30 15:48:53 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						48377d9834 
					 
					
						
						
							
							Configuration option to enable/disable POLARSSL_PKCS1_V15 operations  
						
						
						
						
					 
					
						2013-08-30 13:41:14 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						aab30c130c 
					 
					
						
						
							
							RSA blinding added for CRT operations  
						
						
						
						
					 
					
						2013-08-30 11:03:09 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						548957dd49 
					 
					
						
						
							
							Refactored RSA to have random generator in every RSA operation  
						
						... 
						
						
						
						Primarily so that rsa_private() receives an RNG for blinding purposes. 
						
						
					 
					
						2013-08-30 10:30:02 +02:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						3053f5bcb4 
					 
					
						
						
							
							Get rid of pk_wrap_rsa()  
						
						
						
						
					 
					
						2013-08-20 20:46:04 +02:00 
						 
				 
			
				
					
						
							
							
								Manuel Pégourié-Gonnard 
							
						 
					 
					
						
						
							
						
						cc0a9d040d 
					 
					
						
						
							
							Fix const-correctness of rsa_*_verify()  
						
						
						
						
					 
					
						2013-08-20 20:46:03 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						c70b982056 
					 
					
						
						
							
							OID functionality moved to a separate module.  
						
						... 
						
						
						
						A new OID module has been created that contains the main OID searching
functionality based on type-dependent arrays. A base type is used to
contain the basic values (oid_descriptor_t) and that type is extended to
contain type specific information (like a pk_alg_t).
As a result the rsa sign and verify function prototypes have changed. They
now expect a md_type_t identifier instead of the removed RSA_SIG_XXX
defines.
All OID definitions have been moved to oid.h
All OID matching code is in the OID module.
The RSA PKCS#1 functions cleaned up as a result and adapted to use the
MD layer.
The SSL layer cleanup up as a result and adapted to use the MD layer.
The X509 parser cleaned up and matches OIDs in certificates with new
module and adapted to use the MD layer.
The X509 writer cleaned up and adapted to use the MD layer.
Apps and tests modified accordingly 
						
						
					 
					
						2013-04-07 22:00:46 +02:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						8804f69d46 
					 
					
						
						
							
							Removed timing differences due to bad padding from RSA decrypt for  
						
						... 
						
						
						
						PKCS#1 v1.5 operations 
						
						
					 
					
						2013-03-06 18:01:03 +01:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						a43231c5a5 
					 
					
						
						
							
							Added support for custom labels when using rsa_rsaes_oaep_encrypt() or rsa_rsaes_oaep_decrypt()  
						
						
						
						
					 
					
						2013-03-06 18:01:02 +01:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						b386913f8b 
					 
					
						
						
							
							Split up the RSA PKCS#1 encrypt, decrypt, sign and verify functions  
						
						... 
						
						
						
						Split rsa_pkcs1_encrypt() into rsa_rsaes_oaep_encrypt() and
rsa_rsaes_pkcs1_v15_encrypt()
Split rsa_pkcs1_decrypt() into rsa_rsaes_oaep_decrypt() and
rsa_rsaes_pkcs1_v15_decrypt()
Split rsa_pkcs1_sign() into rsa_rsassa_pss_sign() and
rsa_rsassa_pkcs1_v15_sign()
Split rsa_pkcs1_verify() into rsa_rsassa_pss_verify() and
rsa_rsassa_pkcs1_v15_verify()
The original functions exist as generic wrappers to these functions. 
						
						
					 
					
						2013-03-06 18:01:02 +01:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						02303e8be4 
					 
					
						
						
							
							Moved md_init_ctx() calls around to minimize exit points  
						
						
						
						
					 
					
						2013-01-03 11:08:31 +01:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						40628bad98 
					 
					
						
						
							
							Memory leak when using RSA_PKCS_V21 operations fixed  
						
						
						
						
					 
					
						2013-01-03 10:50:31 +01:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						9a73632fd9 
					 
					
						
						
							
							- Merged changesets 1399 up to and including 1415 into 1.2 branch  
						
						
						
						
					 
					
						2012-11-14 12:39:52 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						0be82f20a9 
					 
					
						
						
							
							- Updated rsa_pkcs1_verify() and rsa_pkcs1_sign() to use appropriate buffer size for max MPIs  
						
						
						
						
					 
					
						2012-10-03 20:36:33 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						321df6fb80 
					 
					
						
						
							
							- Expanded rsa_check_privkey() to check DP, DQ and QP as well  
						
						
						
						
					 
					
						2012-09-27 13:21:34 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						bb51f0cb3d 
					 
					
						
						
							
							- Only include md.h if needed by POLARSSL_PKCS1_V21  
						
						
						
						
					 
					
						2012-08-23 07:46:58 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						3c16db9a10 
					 
					
						
						
							
							- Fixed potential memory zeroization on miscrafted RSA key  
						
						
						
						
					 
					
						2012-07-05 13:58:08 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						e6ee41f932 
					 
					
						
						
							
							- Added OpenSSL / PolarSSL compatibility script (tests/compat.sh) and example application (programs/ssl/o_p_test) (Requires OpenSSL)  
						
						... 
						
						
						
						- Handle encryption with private key and decryption with public key as per RFC 2313 
						
						
					 
					
						2012-05-19 08:43:48 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						56a7684023 
					 
					
						
						
							
							- Added alternative for SHA1 signature structure to check for (without NULL)  
						
						
						
						
					 
					
						2012-03-22 15:31:27 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						ed375caa3b 
					 
					
						
						
							
							- Fixed signed status of ret  
						
						
						
						
					 
					
						2012-01-14 18:10:38 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						a3d195c41f 
					 
					
						
						
							
							- Changed the used random function pointer to more flexible format. Renamed havege_rand() to havege_random() to prevent mistakes. Lots of changes as a consequence in library code and programs  
						
						
						
						
					 
					
						2011-11-27 21:07:34 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						fe3256e54b 
					 
					
						
						
							
							-  Introduced POLARSSL_MPI_MAX_SIZE and POLARSSL_MPI_MAX_BITS for MPI size management (Closes ticket  #44 )  
						
						
						
						
					 
					
						2011-11-25 12:11:43 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						1fe7d9baf9 
					 
					
						
						
							
							- Fixed incorrect behaviour in case of RSASSA-PSS with a salt length smaller than the hash length. (Closes ticket  #41 )  
						
						
						
						
					 
					
						2011-11-15 15:26:03 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						b125ed8fc6 
					 
					
						
						
							
							- Fixed typo in doxygen tag  
						
						
						
						
					 
					
						2011-11-10 13:33:51 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						684ddce18c 
					 
					
						
						
							
							- Minor fixer to remove compiler warnings for ARMCC  
						
						
						
						
					 
					
						2011-07-01 09:25:54 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						27fdf46d16 
					 
					
						
						
							
							- Removed deprecated casts to int for now unsigned values  
						
						
						
						
					 
					
						2011-06-09 13:55:13 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						5690efccc4 
					 
					
						
						
							
							- Fixed a whole bunch of dependencies on defines between files, examples and tests  
						
						
						
						
					 
					
						2011-05-26 13:16:06 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						9d781407bc 
					 
					
						
						
							
							- A error_strerror function() has been added to translate between error codes and their description.  
						
						... 
						
						
						
						- The error codes have been remapped and combining error codes is now done with a PLUS instead of an OR as error codes used are negative.
 - Descriptions to all error codes have been added.
 - Generation script for error.c has been created to automatically generate error.c from the available error definitions in the headers. 
						
						
					 
					
						2011-05-09 16:17:09 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						6c591fab72 
					 
					
						
						
							
							- mpi_init() and mpi_free() only accept a single argument and do not accept variable arguments anymore. This prevents unexpected memory corruption in a number of use cases.  
						
						
						
						
					 
					
						2011-05-05 11:49:20 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						23986e5d5d 
					 
					
						
						
							
							- Major type rewrite of int to size_t for most variables and arguments used for buffer lengths and loops  
						
						
						
						
					 
					
						2011-04-24 08:57:21 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						0216cc1bee 
					 
					
						
						
							
							- Added flag to disable Chinese Remainder Theorem when using RSA private operation (POLARSSL_RSA_NO_CRT)  
						
						
						
						
					 
					
						2011-03-26 13:40:23 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						53019ae6f7 
					 
					
						
						
							
							- RSASSA-PSS verification now properly handles salt lengths other than hlen  
						
						
						
						
					 
					
						2011-03-25 13:58:48 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						9dcc32236b 
					 
					
						
						
							
							- Added support for PKCS#1 v2.1 encoding and thus support for the RSAES-OAEP and RSASSA-PSS operations (enabled by POLARSSL_PKCS1_V21)  
						
						
						
						
					 
					
						2011-03-08 14:16:06 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						21eb2802fe 
					 
					
						
						
							
							- Changed origins of random function and pointer in rsa_pkcs1_encrypt, rsa_init, rsa_gen_key.  
						
						... 
						
						
						
						Moved to parameters of function instead of context pointers as within ssl_cli, context pointer cannot be set easily. 
						
						
					 
					
						2010-08-16 11:10:02 +00:00 
						 
				 
			
				
					
						
							
							
								Paul Bakker 
							
						 
					 
					
						
						
							
						
						b96f154e51 
					 
					
						
						
							
							- Fixed copyright message  
						
						
						
						
					 
					
						2010-07-18 20:36:00 +00:00