mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2024-11-26 00:05:36 +01:00
x509: trailing bytes in DER: fix bug
Fix bug in mbedtls_x509_crt_parse that caused trailing extra data in the buffer after DER certificates to be included in the raw representation. #377
This commit is contained in:
parent
e154f95e03
commit
cc0e49ddde
@ -11,6 +11,8 @@ Bugfix
|
|||||||
* Fix issue in Makefile that prevented building using armar. #386
|
* Fix issue in Makefile that prevented building using armar. #386
|
||||||
* Fix memory leak that occured only when ECJPAKE was enabled and ECDHE and
|
* Fix memory leak that occured only when ECJPAKE was enabled and ECDHE and
|
||||||
ECDSA was disabled in config.h . The leak didn't occur by default.
|
ECDSA was disabled in config.h . The leak didn't occur by default.
|
||||||
|
* Fix bug in mbedtls_x509_crt_parse that caused trailing extra data in the
|
||||||
|
buffer after DER certificates to be included in the raw representation.
|
||||||
|
|
||||||
Changes
|
Changes
|
||||||
* On ARM platforms, when compiling with -O0 with GCC, Clang or armcc5,
|
* On ARM platforms, when compiling with -O0 with GCC, Clang or armcc5,
|
||||||
|
@ -680,14 +680,9 @@ static int x509_crt_parse_der_core( mbedtls_x509_crt *crt, const unsigned char *
|
|||||||
if( crt == NULL || buf == NULL )
|
if( crt == NULL || buf == NULL )
|
||||||
return( MBEDTLS_ERR_X509_BAD_INPUT_DATA );
|
return( MBEDTLS_ERR_X509_BAD_INPUT_DATA );
|
||||||
|
|
||||||
p = mbedtls_calloc( 1, len = buflen );
|
// Use the original buffer until we figure out actual length
|
||||||
if( p == NULL )
|
p = (unsigned char*) buf;
|
||||||
return( MBEDTLS_ERR_X509_ALLOC_FAILED );
|
len = buflen;
|
||||||
|
|
||||||
memcpy( p, buf, buflen );
|
|
||||||
|
|
||||||
crt->raw.p = p;
|
|
||||||
crt->raw.len = len;
|
|
||||||
end = p + len;
|
end = p + len;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -711,6 +706,18 @@ static int x509_crt_parse_der_core( mbedtls_x509_crt *crt, const unsigned char *
|
|||||||
}
|
}
|
||||||
crt_end = p + len;
|
crt_end = p + len;
|
||||||
|
|
||||||
|
// Create and populate a new buffer for the raw field
|
||||||
|
crt->raw.len = crt_end - buf;
|
||||||
|
crt->raw.p = p = mbedtls_calloc( 1, crt->raw.len );
|
||||||
|
if( p == NULL )
|
||||||
|
return( MBEDTLS_ERR_X509_ALLOC_FAILED );
|
||||||
|
|
||||||
|
memcpy( p, buf, crt->raw.len );
|
||||||
|
|
||||||
|
// Direct pointers to the new buffer
|
||||||
|
p += crt->raw.len - len;
|
||||||
|
end = crt_end = p + len;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* TBSCertificate ::= SEQUENCE {
|
* TBSCertificate ::= SEQUENCE {
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user