Struct subtle::Choice [−][src]
pub struct Choice(_);
The Choice
struct represents a choice for use in conditional assignment.
It is a wrapper around a u8
, which should have the value either 1
(true)
or 0
(false).
The conversion from u8
to Choice
passes the value through an optimization
barrier, as a best-effort attempt to prevent the compiler from inferring that
the Choice
value is a boolean. This strategy is based on Tim Maclean’s
work on rust-timing-shield
, which attempts to provide
a more comprehensive approach for preventing software side-channels in Rust
code.
The Choice
struct implements operators for AND, OR, XOR, and NOT, to allow
combining Choice
values. These operations do not short-circuit.
Implementations
impl Choice
[src]
impl Choice
[src]Trait Implementations
impl BitAndAssign<Choice> for Choice
[src]
impl BitAndAssign<Choice> for Choice
[src]fn bitand_assign(&mut self, rhs: Choice)
[src]
impl BitOrAssign<Choice> for Choice
[src]
impl BitOrAssign<Choice> for Choice
[src]fn bitor_assign(&mut self, rhs: Choice)
[src]
impl BitXorAssign<Choice> for Choice
[src]
impl BitXorAssign<Choice> for Choice
[src]fn bitxor_assign(&mut self, rhs: Choice)
[src]
impl ConditionallySelectable for Choice
[src]
impl ConditionallySelectable for Choice
[src]fn conditional_select(a: &Self, b: &Self, choice: Choice) -> Self
[src]
fn conditional_assign(&mut self, other: &Self, choice: Choice)
[src]
fn conditional_swap(a: &mut Self, b: &mut Self, choice: Choice)
[src]
impl From<Choice> for bool
[src]
impl From<Choice> for bool
[src]fn from(source: Choice) -> bool
[src]
Convert the Choice
wrapper into a bool
, depending on whether
the underlying u8
was a 0
or a 1
.
Note
This function exists to avoid having higher-level cryptographic protocol implementations duplicating this pattern.
The intended use case for this conversion is at the end of a
higher-level primitive implementation: for example, in checking a keyed
MAC, where the verification should happen in constant-time (and thus use
a Choice
) but it is safe to return a bool
at the end of the
verification.