primitives/algebra/field/binary/
gf2_128.rs

1use aes::Block;
2
3use crate::algebra::field::binary::gf2_ext::*;
4
5define_gf2_extension!(Gf2_128, IdGf2_128, 2, [1, 2, 7]);
6
7impl Gf2_128 {
8    pub fn to_le_block(&self) -> Block {
9        self.into_le_block()
10    }
11
12    pub fn into_le_block(self) -> Block {
13        #[cfg(target_endian = "little")]
14        unsafe {
15            std::mem::transmute(self)
16        }
17        #[cfg(target_endian = "big")]
18        {
19            let block = self.to_le_bytes();
20            Block::from_exact_iter(block).unwrap()
21        }
22    }
23
24    pub fn as_ne_block_mut(&mut self) -> &mut Block {
25        unsafe { std::mem::transmute(self) }
26    }
27
28    pub fn from_le_block(block: Block) -> Self {
29        #[cfg(target_endian = "little")]
30        unsafe {
31            std::mem::transmute(block)
32        }
33        #[cfg(target_endian = "big")]
34        {
35            let block = block.to_le_bytes();
36            Gf2_128::from_le_bytes(&block).unwrap()
37        }
38    }
39}