Bernstein's CubeHash is a hash function family that includes four functions submitted to the NIST Hash Competition. A CubeHash function is parametrized by a number of rounds r , a block byte size b , and a digest bit length h (the compression function makes r rounds, while the finalization function makes 10r rounds). The 1024-bit internal state of CubeHash is represented as a five-dimensional hypercube. The submissions to NIST recommends r = 8, b = 1, and h *** {224,256,384,512}.
This paper presents the first external analysis of CubeHash, with
improved standard generic attacks for collisions and preimages
a multicollision attack that exploits fixed points
a study of the round function symmetries
a preimage attack that exploits these symmetries
a practical collision attack on a weakened version of CubeHash
a study of fixed points and an example of nontrivial fixed point
high-probability truncated differentials over 10 rounds
Since the first publication of these results, several collision attacks for reduced versions of CubeHash were published by Dai, Peyrin, et al. Our results are more general, since they apply to any choice of the parameters, and show intrinsic properties of the CubeHash design, rather than attacks on specific versions.
[1]
Thomas Peyrin,et al.
Cryptanalysis of CubeHash
,
2009,
ACNS.
[2]
Frederick Mosteller,et al.
Methods for studying coincidences
,
1989
.
[3]
Elaine B. Barker,et al.
A Statistical Test Suite for Random and Pseudorandom Number Generators for Cryptographic Applications
,
2000
.
[4]
Antoine Joux,et al.
Multicollisions in Iterated Hash Functions. Application to Cascaded Constructions
,
2004,
CRYPTO.
[5]
Suzuki Kazuhiro,et al.
Birthday Paradox for Multi-Collisions
,
2007
.
[6]
Elaine B. Barker,et al.
A Statistical Test Suite for Random and Pseudorandom Number Generators for Cryptographic Applications
,
2000
.