| // Copyright 2018 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| |
| // Package randutil contains internal randomness utilities for various |
| // crypto packages. |
| package randutil |
| |
| import ( |
| "io" |
| "math/rand/v2" |
| ) |
| |
| // MaybeReadByte reads a single byte from r with 50% probability. This is used |
| // to ensure that callers do not depend on non-guaranteed behaviour, e.g. |
| // assuming that rsa.GenerateKey is deterministic w.r.t. a given random stream. |
| // |
| // This does not affect tests that pass a stream of fixed bytes as the random |
| // source (e.g. a zeroReader). |
| func MaybeReadByte(r io.Reader) { |
| if rand.Uint64()&1 == 1 { |
| return |
| } |
| var buf [1]byte |
| r.Read(buf[:]) |
| } |