mirror of https://github.com/aria2/aria2
Merge pull request #823 from aria2/fix-getrandom-assertion-failure
Fix assertion failure in SimpleRandomizer::getRandomBytespull/836/head
commit
6abf2388cc
|
@ -101,18 +101,7 @@ void SimpleRandomizer::getRandomBytes(unsigned char* buf, size_t len)
|
||||||
static bool have_random_support = true;
|
static bool have_random_support = true;
|
||||||
if (have_random_support) {
|
if (have_random_support) {
|
||||||
auto rv = getrandom_linux(buf, len);
|
auto rv = getrandom_linux(buf, len);
|
||||||
if (rv != -1
|
if (rv != -1) {
|
||||||
#ifdef ENOSYS
|
|
||||||
/* If the system does not know ENOSYS at this point, just leave the
|
|
||||||
* check out. If the call failed, we'll not take this branch at all
|
|
||||||
* and disable support below.
|
|
||||||
*/
|
|
||||||
|| errno != ENOSYS
|
|
||||||
#endif
|
|
||||||
) {
|
|
||||||
if (rv < -1) {
|
|
||||||
A2_LOG_ERROR(fmt("Failed to produce randomness: %d", errno));
|
|
||||||
}
|
|
||||||
// getrandom is not supposed to fail, ever, so, we want to assert here.
|
// getrandom is not supposed to fail, ever, so, we want to assert here.
|
||||||
assert(rv >= 0 && (size_t)rv == len);
|
assert(rv >= 0 && (size_t)rv == len);
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in New Issue