Proving Resistance Against Invariant Attacks: How to Choose the Round Constants. - Archive ouverte HAL Access content directly
Conference Papers Year : 2017

Proving Resistance Against Invariant Attacks: How to Choose the Round Constants.

(1) , (2) , (1) , (2)
1
2

Abstract

Many lightweight block ciphers apply a very simple key schedule in which the round keys only differ by addition of a round-specific constant. Generally, there is not much theory on how to choose appropriate constants. In fact, several of those schemes were recently broken using invariant attacks, i.e., invariant subspace or nonlinear invariant attacks. This work analyzes the resistance of such ciphers against invariant attacks and reveals the precise mathematical properties that render those attacks applicable. As a first practical consequence, we prove that some ciphers including Prince, Skinny-64 and Mantis 7 are not vulnerable to invariant attacks. Also, we show that the invariant factors of the linear layer have a major impact on the resistance against those attacks. Most notably, if the number of invariant factors of the linear layer is small (e.g., if its minimal polynomial has a high degree), we can easily find round constants which guarantee the resistance to all types of invariant attacks, independently of the choice of the S-box layer. We also explain how to construct optimal round constants for a given, but arbitrary, linear layer.
Fichier principal
Vignette du fichier
463.pdf (524.81 Ko) Télécharger le fichier
Origin : Files produced by the author(s)
Loading...

Dates and versions

hal-01631130 , version 1 (08-11-2017)

Identifiers

Cite

Christof Beierle, Anne Canteaut, Gregor Leander, Yann Rotella. Proving Resistance Against Invariant Attacks: How to Choose the Round Constants.. Crypto 2017 - Advances in Cryptology, Steven Myers, Aug 2017, Santa Barbara, United States. pp.647--678, ⟨10.1007/978-3-319-63715-0_22⟩. ⟨hal-01631130⟩

Collections

INRIA INRIA2 ANR
319 View
375 Download

Altmetric

Share

Gmail Facebook Twitter LinkedIn More