blob: 93432843c6673f156bdab03b538687d60bd4e9a5 [file] [log] [blame]
Alice Wang8b8e6e62023-10-02 09:10:13 +00001// Copyright 2023, The Android Open Source Project
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15//! Wrappers of the randon number generations functions in BoringSSL rand.h.
16
17use crate::util::check_int_result;
18use bssl_avf_error::{ApiName, Result};
19use bssl_ffi::RAND_bytes;
20
21/// Fills the given `dest` with random data.
22pub fn rand_bytes(dest: &mut [u8]) -> Result<()> {
23 // SAFETY: This function only writes to the given buffer within its bounds.
24 let ret = unsafe { RAND_bytes(dest.as_mut_ptr(), dest.len()) };
25 check_int_result(ret, ApiName::RAND_bytes)
26}