mirror of
https://github.com/yuzu-emu/mbedtls
synced 2024-11-24 16:48:29 +00:00
Merge remote-tracking branch 'upstream-public/pr/2117' into development
This commit is contained in:
commit
c27e3420b9
2 changed files with 12 additions and 48 deletions
|
@ -40,6 +40,9 @@ Bugfix
|
||||||
* Fix for Clang, which was reporting a warning for the bignum.c inline
|
* Fix for Clang, which was reporting a warning for the bignum.c inline
|
||||||
assembly for AMD64 targets creating string literals greater than those
|
assembly for AMD64 targets creating string literals greater than those
|
||||||
permitted by the ISO C99 standard. Found by Aaron Jones. Fixes #482.
|
permitted by the ISO C99 standard. Found by Aaron Jones. Fixes #482.
|
||||||
|
* Fix runtime error in `mbedtls_platform_entropy_poll()` when run
|
||||||
|
through qemu user emulation. Reported and fix suggested by randombit
|
||||||
|
in #1212. Fixes #1212.
|
||||||
|
|
||||||
= mbed TLS 2.14.0 branch released 2018-11-19
|
= mbed TLS 2.14.0 branch released 2018-11-19
|
||||||
|
|
||||||
|
|
|
@ -99,6 +99,7 @@ int mbedtls_platform_entropy_poll( void *data, unsigned char *output, size_t len
|
||||||
#include <sys/syscall.h>
|
#include <sys/syscall.h>
|
||||||
#if defined(SYS_getrandom)
|
#if defined(SYS_getrandom)
|
||||||
#define HAVE_GETRANDOM
|
#define HAVE_GETRANDOM
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
static int getrandom_wrapper( void *buf, size_t buflen, unsigned int flags )
|
static int getrandom_wrapper( void *buf, size_t buflen, unsigned int flags )
|
||||||
{
|
{
|
||||||
|
@ -108,47 +109,8 @@ static int getrandom_wrapper( void *buf, size_t buflen, unsigned int flags )
|
||||||
memset( buf, 0, buflen );
|
memset( buf, 0, buflen );
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return( syscall( SYS_getrandom, buf, buflen, flags ) );
|
return( syscall( SYS_getrandom, buf, buflen, flags ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
#include <sys/utsname.h>
|
|
||||||
/* Check if version is at least 3.17.0 */
|
|
||||||
static int check_version_3_17_plus( void )
|
|
||||||
{
|
|
||||||
int minor;
|
|
||||||
struct utsname un;
|
|
||||||
const char *ver;
|
|
||||||
|
|
||||||
/* Get version information */
|
|
||||||
uname(&un);
|
|
||||||
ver = un.release;
|
|
||||||
|
|
||||||
/* Check major version; assume a single digit */
|
|
||||||
if( ver[0] < '3' || ver[0] > '9' || ver [1] != '.' )
|
|
||||||
return( -1 );
|
|
||||||
|
|
||||||
if( ver[0] - '0' > 3 )
|
|
||||||
return( 0 );
|
|
||||||
|
|
||||||
/* Ok, so now we know major == 3, check minor.
|
|
||||||
* Assume 1 or 2 digits. */
|
|
||||||
if( ver[2] < '0' || ver[2] > '9' )
|
|
||||||
return( -1 );
|
|
||||||
|
|
||||||
minor = ver[2] - '0';
|
|
||||||
|
|
||||||
if( ver[3] >= '0' && ver[3] <= '9' )
|
|
||||||
minor = 10 * minor + ver[3] - '0';
|
|
||||||
else if( ver [3] != '.' )
|
|
||||||
return( -1 );
|
|
||||||
|
|
||||||
if( minor < 17 )
|
|
||||||
return( -1 );
|
|
||||||
|
|
||||||
return( 0 );
|
|
||||||
}
|
|
||||||
static int has_getrandom = -1;
|
|
||||||
#endif /* SYS_getrandom */
|
#endif /* SYS_getrandom */
|
||||||
#endif /* __linux__ */
|
#endif /* __linux__ */
|
||||||
|
|
||||||
|
@ -159,22 +121,21 @@ int mbedtls_platform_entropy_poll( void *data,
|
||||||
{
|
{
|
||||||
FILE *file;
|
FILE *file;
|
||||||
size_t read_len;
|
size_t read_len;
|
||||||
|
int ret;
|
||||||
((void) data);
|
((void) data);
|
||||||
|
|
||||||
#if defined(HAVE_GETRANDOM)
|
#if defined(HAVE_GETRANDOM)
|
||||||
if( has_getrandom == -1 )
|
ret = getrandom_wrapper( output, len, 0 );
|
||||||
has_getrandom = ( check_version_3_17_plus() == 0 );
|
if( ret >= 0 )
|
||||||
|
|
||||||
if( has_getrandom )
|
|
||||||
{
|
{
|
||||||
int ret;
|
|
||||||
|
|
||||||
if( ( ret = getrandom_wrapper( output, len, 0 ) ) < 0 )
|
|
||||||
return( MBEDTLS_ERR_ENTROPY_SOURCE_FAILED );
|
|
||||||
|
|
||||||
*olen = ret;
|
*olen = ret;
|
||||||
return( 0 );
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
else if( errno != ENOSYS )
|
||||||
|
return( MBEDTLS_ERR_ENTROPY_SOURCE_FAILED );
|
||||||
|
/* Fall through if the system call isn't known. */
|
||||||
|
#else
|
||||||
|
((void) ret);
|
||||||
#endif /* HAVE_GETRANDOM */
|
#endif /* HAVE_GETRANDOM */
|
||||||
|
|
||||||
*olen = 0;
|
*olen = 0;
|
||||||
|
|
Loading…
Reference in a new issue