Zeroize tmp buf in ctr_drbg_write_seed_file()
diff --git a/library/ctr_drbg.c b/library/ctr_drbg.c
index 7828c4e..a31f7b8 100644
--- a/library/ctr_drbg.c
+++ b/library/ctr_drbg.c
@@ -434,9 +434,9 @@
else
ret = 0;
+exit:
mbedtls_zeroize( buf, sizeof( buf ) );
-exit:
fclose( f );
return( ret );
}
@@ -456,8 +456,12 @@
fseek( f, 0, SEEK_SET );
if( n > MBEDTLS_CTR_DRBG_MAX_INPUT )
- ret = MBEDTLS_ERR_CTR_DRBG_INPUT_TOO_BIG;
- else if( fread( buf, 1, n, f ) != n )
+ {
+ fclose( f );
+ return( MBEDTLS_ERR_CTR_DRBG_INPUT_TOO_BIG );
+ }
+
+ if( fread( buf, 1, n, f ) != n )
ret = MBEDTLS_ERR_CTR_DRBG_FILE_IO_ERROR;
else
mbedtls_ctr_drbg_update( ctx, buf, n );