]> Cypherpunks repositories - gostls13.git/commit
internal/syscall/unix: allow calling getrandom(..., 0, ...)
authorJason A. Donenfeld <Jason@zx2c4.com>
Tue, 24 Sep 2024 01:06:38 +0000 (03:06 +0200)
committerGopher Robot <gobot@golang.org>
Wed, 25 Sep 2024 23:56:00 +0000 (23:56 +0000)
commit80143607f06fd6410700e9764cfea9aaac9c311c
tree99ef99e40111c67150513c960eb83ca027fc9478
parent3d6173aa120e64a31438f9fb717afb1b9f6708dd
internal/syscall/unix: allow calling getrandom(..., 0, ...)

Calling getrandom() with a zero length is actually valid and useful:

- Calling getrandom(..., 0, 0) will block until the RNG is initialized.
- Calling getrandom(..., 0, GRND_NONBLOCK) will query whether the RNG
  is initialized.

So instead of short circuiting execution for these circumstances, pass
this through to the syscall.

Change-Id: I15178f087908a2d8be6c020a1ef800cc0a074742
Reviewed-on: https://go-review.googlesource.com/c/go/+/615315
Run-TryBot: Jason Donenfeld <Jason@zx2c4.com>
Reviewed-by: Filippo Valsorda <filippo@golang.org>
Auto-Submit: Jason Donenfeld <Jason@zx2c4.com>
Reviewed-by: Michael Pratt <mpratt@google.com>
Reviewed-by: Cuong Manh Le <cuong.manhle.vn@gmail.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Michael Knyszek <mknyszek@google.com>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
src/internal/syscall/unix/getrandom.go