CISUC

Implementing BLAKE with AVX, AVX2, and XOP

Authors

Abstract

In 2013 Intel will release the AVX2 instructions, which introduce 256-bit single-instruction multiple-data (SIMD) integer arithmetic. This will enable desktop and server processors from this vendor to support 4-way SIMD computation of 64-bit add-rotate-xor algorithms, as well as 8-way 32-bit SIMD computations. AVX2 also includes interesting instructions for cryptographic functions, like any-to-any permute and vectorized table-lookup. In this paper, we explore the potential of AVX2 to speed-up the SHA-3 finalist BLAKE, and present the first working assembly implementations of BLAKE-256 and BLAKE-512 with AVX2. We then investigate the potential of the recent AVX and XOP instructions to accelerate BLAKE, and report new speed records on Sandy Bridge and Bulldozer microarchitectures (7.47 and 11.64 cycles per byte for BLAKE-256, 5.71 and 6.95 for BLAKE-512).

Keywords

hash functions, SHA-3, implementation, SIMD

TechReport Number

275

Cited by

Year 2013 : 1 citations

 Fast Software Encryption with SIMD (How to speed up symmetric block ciphers with the AVX/AVX2 instruction set) . In: ACM (Hrsg.) : Proceedings of the Third European Workshop on System Security (EUROSEC 2013 Prag 14.4.2013). 2013

Year 2012 : 1 citations

 Götzfried, Johannes. "Advanced Vector Extensions to Accelerate Crypto Primitives."