mirror of
https://github.com/str4d/rage.git
synced 2025-04-03 19:07:42 +03:00
Merge pull request #424 from str4d/418-scrypt-very-fast-machines
scrypt: Increase `log_n` until it is measurable
This commit is contained in:
commit
0a64d38208
2 changed files with 13 additions and 4 deletions
|
@ -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.
|
||||
|
|
|
@ -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.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue