Skip to content

Commit 9b7a1a3

Browse files
committed
feat: added selection of entropy crate
Added ability to select between `rand` and `aws-lc-rs` crates for entropy device. Signed-off-by: Egor Lazarchuk <[email protected]>
1 parent c0b3420 commit 9b7a1a3

File tree

6 files changed

+32
-5
lines changed

6 files changed

+32
-5
lines changed

Cargo.lock

+1
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

src/cpu-template-helper/Cargo.toml

+1-1
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,7 @@ serde = { version = "1.0.136", features = ["derive"] }
1818
serde_json = "1.0.78"
1919
thiserror = "1.0.32"
2020

21-
vmm = { path = "../vmm" }
21+
vmm = { path = "../vmm", features = ["rng-rand"] }
2222

2323
[dev-dependencies]
2424
utils = { path = "../utils" }

src/firecracker/Cargo.toml

+6-1
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,11 @@ license = "Apache-2.0"
1212
name = "firecracker"
1313
bench = false
1414

15+
[features]
16+
default = ["rng-aws-lc-rs"]
17+
rng-aws-lc-rs = ["vmm/rng-aws-lc-rs"]
18+
rng-rand = ["vmm/rng-rand"]
19+
1520
[dependencies]
1621
event-manager = "0.3.0"
1722
libc = "0.2.117"
@@ -24,7 +29,7 @@ mmds = { path = "../mmds" }
2429
seccompiler = { path = "../seccompiler" }
2530
snapshot = { path = "../snapshot" }
2631
utils = { path = "../utils" }
27-
vmm = { path = "../vmm" }
32+
vmm = { path = "../vmm", default-features = false }
2833

2934
[dev-dependencies]
3035
cargo_toml = "0.15.2"

src/vmm/Cargo.toml

+7-1
Original file line numberDiff line numberDiff line change
@@ -8,8 +8,14 @@ license = "Apache-2.0"
88
[lib]
99
bench = false
1010

11+
[features]
12+
default = []
13+
rng-aws-lc-rs = ["dep:aws-lc-rs"]
14+
rng-rand = ["dep:rand"]
15+
1116
[dependencies]
12-
aws-lc-rs = "1.0.2"
17+
aws-lc-rs = { version = "1.0.2", optional = true }
18+
rand = { version = "0.8.5", optional = true }
1319
bitflags = "2.0.2"
1420
derive_more = { version = "0.99.17", default-features = false, features = ["from", "display"] }
1521
event-manager = "0.3.0"

src/vmm/build.rs

+5
Original file line numberDiff line numberDiff line change
@@ -127,4 +127,9 @@ fn cpuid() {
127127
all(target_arch = "x86_64", not(target_env = "sgx"))
128128
))]
129129
println!("cargo:rustc-cfg=cpuid");
130+
131+
#[cfg(
132+
not(any(feature="rng-aws-lc-rs", feature="rng-rand")) // If neither are enabled
133+
)]
134+
compile_error!("Please enable the feature \"rng-aws-lc-rs\" OR the feature \"rng-rand\".");
130135
}

src/vmm/src/devices/virtio/rng/device.rs

+12-2
Original file line numberDiff line numberDiff line change
@@ -5,8 +5,11 @@ use std::io;
55
use std::sync::atomic::AtomicUsize;
66
use std::sync::Arc;
77

8-
use aws_lc_rs::rand;
8+
#[cfg(feature = "rng-aws-lc-rs")]
9+
use aws_lc_rs::{error::Unspecified as RandomError, rand};
910
use logger::{debug, error, IncMetric, METRICS};
11+
#[cfg(all(feature = "rng-rand", not(feature = "rng-aws-lc-rs")))]
12+
use rand::{rngs::OsRng, Error as RandomError, RngCore};
1013
use rate_limiter::{RateLimiter, TokenType};
1114
use utils::eventfd::EventFd;
1215
use utils::vm_memory::{GuestMemoryError, GuestMemoryMmap};
@@ -27,7 +30,7 @@ pub enum Error {
2730
#[error("Bad guest memory buffer: {0}")]
2831
GuestMemory(#[from] GuestMemoryError),
2932
#[error("Could not get random bytes: {0}")]
30-
Random(#[from] aws_lc_rs::error::Unspecified),
33+
Random(#[from] RandomError),
3134
}
3235

3336
type Result<T> = std::result::Result<T, Error>;
@@ -109,10 +112,17 @@ impl Entropy {
109112
}
110113

111114
let mut rand_bytes = vec![0; iovec.len()];
115+
116+
#[cfg(feature = "rng-aws-lc-rs")]
112117
rand::fill(&mut rand_bytes).map_err(|err| {
113118
METRICS.entropy.host_rng_fails.inc();
114119
err
115120
})?;
121+
#[cfg(all(feature = "rng-rand", not(feature = "rng-aws-lc-rs")))]
122+
OsRng.try_fill_bytes(&mut rand_bytes).map_err(|err| {
123+
METRICS.entropy.host_rng_fails.inc();
124+
err
125+
})?;
116126

117127
// It is ok to unwrap here. We are writing `iovec.len()` bytes at offset 0.
118128
Ok(iovec.write_at(&rand_bytes, 0).unwrap().try_into().unwrap())

0 commit comments

Comments
 (0)