mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2025-03-26 20:25:07 +00:00
Fix memory corruption in rsa sign/verify programs
backport from d74c697
see #210
This commit is contained in:
parent
e217ceea38
commit
6432c7e782
|
@ -11,6 +11,7 @@ Bugfix
|
||||||
* Fix -Wshadow warnings (found by hnrkp) (#240)
|
* Fix -Wshadow warnings (found by hnrkp) (#240)
|
||||||
* Fix unused function warning when using MBEDTLS_MDx_ALT or
|
* Fix unused function warning when using MBEDTLS_MDx_ALT or
|
||||||
MBEDTLS_SHAxxx_ALT (found by Henrik) (#239)
|
MBEDTLS_SHAxxx_ALT (found by Henrik) (#239)
|
||||||
|
* Fix memory corruption in pkey programs (found by yankuncheng) (#210)
|
||||||
|
|
||||||
= mbed TLS 1.3.12 released 2015-08-11
|
= mbed TLS 1.3.12 released 2015-08-11
|
||||||
|
|
||||||
|
|
|
@ -60,6 +60,7 @@ int main( int argc, char *argv[] )
|
||||||
rsa_context rsa;
|
rsa_context rsa;
|
||||||
unsigned char hash[20];
|
unsigned char hash[20];
|
||||||
unsigned char buf[POLARSSL_MPI_MAX_SIZE];
|
unsigned char buf[POLARSSL_MPI_MAX_SIZE];
|
||||||
|
char filename[512];
|
||||||
|
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
|
||||||
|
@ -133,14 +134,14 @@ int main( int argc, char *argv[] )
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Write the signature into <filename>-sig.txt
|
* Write the signature into <filename>.sig
|
||||||
*/
|
*/
|
||||||
memcpy( argv[1] + strlen( argv[1] ), ".sig", 5 );
|
snprintf( filename, sizeof( filename ), "%s.sig", argv[1] );
|
||||||
|
|
||||||
if( ( f = fopen( argv[1], "wb+" ) ) == NULL )
|
if( ( f = fopen( filename, "wb+" ) ) == NULL )
|
||||||
{
|
{
|
||||||
ret = 1;
|
ret = 1;
|
||||||
polarssl_printf( " failed\n ! Could not create %s\n\n", argv[1] );
|
polarssl_printf( " failed\n ! Could not create %s\n\n", filename );
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -150,7 +151,7 @@ int main( int argc, char *argv[] )
|
||||||
|
|
||||||
fclose( f );
|
fclose( f );
|
||||||
|
|
||||||
polarssl_printf( "\n . Done (created \"%s\")\n\n", argv[1] );
|
polarssl_printf( "\n . Done (created \"%s\")\n\n", filename );
|
||||||
|
|
||||||
exit:
|
exit:
|
||||||
|
|
||||||
|
|
|
@ -59,6 +59,7 @@ int main( int argc, char *argv[] )
|
||||||
rsa_context rsa;
|
rsa_context rsa;
|
||||||
unsigned char hash[20];
|
unsigned char hash[20];
|
||||||
unsigned char buf[POLARSSL_MPI_MAX_SIZE];
|
unsigned char buf[POLARSSL_MPI_MAX_SIZE];
|
||||||
|
char filename[512];
|
||||||
|
|
||||||
ret = 1;
|
ret = 1;
|
||||||
if( argc != 2 )
|
if( argc != 2 )
|
||||||
|
@ -99,17 +100,15 @@ int main( int argc, char *argv[] )
|
||||||
* Extract the RSA signature from the text file
|
* Extract the RSA signature from the text file
|
||||||
*/
|
*/
|
||||||
ret = 1;
|
ret = 1;
|
||||||
i = strlen( argv[1] );
|
snprintf( filename, sizeof( filename ), "%s.sig", argv[1] );
|
||||||
memcpy( argv[1] + i, ".sig", 5 );
|
|
||||||
|
|
||||||
if( ( f = fopen( argv[1], "rb" ) ) == NULL )
|
if( ( f = fopen( filename, "rb" ) ) == NULL )
|
||||||
{
|
{
|
||||||
polarssl_printf( "\n ! Could not open %s\n\n", argv[1] );
|
polarssl_printf( "\n ! Could not open %s\n\n", filename );
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
argv[1][i] = '\0', i = 0;
|
i = 0;
|
||||||
|
|
||||||
while( fscanf( f, "%02X", &c ) > 0 &&
|
while( fscanf( f, "%02X", &c ) > 0 &&
|
||||||
i < (int) sizeof( buf ) )
|
i < (int) sizeof( buf ) )
|
||||||
buf[i++] = (unsigned char) c;
|
buf[i++] = (unsigned char) c;
|
||||||
|
|
Loading…
Reference in a new issue