Skip to content

Latest commit

 

History

History
59 lines (42 loc) · 1.4 KB

cprng_draw.md

File metadata and controls

59 lines (42 loc) · 1.4 KB

mx_cprng_draw

NAME

mx_cprng_draw - Draw from the kernel's CPRNG

SYNOPSIS

#include <magenta/syscalls.h>

mx_status_t mx_cprng_draw(void* buffer, size_t len, size_t* actual);

DESCRIPTION

mx_cprng_draw() draws random bytes from the kernel CPRNG. This data should be suitable for cryptographic applications. It will return at most MX_CPRNG_DRAW_MAX_LEN bytes at a time.

RETURN VALUE

mx_cprng_draw() returns MX_OK and the number of random bytes drawn into buffer (via *actual) on success.

ERRORS

MX_ERR_INVALID_ARGS len is too large, or buffer or actual is not a valid userspace pointer.

NOTES

There are no other error conditions. If its arguments are valid, mx_cprng_draw() will succeed.

EXAMPLES

// Draw |len| bytes of cryptographically secure random data into |buf|.
// It is not recommended to call this with large lengths.  If you need many
// bytes, you likely want a usermode CPRNG seeded by this function.
mx_status_t draw(char* buf, size_t len) {
    // This loop is necessary to deal with short reads from the kernel.
    while (len > 0) {
        size_t actual;
        mx_status_t status = mx_cprng_draw(buf, min(len, MX_CPRNG_DRAW_MAX_LEN), &actual);
        if (status != MX_OK) {
            return status;
        }
        buf += actual;
        len -= actual;
    }
    return MX_OK;
}

BUGS

This syscall should be rate-limited.