SNOW is a family of word-based synchronousstream ciphers developed by Thomas Johansson and Patrik Ekdahl atLund University.
They have a 512-bitlinear feedback shift register at their core, followed by a non-linear output state machine with a few additional words of state.
SNOW 1.0,SNOW 2.0, andSNOW 3G use a shift register of 16 32-bit words, and a 32-bitadd-rotate-XOR (ARX) output transformation with 2 or 3 words of state. Each iteration advances the shift register by 32 bits and produces 32 bits of output.
SNOW-V andSNOW-Vi use a shift register of 32 16-bit words (designed to be implemented as 4 128-bitSIMD registers) which is advanced by 16 bits per iteration. 8 LFSR iterations can be performed simultaneously using SIMD operations, after which one output transformation step is performed, producing 128 bits of output. The output transformation uses theAdvanced Encryption Standard (AES) round function (commonlyimplemented in hardware on recent processors), and maintains 2 additional 128-bit words of state.
SNOW 1.0, originally simply SNOW, was submitted to theNESSIE project.[1] The cipher has no known intellectual property or other restrictions. The cipher works on 32-bit words and supports both 128- and 256-bit keys. The cipher consists of a combination of aLFSR and afinite-state machine (FSM) where the LFSR also feeds the next state function of the FSM. The cipher has a short initialization phase and very good performance on both 32-bit processors and in hardware.
During the evaluation, weaknesses were discovered and as a result, SNOW was not included in the NESSIE suite of algorithms. The authors have developed a new version, version 2.0 of the cipher, that solves the weaknesses and improves the performance.[2]
DuringETSISAGE evaluation, the design was further modified to increase its resistance against algebraic attacks with the result named SNOW 3G.[3]
It has been found that related keys exist both for SNOW 2.0 and SNOW 3G,[4] allowing attacks against SNOW 2.0 in the related-key model.
SNOW has been used in theESTREAM project as a reference cipher for the performance evaluation.
SNOW 2.0 is one out of stream ciphers chosen forISO/IEC standard ISO/IEC 18033-4.[5]
SNOW 3G[6] is chosen as the stream cipher for the3GPP encryption algorithms UEA2 and UIA2.[7]
SNOW-V was an extensive redesign published in 2019,[8] designed to match5G cellular network speeds by generating 128 bits of output per iteration. SNOW-Vi[9] was tweaked for even higher speed using small changes to the LFSR; the output transformation is identical.