zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 14a954f3507d97e1a6e6c995f3e4d3db76c64b3d (tree)
parent b23a87953a7a4030af3d9acf8deacb85162dd275
Author: nia <nia@netbsd.org>
Date:   Fri,  1 May 2020 17:22:27 +0100

Add arc4random_buf() in NetBSD libc, use it to implement getrandom()

Diffstat:
Mlib/std/c/netbsd.zig | 1+
Mlib/std/os.zig | 4++++
2 files changed, 5 insertions(+), 0 deletions(-)

diff --git a/lib/std/c/netbsd.zig b/lib/std/c/netbsd.zig @@ -9,6 +9,7 @@ pub const _errno = __errno; pub const dl_iterate_phdr_callback = extern fn (info: *dl_phdr_info, size: usize, data: ?*c_void) c_int; pub extern "c" fn dl_iterate_phdr(callback: dl_iterate_phdr_callback, data: ?*c_void) c_int; +pub extern "c" fn arc4random_buf(buf: [*]u8, len: usize) void; pub extern "c" fn __fstat50(fd: fd_t, buf: *Stat) c_int; pub extern "c" fn __stat50(path: [*:0]const u8, buf: *Stat) c_int; pub extern "c" fn __clock_gettime50(clk_id: c_int, tp: *timespec) c_int; diff --git a/lib/std/os.zig b/lib/std/os.zig @@ -153,6 +153,10 @@ pub fn getrandom(buffer: []u8) GetRandomError!void { } return; } + if (builtin.os.tag == .netbsd) { + netbsd.arc4random_buf(buffer.ptr, buffer.len); + return; + } if (builtin.os.tag == .wasi) { switch (wasi.random_get(buffer.ptr, buffer.len)) { 0 => return,