All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
- Use Edition 2024 and MSRV 1.85 #749
0.3.4 - 2025-10-14
Now, when the wasm_js feature is enabled, the wasm_js backend will be used
by default. Users of wasm32-unknown-unknown targeting JavaScript environments
like the Web and Node.js will no longer need to specify:
--cfg getrandom_backend="wasm_js"
in RUSTFLAGS for the crate to compile. They can now simple enable a feature.
Note: this should not affect non-JS users of the wasm32-unknown-unknown
target. Using --cfg getrandom_backend will still override the source of
randomness even if the wasm_js feature is enabled. This includes
--cfg getrandom_backend=custom and --cfg getrandom_backend=unsupported.
For more information, see the discussions in #671, #675, and #730.
- Implement Memory Sanitizer unpoisoning more precisely #678
- Relax MSRV for the
linux_rawopt-in backend on ARM targets #688 - Use
getrandomsyscall on all RISC-V Linux targets #699 - Replaced
wasidependency withwasip2#721 - Enable
wasm_jsbackend by default if thewasm_jsfeature is enabled #730
- Unstable
rustc-dep-of-stdcrate feature #694
0.3.3 - 2025-05-09
- Error handling in WASI p1 #661
0.3.2 - 2025-03-17
efi_rngopt-in backend #570linux_rawopt-in backend #572.cargo/config.tomlexample in the crate-level docs #591getrandom_test_linux_without_fallbackconfiguration flag to test that file fallback is not triggered in thelinux_android_with_fallbackbackend #605- Built-in support for
*-linux-nonetargets #618 - Cygwin support #626
- Update
wasidependency to v0.14 #594 - Add
#[inline]attribute to the inner functions #596 - Update WASI and Emscripten links in the crate-level docs #597
- Do not use
dlsymon MUSL targets in thelinux_android_with_fallbackbackend #602 - Remove
linux_android.rsand usegetrandom.rsinstead #603 - Always use
RtlGenRandomon Windows targets when compiling with pre-1.78 Rust #610 - Internal representation of the
Errortype #614 - Remove
windows-targetsdependency and useraw-dylibdirectly #627
Error::INTERNAL_STARTandError::CUSTOM_STARTassociated constants #614
0.3.1 - 2025-01-28
- Build error on Android #588
0.3.0 - 2025-01-25
- Bump MSRV to 1.63 #542
- Rename
getrandomandgetrandom_uninitfunctions tofillandfill_uninitrespectively #532
wasm32-wasitarget support (usewasm32-wasip1orwasm32-wasip2instead) #499linux_disable_fallback,rdrand,js,test-in-browser, andcustomcrate features in favor of configuration flags #504register_custom_getrandom!macro #504- Implementation of
From<NonZeroU32>forErrorandError::codemethod #507 - Internet Explorer 11 support #554
- Target-specific associated
Errorconstants #562
- Use
ProcessPrngon Windows 10 and up, and useRtlGenRandomon older Windows versions #415 - Do not use locale-specific
strerror_rfor retrieving error code descriptions #440 - Avoid assuming
usizeis the native word size in therdrandbackend #442 - Do not read from
errnowhenlibcdid not indicate error on Solaris #448 - Switch from
libpthread's mutex tofutexon Linux and tonanosleep-based wait loop on other targets in theuse_filebackend #490 - Do not retry on
EAGAINwhile polling/dev/randomon Linux #522 - Remove separate codepath for Node.js in the
wasm_jsbackend (bumps minimum supported Node.js version to v19) #557 - Use
js_namespacein thewasm_jsbackend #559
wasm32-wasip1andwasm32-wasip2support #499getrandom_backendconfiguration flag for selection of opt-in backends #504Error::new_custommethod #507rndropt-in backend #512- Automatic MemorySanitizer support #521 #571
u32andu64functions for generating random values of the respective type #544wasm32v1-nonesupport in thewasm_jsbackend #560wasm_jscrate feature which allows users to enable thewasm_jsopt-in backend #574
- NetBSD fallback code based on
KERN_ARND#555
0.2.16 - 2025-04-22
0.2.15 - 2024-05-06
- Apple visionOS support #410
- Use
libc::getrandomon DragonflyBSD, FreeBSD, illumos, and Solaris #411 #416 #417 #420 - Unify
libc::getentropy-based implementations #418
0.2.14 - 2024-04-08
- Enable
/dev/urandomfallback for MUSL-based Linux targets #408
0.2.13 - 2024-04-06
linux_disable_fallbackcrate feature to disable/dev/urandom-based fallback on Linux and Android targets. Enabling this feature bumps minimum supported Linux kernel version to 3.17 and Android API level to 23 (Marshmallow). #396
- Disable
/dev/urandomfallback for Linux targets outside of the followingtarget_arches:aarch64,arm,powerpc,powerpc64,s390x,x86,x86_64#396 - Do not catch
EPERMerror code on Android while checking availability of thegetrandomsyscall #396
0.2.12 - 2024-01-09
- Custom backend for targets without atomics #385
- Improve robustness of the Hermit backend and
sys_fill_exact#386 - Raise minimum supported Apple OS versions to macOS 10.12 and iOS 10 #388
- Document platform support policy #387
0.2.11 - 2023-11-08
- GNU/Hurd support #370
0.2.10 - 2023-06-06
- Support for PS Vita (
armv7-sony-vita-newlibeabihf) #359
- Use getentropy from libc on Emscripten targets #362
0.2.9 - 2023-04-06
- AIX support #282
getrandom_uninitfunction #291wasm64-unknown-unknownsupport #303- tvOS and watchOS support #317
- QNX/nto support #325
- Support for
getrandomsyscall on NetBSD ≥ 10.0 #331 RtlGenRandomfallback for non-UWP Windows #337
- Update MSRV to 1.36 #291
- Solaris/OpenBSD/Dragonfly build #301
- Update MSRV to 1.36 #291
- Use getentropy on Emscripten #307
- Solaris: consistently use
/dev/randomsource #310 - Move 3ds selection above rdrand/js/custom fallback #312
- Remove buffer zeroing from Node.js implementation #315
- Use
openinstead ofopen64#326 - Remove #cfg from bsd_arandom.rs #332
- Hermit: use
sys_read_entropysyscall #333 - Eliminate potential panic in sys_fill_exact #334
- rdrand: Remove checking for 0 and !0 and instead check CPU family and do a self-test #335
- Move
__getrandom_customdefinition into a const block #344 - Switch the custom backend to Rust ABI #347
0.2.8 - 2022-10-20
- The Web Cryptography API will now be preferred on
wasm32-unknown-unknownwhen using the"js"feature, even on Node.js #284 #295
- Added benchmarks to track buffer initialization cost #272
- Use
$crateinregister_custom_getrandom!#270
- Add information about enabling
"js"feature #280 - Fix link to
wasm-bindgen#278 - Document the varied implementations for underlying randomness sources #276
0.2.7 - 2022-06-14
- Update
wasidependency to0.11#253
- Use
AtomicPtrinstead ofAtomicUsizefor Strict Provenance compatibility. #263
0.2.6 - 2022-03-28
- Nintendo 3DS (
armv6k-nintendo-3ds) support #248
- Retry
openwhen interrupted #252
0.2.5 - 2022-02-22
- ESP-IDF targets (
*‑espidf) support #245
0.2.4 - 2021-12-13
- Use explicit imports in the
jsbackend #220 - Use
/dev/urandomon Redox instead ofrand:#222 - Use
NonZeroU32::new_uncheckedto convert wasi error #233
0.2.3 - 2021-04-10
- Replace build.rs with link attributes. #205
- Add support for getrandom syscall on DragonFly BSD. #210
- Improve Node.js detection. #215
0.2.2 - 2021-01-19
- Forward
rustc-dep-of-stdto dependencies. #198 - Highlight feature-dependent functionality in documentation using the
doc_cfgfeature. #200
0.2.1 - 2021-01-03
- Multithreaded WASM support. #165
0.2.0 - 2020-09-10
The following (off by default) Cargo features have been added:
"rdrand"- use the RDRAND instruction onno_stdx86/x86_64targets #133"js"- use JavaScript calls onwasm32-unknown-unknown#149- Replaces the
stdwebandwasm-bindgenfeatures (which are removed)
- Replaces the
"custom"- allows a user to specify a custom implementation #109
- Unsupported targets no longer compile #107
- Change/Add
Errorconstants #120 - Only impl
stdtraits when the"std"Cargo feature is specified #106 - Remove official support for Hermit, L4Re, and UEFI #133
- Remove optional
"log"dependency #131 - Update minimum supported Linux kernel to 2.6.32 #153
- Update MSRV to 1.34 #159
0.1.16 - 2020-12-31
- Update
cfg-ifto v1.0. #173 - Implement
std::error::Errorfor theErrortype on additional targets. #169
- Multithreaded WASM support. #171
0.1.15 - 2020-09-10
0.1.14 - 2020-01-07
- Remove use of spin-locks in the
use_filemodule. #125 - Update
wasito v0.9. #126 - Do not read errno value on DragonFlyBSD to fix compilation failure. #129
0.1.13 - 2019-08-25
- VxWorks targets support. #86
- If zero-length slice is passed to the
getrandomfunction, always returnOk(())immediately without doing any calls to the underlying operating system. #104 - Use the
kern.arandomsysctl on NetBSD. #115
0.1.12 - 2019-08-18
- Update wasi dependency from v0.5 to v0.7. #100
0.1.11 - 2019-08-25
- Implement
std-dependent traits for selected targets even ifstdfeature is disabled. (backward compatibility with v0.1.8) #96
0.1.10 - 2019-08-18 [YANKED]
- Use the dummy implementation on
wasm32-unknown-unknowneven with the disableddummyfeature. #90
- Fix CSP error for
wasm-bindgen. #92
0.1.9 - 2019-08-14 [YANKED]
- Remove
stddependency for opening and reading files. #58 - Use
wasiinstead oflibcon WASI target. #64 - By default emit a compile-time error when built for an unsupported target.
This behaviour can be disabled by using the
dummyfeature. #71
0.1.8 - 2019-07-29
- Explicitly specify types to arguments of 'libc::syscall'. #74
0.1.7 - 2019-07-29
- Support for hermit and l4re. #61
Error::raw_os_errormethod,Error::INTERNAL_STARTandError::CUSTOM_STARTconstants. Uselibcfor retrieving OS error descriptions. #54
- Remove
lazy_staticdependency and use custom structures for lock-free initialization. #51 #52 - Try
getrandom()first on FreeBSD. #57
- Bitrig support. #56
Error::UNKNOWN,Error::UNAVAILABLE. #54
0.1.6 - 2019-06-30
- Minor change of RDRAND AMD bug handling. #48
0.1.5 - 2019-06-29
- Use shared
Fileinstead of shared file descriptor. #44 - Workaround for RDRAND hardware bug present on some AMD CPUs. #43
- Try
getentropyand then fallback to/dev/randomon macOS. #38
0.1.4 - 2019-06-28
- Add support for
x86_64-unknown-uefitarget by using RDRAND with CPUID feature detection. #30
- Fix long buffer issues on Windows and Linux. #31 #32
- Check
EPERMin addition toENOSYSon Linux. #37
- Improve efficiency by sharing file descriptor across threads. #13
- Remove
cloudabi,winapi, andfuchsia-cprngdependencies. #40 - Improve RDRAND implementation. #24
- Don't block during syscall detection on Linux. #26
- Increase consistency with libc implementation on FreeBSD. #36
- Apply
rustfmt. #39
0.1.3 - 2019-05-15
- Update for
wasm32-unknown-wasibeing renamed towasm32-wasi, and for WASI being categorized as an OS.
0.1.2 - 2019-04-06
- Add support for
wasm32-unknown-wasitarget.
0.1.1 - 2019-04-05
- Enable std functionality for CloudABI by default.
0.1.0 - 2019-03-23
Publish initial implementation.
0.0.0 - 2019-01-19
Publish an empty template library.