mailing list of musl libc
 help / color / mirror / code / Atom feed
From: William Pitcock <nenolod@dereferenced.org>
To: musl@lists.openwall.com
Cc: Hauke Mehrtens <hauke@hauke-m.de>
Subject: Re: [PATCH v2] Add getrandom syscall wrapper and getentropy function
Date: Mon, 8 Jan 2018 16:06:41 -0600	[thread overview]
Message-ID: <CA+T2pCEebvw3WC3sVUyGWzSacqXqz54q7MaVCM_7h-ViubUucg@mail.gmail.com> (raw)
In-Reply-To: <20180106220809.10078-1-hauke@hauke-m.de>

Hi,

On Sat, Jan 6, 2018 at 4:08 PM, Hauke Mehrtens <hauke@hauke-m.de> wrote:
> This syscall is available since Linux 3.17 and was also implemented in
> glibc in version 2.25 using the same interfaces.
> The getrandom function is a pure syscall wrapper liker glibc does it.
> getentropy is implemented on top of the getrandom syscall and fills the
> buffer.
>
> Currently no fallback is implemented this could be possible by using
> AT_RANDOM in the future.
> ---
>  include/sys/random.h   | 21 +++++++++++++++++++++
>  src/linux/getentropy.c | 29 +++++++++++++++++++++++++++++
>  src/linux/getrandom.c  |  7 +++++++
>  3 files changed, 57 insertions(+)
>  create mode 100644 include/sys/random.h
>  create mode 100644 src/linux/getentropy.c
>  create mode 100644 src/linux/getrandom.c
>
> diff --git a/include/sys/random.h b/include/sys/random.h
> new file mode 100644
> index 00000000..5b09e394
> --- /dev/null
> +++ b/include/sys/random.h
> @@ -0,0 +1,21 @@
> +#ifndef _SYS_RANDOM_H
> +#define _SYS_RANDOM_H
> +#ifdef __cplusplus
> +extern "C" {
> +#endif
> +
> +#define __NEED_size_t
> +#define __NEED_ssize_t
> +#include <bits/alltypes.h>
> +
> +#define GRND_NONBLOCK  0x0001
> +#define GRND_RANDOM    0x0002
> +
> +ssize_t getrandom(void *buf, size_t buflen, unsigned int flags);
> +
> +int getentropy(void *buffer, size_t length);

Function prototypes in headers should be provided without naming the arguments.

> +
> +#ifdef __cplusplus
> +}
> +#endif
> +#endif
> diff --git a/src/linux/getentropy.c b/src/linux/getentropy.c
> new file mode 100644
> index 00000000..48ca3d51
> --- /dev/null
> +++ b/src/linux/getentropy.c
> @@ -0,0 +1,29 @@
> +#include <sys/random.h>
> +#include <errno.h>
> +#include "syscall.h"
> +
> +int getentropy(void *buffer, size_t length)
> +{
> +       int ret;
> +       char *pos = buffer;
> +       size_t rem = length;
> +
> +       if (length > 256) {
> +               return __syscall_ret(-EIO);
> +       }
> +
> +       while (rem) {
> +               ret = __syscall_cp(SYS_getrandom, pos, rem, 0);
> +               if (ret == -EINTR) {
> +                       continue;
> +               } else if (ret == -EFAULT || ret == -ENOSYS) {
> +                       return __syscall_ret(ret);
> +               } else if (ret <= 0) {
> +                       return __syscall_ret(-EIO);
> +               }
> +
> +               pos += ret;
> +               rem -= ret;
> +       }
> +       return 0;
> +}
> diff --git a/src/linux/getrandom.c b/src/linux/getrandom.c
> new file mode 100644
> index 00000000..795b932c
> --- /dev/null
> +++ b/src/linux/getrandom.c
> @@ -0,0 +1,7 @@
> +#include <sys/random.h>
> +#include "syscall.h"
> +
> +ssize_t getrandom(void *buf, size_t buflen, unsigned int flags)
> +{
> +       return syscall_cp(SYS_getrandom, buf, buflen, flags);
> +}
> --
> 2.11.0
>

Otherwise this looks okay to me.

William


  reply	other threads:[~2018-01-08 22:06 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-01-06 22:08 Hauke Mehrtens
2018-01-08 22:06 ` William Pitcock [this message]
2018-01-09 18:48 ` Rich Felker
2018-01-21 13:22   ` Hauke Mehrtens

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=CA+T2pCEebvw3WC3sVUyGWzSacqXqz54q7MaVCM_7h-ViubUucg@mail.gmail.com \
    --to=nenolod@dereferenced.org \
    --cc=hauke@hauke-m.de \
    --cc=musl@lists.openwall.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.vuxu.org/mirror/musl/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).