mirror of
				https://github.com/cuberite/polarssl.git
				synced 2025-10-30 19:20:40 -04:00 
			
		
		
		
	Zeroize internal buffers and variables in PKCS and SHA
Zeroising of local buffers and variables which are used for calculations in mbedtls_pkcs5_pbkdf2_hmac() and mbedtls_internal_sha*_process() functions to erase sensitive data from memory. Checked all function for possible missing zeroisation in PKCS and SHA. Signed-off-by: gabor-mezei-arm <gabor.mezei@arm.com>
This commit is contained in:
		
							parent
							
								
									8ed8694199
								
							
						
					
					
						commit
						76749aea78
					
				| @ -0,0 +1,5 @@ | |||||||
|  | Security | ||||||
|  |    * Zeroising of local buffers and variables which are used for calculations | ||||||
|  |      in mbedtls_pkcs5_pbkdf2_hmac() and mbedtls_internal_sha*_process() | ||||||
|  |      functions to erase sensitive data from memory. Reported by | ||||||
|  |      Johan Malmgren and Johan Uppman Bruce from Sectra. | ||||||
| @ -290,6 +290,10 @@ int mbedtls_pkcs5_pbkdf2_hmac( mbedtls_md_context_t *ctx, | |||||||
|                 break; |                 break; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /* Zeroise buffers to clear sensitive data from memory. */ | ||||||
|  |     mbedtls_platform_zeroize( work, MBEDTLS_MD_MAX_SIZE ); | ||||||
|  |     mbedtls_platform_zeroize( md1, MBEDTLS_MD_MAX_SIZE ); | ||||||
|  | 
 | ||||||
|     return( 0 ); |     return( 0 ); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -285,6 +285,15 @@ int mbedtls_internal_sha1_process( mbedtls_sha1_context *ctx, | |||||||
|     ctx->state[3] += D; |     ctx->state[3] += D; | ||||||
|     ctx->state[4] += E; |     ctx->state[4] += E; | ||||||
| 
 | 
 | ||||||
|  |     /* Zeroise buffers and variables to clear sensitive data from memory. */ | ||||||
|  |     mbedtls_platform_zeroize( &A, sizeof( A ) ); | ||||||
|  |     mbedtls_platform_zeroize( &B, sizeof( B ) ); | ||||||
|  |     mbedtls_platform_zeroize( &C, sizeof( C ) ); | ||||||
|  |     mbedtls_platform_zeroize( &D, sizeof( D ) ); | ||||||
|  |     mbedtls_platform_zeroize( &E, sizeof( E ) ); | ||||||
|  |     mbedtls_platform_zeroize( &W, sizeof( W ) ); | ||||||
|  |     mbedtls_platform_zeroize( &temp, sizeof( temp ) ); | ||||||
|  | 
 | ||||||
|     return( 0 ); |     return( 0 ); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -253,6 +253,12 @@ int mbedtls_internal_sha256_process( mbedtls_sha256_context *ctx, | |||||||
|     for( i = 0; i < 8; i++ ) |     for( i = 0; i < 8; i++ ) | ||||||
|         ctx->state[i] += A[i]; |         ctx->state[i] += A[i]; | ||||||
| 
 | 
 | ||||||
|  |     /* Zeroise buffers and variables to clear sensitive data from memory. */ | ||||||
|  |     mbedtls_platform_zeroize( &A, sizeof( A ) ); | ||||||
|  |     mbedtls_platform_zeroize( &W, sizeof( W ) ); | ||||||
|  |     mbedtls_platform_zeroize( &temp1, sizeof( temp1 ) ); | ||||||
|  |     mbedtls_platform_zeroize( &temp2, sizeof( temp2 ) ); | ||||||
|  | 
 | ||||||
|     return( 0 ); |     return( 0 ); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -311,6 +311,12 @@ int mbedtls_internal_sha512_process( mbedtls_sha512_context *ctx, | |||||||
|     for( i = 0; i < 8; i++ ) |     for( i = 0; i < 8; i++ ) | ||||||
|         ctx->state[i] += A[i]; |         ctx->state[i] += A[i]; | ||||||
| 
 | 
 | ||||||
|  |     /* Zeroise buffers and variables to clear sensitive data from memory. */ | ||||||
|  |     mbedtls_platform_zeroize( &A, sizeof( A ) ); | ||||||
|  |     mbedtls_platform_zeroize( &W, sizeof( W ) ); | ||||||
|  |     mbedtls_platform_zeroize( &temp1, sizeof( temp1 ) ); | ||||||
|  |     mbedtls_platform_zeroize( &temp2, sizeof( temp2 ) ); | ||||||
|  | 
 | ||||||
|     return( 0 ); |     return( 0 ); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 gabor-mezei-arm
						gabor-mezei-arm