mirror of
				https://github.com/cuberite/polarssl.git
				synced 2025-10-25 00:32:44 -04:00 
			
		
		
		
	psa: Use psa_status_t in psa_key_agreement_ecdh()
Use the PSA-native status type in psa_key_agreement_ecdh() in preparation for us calling PSA functions (and not just Mbed TLS functions) and still being able to return a psa_status_t (without having to translate it to a Mbed TLS error and then back again).
This commit is contained in:
		
							parent
							
								
									25384a236e
								
							
						
					
					
						commit
						97271b37c8
					
				| @ -4044,12 +4044,13 @@ static psa_status_t psa_key_agreement_ecdh( const uint8_t *peer_key, | |||||||
|     mbedtls_pk_context pk; |     mbedtls_pk_context pk; | ||||||
|     mbedtls_ecp_keypair *their_key = NULL; |     mbedtls_ecp_keypair *their_key = NULL; | ||||||
|     mbedtls_ecdh_context ecdh; |     mbedtls_ecdh_context ecdh; | ||||||
|     int ret; |     psa_status_t status; | ||||||
|     mbedtls_ecdh_init( &ecdh ); |     mbedtls_ecdh_init( &ecdh ); | ||||||
|     mbedtls_pk_init( &pk ); |     mbedtls_pk_init( &pk ); | ||||||
| 
 | 
 | ||||||
|     ret = mbedtls_pk_parse_public_key( &pk, peer_key, peer_key_length ); |     status = mbedtls_to_psa_error( | ||||||
|     if( ret != 0 ) |         mbedtls_pk_parse_public_key( &pk, peer_key, peer_key_length ) ); | ||||||
|  |     if( status != PSA_SUCCESS ) | ||||||
|         goto exit; |         goto exit; | ||||||
|     switch( mbedtls_pk_get_type( &pk ) ) |     switch( mbedtls_pk_get_type( &pk ) ) | ||||||
|     { |     { | ||||||
| @ -4057,33 +4058,36 @@ static psa_status_t psa_key_agreement_ecdh( const uint8_t *peer_key, | |||||||
|         case MBEDTLS_PK_ECKEY_DH: |         case MBEDTLS_PK_ECKEY_DH: | ||||||
|             break; |             break; | ||||||
|         default: |         default: | ||||||
|             ret = MBEDTLS_ERR_ECP_INVALID_KEY; |             status = PSA_ERROR_INVALID_ARGUMENT; | ||||||
|             goto exit; |             goto exit; | ||||||
|     } |     } | ||||||
|     their_key = mbedtls_pk_ec( pk ); |     their_key = mbedtls_pk_ec( pk ); | ||||||
|     if( their_key->grp.id != our_key->grp.id ) |     if( their_key->grp.id != our_key->grp.id ) | ||||||
|     { |     { | ||||||
|         ret = MBEDTLS_ERR_ECP_INVALID_KEY; |         status = PSA_ERROR_INVALID_ARGUMENT; | ||||||
|         goto exit; |         goto exit; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     ret = mbedtls_ecdh_get_params( &ecdh, their_key, MBEDTLS_ECDH_THEIRS ); |     status = mbedtls_to_psa_error( | ||||||
|     if( ret != 0 ) |         mbedtls_ecdh_get_params( &ecdh, their_key, MBEDTLS_ECDH_THEIRS ) ); | ||||||
|  |     if( status != PSA_SUCCESS ) | ||||||
|         goto exit; |         goto exit; | ||||||
|     ret = mbedtls_ecdh_get_params( &ecdh, our_key, MBEDTLS_ECDH_OURS ); |     status = mbedtls_to_psa_error( | ||||||
|     if( ret != 0 ) |         mbedtls_ecdh_get_params( &ecdh, our_key, MBEDTLS_ECDH_OURS ) ); | ||||||
|  |     if( status != PSA_SUCCESS ) | ||||||
|         goto exit; |         goto exit; | ||||||
| 
 | 
 | ||||||
|     ret = mbedtls_ecdh_calc_secret( &ecdh, |     status = mbedtls_to_psa_error( | ||||||
|                                     shared_secret_length, |         mbedtls_ecdh_calc_secret( &ecdh, | ||||||
|                                     shared_secret, shared_secret_size, |                                   shared_secret_length, | ||||||
|                                     mbedtls_ctr_drbg_random, |                                   shared_secret, shared_secret_size, | ||||||
|                                     &global_data.ctr_drbg ); |                                   mbedtls_ctr_drbg_random, | ||||||
|  |                                   &global_data.ctr_drbg ) ); | ||||||
| 
 | 
 | ||||||
| exit: | exit: | ||||||
|     mbedtls_pk_free( &pk ); |     mbedtls_pk_free( &pk ); | ||||||
|     mbedtls_ecdh_free( &ecdh ); |     mbedtls_ecdh_free( &ecdh ); | ||||||
|     return( mbedtls_to_psa_error( ret ) ); |     return( status ); | ||||||
| } | } | ||||||
| #endif /* MBEDTLS_ECDH_C */ | #endif /* MBEDTLS_ECDH_C */ | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Jaeden Amero
						Jaeden Amero