Sha256: 75f2c3319068e06ec27135d516953ab645cc7c45033f045cba44136236ef5601

Contents?: true

Size: 1.08 KB

Versions: 8

Compression:

Stored size: 1.08 KB

Contents

//! Implementation for iOS, tvOS, and watchOS where `getentropy` is unavailable.
use crate::Error;
use core::{ffi::c_void, mem::MaybeUninit};

// libsystem contains the libc of Darwin, and every binary ends up linked against it either way. This
// makes it a more lightweight choice compared to `Security.framework`.
extern "C" {
    // This RNG uses a thread-local CSPRNG to provide data, which is seeded by the operating system's root CSPRNG.
    // Its the best option after `getentropy` on modern Darwin-based platforms that also avoids the
    // high startup costs and linking of Security.framework.
    //
    // While its just an implementation detail, `Security.framework` just calls into this anyway.
    fn CCRandomGenerateBytes(bytes: *mut c_void, size: usize) -> i32;
}

pub fn getrandom_inner(dest: &mut [MaybeUninit<u8>]) -> Result<(), Error> {
    let ret = unsafe { CCRandomGenerateBytes(dest.as_mut_ptr() as *mut c_void, dest.len()) };
    // kCCSuccess (from CommonCryptoError.h) is always zero.
    if ret != 0 {
        Err(Error::IOS_SEC_RANDOM)
    } else {
        Ok(())
    }
}

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
wasmtime-29.0.0 ./ext/cargo-vendor/getrandom-0.2.15/src/apple-other.rs
wasmtime-28.0.0 ./ext/cargo-vendor/getrandom-0.2.15/src/apple-other.rs
wasmtime-27.0.0 ./ext/cargo-vendor/getrandom-0.2.15/src/apple-other.rs
wasmtime-26.0.0 ./ext/cargo-vendor/getrandom-0.2.15/src/apple-other.rs
wasmtime-25.0.2 ./ext/cargo-vendor/getrandom-0.2.15/src/apple-other.rs
wasmtime-25.0.1 ./ext/cargo-vendor/getrandom-0.2.15/src/apple-other.rs
wasmtime-25.0.0 ./ext/cargo-vendor/getrandom-0.2.15/src/apple-other.rs
wasmtime-24.0.0 ./ext/cargo-vendor/getrandom-0.2.15/src/apple-other.rs