Skip to main content

Serpent

Serpent is a modern block cipher published in 1998. It was one of the 5 finalists in the AES contest. It had the least number of negative votes and the second greatest positive vote count after Rijndael.

Basic facts:

  • Construction: The cipher is a substitution-permutation network (SPN) consisting of 32 rounds (even though 16 rounds were deemed secure enough). Each round except the last consists of a key mixing operation, substitution (using 32 parallel 4-bit S-boxes) and a linear transformation. In the last round, the linear transformation is replaced by an additional key mixing.
  • Key expansion:
    • As an AES candidate, Serpent offered 128, 192 and 256-bit keys. By design, it can accept any key between 0 and 256 bits inclusive, any key that has less than the full 256 bits is padded by appending a single $1$ bit and then as many $0$ bits as needed.
    • The 256-bit key is expanded into 132 32-bit words (collectively called the prekey) using a recurrent expression.
    • A bitslice-mode S-box (see later) is applied to 4 words of the prekey at a time, producing 33 128-bit subkeys (round keys).
  • Implementation: The algorithm specification describes two possible approaches to implementing Serpent.
    • Formally, the Serpent round operates on state consisting of 32 4-bit chunks of data (the same S-box is applied 32 times in parallel).
    • In the so-called "bitslice mode", the state is rearranged into 4 32-bit words, where the first bits of each word correspond to the first 4-bit chunk in the formal description, etc.
    • The catch is that Serpent treats input data (i.e. plaintexts and ciphertexts) as already converted to the bitslice representation.
    • This means that when the "formal" implementation is chosen, the input and output bits (as well as individual subkeys) have to be permuted back from the default bitslice mode.
  • Data representation: In Serpent, for some godforsaken reason, everything is backwards.
    • The user key is TODO

References:

  • https://www.cl.cam.ac.uk/archive/rja14/Papers/serpent.pdf