Skip to content

Commit

Permalink
kuznyechik: use const eval to generate tables
Browse files Browse the repository at this point in the history
  • Loading branch information
newpavlov committed Sep 26, 2024
1 parent 0ce5b88 commit 0d44018
Show file tree
Hide file tree
Showing 20 changed files with 377 additions and 279 deletions.
2 changes: 1 addition & 1 deletion kuznyechik/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ zeroize = ["cipher/zeroize"]

[lints.rust.unexpected_cfgs]
level = "warn"
check-cfg = ["cfg(kuznyechik_force_soft)", "cfg(kuznyechik_compact_soft)"]
check-cfg = ['cfg(kuznyechik_backend, values("soft", "compact_soft"))']

[package.metadata.docs.rs]
all-features = true
Expand Down
12 changes: 4 additions & 8 deletions kuznyechik/src/big_soft/backends.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
use super::consts::{Table, DEC_TABLE, ENC_TABLE, RKEY_GEN};
use crate::{
consts::{P, P_INV},
fused_tables::{Table, DEC_TABLE, ENC_TABLE},
utils::KEYGEN,
Block, Key,
};
use cipher::{
Expand All @@ -27,7 +28,7 @@ fn sub_bytes(block: u128, sbox: &[u8; 256]) -> u128 {

#[inline(always)]
fn transform(block: u128, table: &Table) -> u128 {
let table: &[[u128; 256]; 16] = unsafe { &*(table.as_ptr().cast()) };
let table: &[[u128; 256]; 16] = unsafe { &*(table.0.as_ptr().cast()) };
let block = block.to_le_bytes();
let mut res = 0u128;
for i in 0..16 {
Expand All @@ -41,12 +42,7 @@ fn transform(block: u128, table: &Table) -> u128 {
pub(super) fn expand_enc_keys(key: &Key) -> RoundKeys {
#[inline(always)]
fn next_const(i: usize) -> u128 {
// correct alignment of `p` is guaranteed since the table is aligned to 16 bytes
let t: &[u128; 32] = unsafe { &*(RKEY_GEN.as_ptr().cast()) };
let val = t[i];
#[cfg(target_endian = "big")]
let val = val.swap_bytes();
val
u128::from_le_bytes(KEYGEN[i].0)
}

let mut enc_keys = [0; 10];
Expand Down
2 changes: 0 additions & 2 deletions kuznyechik/src/big_soft/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,6 @@ use cipher::{
};

mod backends;
#[path = "../fused_tables/consts.rs"]
mod consts;

use backends::{expand_enc_keys, inv_enc_keys, DecBackend, EncBackend, RoundKeys};

Expand Down
52 changes: 10 additions & 42 deletions kuznyechik/src/compact_soft/backends.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
use super::consts::GF;
use crate::consts::{P, P_INV};
use crate::{Block, Key};
use crate::{
consts::{P, P_INV},
utils::{l_step, KEYGEN},
Block, Key,
};
use cipher::{
consts, BlockCipherDecBackend, BlockCipherEncBackend, BlockSizeUser, InOut, ParBlocksSizeUser,
};
Expand All @@ -14,35 +16,6 @@ fn x(a: &mut Block, b: &Block) {
}
}

fn l_step(msg: &mut Block, i: usize) {
#[inline(always)]
fn get_idx(b: usize, i: usize) -> usize {
b.wrapping_sub(i) & 0x0F
}
#[inline(always)]
fn get_m(msg: &Block, b: usize, i: usize) -> usize {
msg[get_idx(b, i)] as usize
}

let mut x = msg[get_idx(15, i)];
x ^= GF[3][get_m(msg, 14, i)];
x ^= GF[1][get_m(msg, 13, i)];
x ^= GF[2][get_m(msg, 12, i)];
x ^= GF[0][get_m(msg, 11, i)];
x ^= GF[5][get_m(msg, 10, i)];
x ^= GF[4][get_m(msg, 9, i)];
x ^= msg[get_idx(8, i)];
x ^= GF[6][get_m(msg, 7, i)];
x ^= msg[get_idx(6, i)];
x ^= GF[4][get_m(msg, 5, i)];
x ^= GF[5][get_m(msg, 4, i)];
x ^= GF[0][get_m(msg, 3, i)];
x ^= GF[2][get_m(msg, 2, i)];
x ^= GF[1][get_m(msg, 1, i)];
x ^= GF[3][get_m(msg, 0, i)];
msg[get_idx(15, i)] = x;
}

#[inline(always)]
fn lsx(block: &mut Block, key: &Block) {
x(block, key);
Expand All @@ -52,7 +25,7 @@ fn lsx(block: &mut Block, key: &Block) {
}
// l
for i in 0..16 {
l_step(block, i);
l_step(&mut block.0, i);
}
}

Expand All @@ -61,7 +34,7 @@ fn lsx_inv(block: &mut Block, key: &Block) {
x(block, key);
// l_inv
for i in 0..16 {
l_step(block, 15 - i);
l_step(&mut block.0, 15 - i);
}
// s_inv
for i in 0..16 {
Expand All @@ -70,22 +43,17 @@ fn lsx_inv(block: &mut Block, key: &Block) {
}

fn get_c(n: usize) -> Block {
let mut v = Block::default();
v[15] = n as u8;
for i in 0..16 {
l_step(&mut v, i);
}
v
KEYGEN[n].0.into()
}

fn f(k1: &mut Block, k2: &mut Block, n: usize) {
for i in 0..4 {
let mut k1_cpy = *k1;
lsx(&mut k1_cpy, &get_c(8 * n + 2 * i + 1));
lsx(&mut k1_cpy, &get_c(8 * n + 2 * i));
x(k2, &k1_cpy);

let mut k2_cpy = *k2;
lsx(&mut k2_cpy, &get_c(8 * n + 2 * i + 2));
lsx(&mut k2_cpy, &get_c(8 * n + 2 * i + 1));
x(k1, &k2_cpy);
}
}
Expand Down
143 changes: 0 additions & 143 deletions kuznyechik/src/compact_soft/consts.rs

This file was deleted.

1 change: 0 additions & 1 deletion kuznyechik/src/compact_soft/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ use cipher::{
};

mod backends;
mod consts;

use backends::{expand, DecBackend, EncBackend, RoundKeys};

Expand Down
Loading

0 comments on commit 0d44018

Please sign in to comment.