Merge pull request #424 from str4d/418-scrypt-very-fast-machines

scrypt: Increase `log_n` until it is measurable
This commit is contained in:
str4d 2023-12-27 10:50:09 +00:00 committed by GitHub
commit 0a64d38208
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 13 additions and 4 deletions

View file

@ -25,6 +25,8 @@ to 1.0.0 are beta releases.
- `impl TryFrom<Identity> for Recipient`
### Fixed
- `age::Encryptor::with_user_passphrase` will now re-measure the `scrypt` work
factor until it is measurable, instead of setting the work factor to maximum.
- `age::cli_common`:
- `UiCallbacks::confirm` no longer requires erasing the confirmation message
before it will accept a response.

View file

@ -25,10 +25,7 @@ const ENCRYPTED_FILE_KEY_BYTES: usize = FILE_KEY_BYTES + 16;
///
/// Guaranteed to return a valid work factor (less than 64).
fn target_scrypt_work_factor() -> u8 {
// Time a work factor that should always be fast.
let mut log_n = 10;
let duration: Option<Duration> = {
let measure_duration = |log_n| {
// Platforms that have a functional SystemTime::now():
#[cfg(not(all(target_arch = "wasm32", not(target_os = "wasi"))))]
{
@ -61,6 +58,16 @@ fn target_scrypt_work_factor() -> u8 {
}
};
// Time a work factor that should always be fast.
let mut log_n = 10;
let mut duration: Option<Duration> = measure_duration(log_n);
while duration.map(|d| d.is_zero()).unwrap_or(false) {
// On some newer platforms, the work factor may be so fast that it is cannot be
// measured. Increase the work factor until we can measure something.
log_n += 1;
duration = measure_duration(log_n);
}
duration
.map(|mut d| {
// Use duration as a proxy for CPU usage, which scales linearly with N.