This repository contains the codes for verifying the distinguishers of CRAFT (https://tosc.iacr.org/index.php/ToSC/article/view/7396) presented in our paper "Differential Attacks on CRAFT Exploiting the Involutory S-boxes and Tweak Additions" which was accepted to ToSC 2020 Issue 3 / FSE 2021.

The verified distinguishers are listed as follows:

  • A 6-round single-key differential distinguisher (verification_6r.cpp)

  • An 8-round single-key differential distinguisher (verification_8r.cpp)

  • A 10-round single-key differential distinguisher (verification_6r.cpp)

  • A 12-round single-key differential distinguisher (verified with GUP accelerated computing, see cuda_verification.cu)

  • A 14-round single-key differential distinguisher (verified with GUP accelerated computing, see cuda_verification.cu)

  • A 16-round experimental differential distinguisher (see cuda_verification.cu, and the program is still running to test more data)

  • An 8-round weak-key differential characteristics 0x00a0af0000000000 to 0x00a0af0000000000 (cuda_verification_x_0---x_8.cu) and 0x00a0a50000000000 to 0x00a0a50000000000 (cuda_verification_x_4---x_12.cu)

  • A 2-round weak-key differential characteristics (x_16---x_18.cpp)

For r in {6, 8}, the experimental probability for an r-round distinguisher is obtained as follows. First, we set the tweak to satisfy the required conditions of the distinguisher, then compute the probabilities of the distinguishers for several randomly chosen keys, and the average probability is used as the experimental probability. For r = 10, we only perform the experiment for four randomly chosen keys.

For r in {12, 14, 16}, due to the high complexity, the experiment is only performed for one randomly chosen key.

For 8-round and 2-round weak-key differential characteristics, First, we set the tweak to satisfy the required conditions of the distinguisher, then we choose 16 keys which satisfy the required conditions of weak-key model randomly and conpute the probabilities and the average probability is used as the experimental probability.

We also implement Algorithm 1 in the submitted paper for a 7-round distinguisher and try to recovery one nibble of the secret key (recover_knibble.cpp).