Merge remote-tracking branch 'n8sh/getrandom-syscall'

Fix #18.
This commit is contained in:
Eugen Wissner 2018-02-22 05:25:59 +01:00
commit af942116e4
2 changed files with 13 additions and 10 deletions

View File

@ -9,6 +9,10 @@
"targetType": "library",
"dependencies-linux": {
"mir-linux-kernel": "~>1.0.0",
},
"configurations": [
{
"name": "library",

View File

@ -117,7 +117,8 @@ else version (Solaris)
version (linux)
{
extern (C) long syscall(long number, ...) nothrow @system @nogc;
import core.stdc.config : c_long;
extern (C) c_long syscall(c_long number, ...) nothrow @system @nogc;
/**
* Uses getrandom system call.
@ -158,7 +159,8 @@ version (linux)
do
{
// int getrandom(void *buf, size_t buflen, unsigned int flags);
auto length = syscall(318, output.ptr, output.length, 0);
import mir.linux._asm.unistd : NR_getrandom;
auto length = syscall(NR_getrandom, output.ptr, output.length, 0);
Nullable!ubyte ret;
if (length >= 0)
@ -169,9 +171,7 @@ version (linux)
}
}
version (X86_64)
{
private unittest
@nogc @system unittest
{
auto entropy = defaultAllocator.make!Entropy();
ubyte[blockSize] output;
@ -180,7 +180,6 @@ version (linux)
defaultAllocator.dispose(entropy);
}
}
}
else version (SecureARC4Random)
{
private extern (C) void arc4random_buf(scope void* buf, size_t nbytes) nothrow @nogc @system;