mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2025-07-30 22:43:08 +03:00
Zeroize temporary heap buffers used in PSA operations
Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com>
This commit is contained in:
2
ChangeLog.d/psa-zeroize.txt
Normal file
2
ChangeLog.d/psa-zeroize.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
Security
|
||||||
|
* Zeroize temporary heap buffers used in PSA operations.
|
@ -6171,16 +6171,22 @@ psa_status_t psa_crypto_local_input_alloc(const uint8_t *input, size_t input_len
|
|||||||
return PSA_SUCCESS;
|
return PSA_SUCCESS;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
mbedtls_free(local_input->buffer);
|
if (local_input->buffer != NULL) {
|
||||||
local_input->buffer = NULL;
|
mbedtls_platform_zeroize(local_input->buffer, local_input->length);
|
||||||
|
mbedtls_free(local_input->buffer);
|
||||||
|
local_input->buffer = NULL;
|
||||||
|
}
|
||||||
local_input->length = 0;
|
local_input->length = 0;
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
void psa_crypto_local_input_free(psa_crypto_local_input_t *local_input)
|
void psa_crypto_local_input_free(psa_crypto_local_input_t *local_input)
|
||||||
{
|
{
|
||||||
mbedtls_free(local_input->buffer);
|
if (local_input->buffer != NULL) {
|
||||||
local_input->buffer = NULL;
|
mbedtls_platform_zeroize(local_input->buffer, local_input->length);
|
||||||
|
mbedtls_free(local_input->buffer);
|
||||||
|
local_input->buffer = NULL;
|
||||||
|
}
|
||||||
local_input->length = 0;
|
local_input->length = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -6223,8 +6229,11 @@ psa_status_t psa_crypto_local_output_free(psa_crypto_local_output_t *local_outpu
|
|||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
mbedtls_free(local_output->buffer);
|
if (local_output->buffer != NULL) {
|
||||||
local_output->buffer = NULL;
|
mbedtls_platform_zeroize(local_output->buffer, local_output->length);
|
||||||
|
mbedtls_free(local_output->buffer);
|
||||||
|
local_output->buffer = NULL;
|
||||||
|
}
|
||||||
local_output->length = 0;
|
local_output->length = 0;
|
||||||
|
|
||||||
return PSA_SUCCESS;
|
return PSA_SUCCESS;
|
||||||
|
Reference in New Issue
Block a user