Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Statically assert that delays are less than 25,769,803,784 cycles #36

Closed
wants to merge 2 commits into from
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 9 additions & 8 deletions src/delay_cycles.rs
Original file line number Diff line number Diff line change
Expand Up @@ -103,14 +103,15 @@ const fn select(info: Cycles, cycles: u64, above: u64) -> Selection {
}

impl<const CYCLES: u64, const MUL: u64, const DIV: u64> Delayer<CYCLES, MUL, DIV> {
// Multiply first to avoid precision loss.
// With a u64 there is no overflow when MUL is lower than:
// (2^64-1)/25_769_803_784 == 715_827_882.
// Since MUL is usually CPU_FREQUENCY_HZ, this allows up to 715.83 MHz.
const TOTAL_CYCLES: u64 = CYCLES * MUL / DIV;

// With `feature(generic_const_exprs) it becomes possible to construct a static assertion.
//const _: [(); 0 - ((Self::TOTAL_CYCLES > 25_769_803_784) as usize)] = [];
// Compute the intended number of cycles to delay, and panic if it is greater than
// the maximum supported amount of cycles
const TOTAL_CYCLES: u64 = {
const MAX_SUPPORTED_CYCLES: u64 = 25_769_803_784;
// Multiply first to avoid precision loss, and expand to u128 to avoid overflow
let result: u128 = (CYCLES as u128) * (MUL as u128) / (DIV as u128);
assert!(result <= (MAX_SUPPORTED_CYCLES as u128), "Error: Tried to delay for too many cycles. The maximum supported delay is 25_769_803_784 cycles");
result as u64
};

// counter mask, cycles per run, cycles per iteration. | cost + worst case remainder cost
const U32_INFO: Cycles = cycles(0xFFFF_FFFF, 9, 6); // 8 + 3
Expand Down