For the latest news and information visit
The GNU Crypto project

gnu.crypto.cipher
Class Serpent

java.lang.Object
  extended by gnu.crypto.cipher.BaseCipher
      extended by gnu.crypto.cipher.Serpent
All Implemented Interfaces:
IBlockCipher, IBlockCipherSpi, Cloneable

public class Serpent
extends BaseCipher

Serpent is a 32-round substitution-permutation network block cipher, operating on 128-bit blocks and accepting keys of 128, 192, and 256 bits in length. At each round the plaintext is XORed with a 128 bit portion of the session key -- a 4224 bit key computed from the input key -- then one of eight S-boxes are applied, and finally a simple linear transformation is done. Decryption does the exact same thing in reverse order, and using the eight inverses of the S-boxes.

Serpent was designed by Ross Anderson, Eli Biham, and Lars Knudsen as a proposed cipher for the Advanced Encryption Standard.

Serpent can be sped up greatly by replacing S-box substitution with a sequence of binary operations, and the optimal implementation depends upon finding the fastest sequence of binary operations that reproduce this substitution. This implementation uses the S-boxes discovered by Dag Arne Osvik, which are optimized for the Pentium family of processors.

References:

  1. Serpent: A Candidate Block Cipher for the Advanced Encryption Standard.

Version:
$Revision: 1.9 $

Field Summary
 
Fields inherited from class gnu.crypto.cipher.BaseCipher
currentBlockSize, currentKey, defaultBlockSize, defaultKeySize, lock, name
 
Fields inherited from interface gnu.crypto.cipher.IBlockCipher
CIPHER_BLOCK_SIZE, KEY_MATERIAL
 
Constructor Summary
Serpent()
          Trivial zero-argument constructor.
 
Method Summary
 Iterator blockSizes()
          Returns an Iterator over the supported block sizes.
 Object clone()
          Returns a clone of this instance.
 void decrypt(byte[] in, int i, byte[] out, int o, Object K, int bs)
           
 void encrypt(byte[] in, int i, byte[] out, int o, Object K, int bs)
           
 Iterator keySizes()
          Returns an Iterator over the supported key sizes.
 Object makeKey(byte[] kb, int blockSize)
           
 boolean selfTest()
          A correctness test that consists of basic symmetric encryption / decryption test(s) for all supported block and key sizes, as well as one (1) variable key Known Answer Test (KAT).
 
Methods inherited from class gnu.crypto.cipher.BaseCipher
currentBlockSize, decryptBlock, defaultBlockSize, defaultKeySize, encryptBlock, init, name, reset, testKat, testKat
 
Methods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

Serpent

public Serpent()
Trivial zero-argument constructor.

Method Detail

clone

public Object clone()
Description copied from interface: IBlockCipher

Returns a clone of this instance.

Specified by:
clone in interface IBlockCipher
Specified by:
clone in class BaseCipher
Returns:
a clone copy of this instance.

blockSizes

public Iterator blockSizes()
Description copied from interface: IBlockCipher

Returns an Iterator over the supported block sizes. Each element returned by this object is an Integer.

Returns:
an Iterator over the supported block sizes.

keySizes

public Iterator keySizes()
Description copied from interface: IBlockCipher

Returns an Iterator over the supported key sizes. Each element returned by this object is an Integer.

Returns:
an Iterator over the supported key sizes.

makeKey

public Object makeKey(byte[] kb,
                      int blockSize)
               throws InvalidKeyException
Throws:
InvalidKeyException

encrypt

public void encrypt(byte[] in,
                    int i,
                    byte[] out,
                    int o,
                    Object K,
                    int bs)

decrypt

public void decrypt(byte[] in,
                    int i,
                    byte[] out,
                    int o,
                    Object K,
                    int bs)

selfTest

public boolean selfTest()
Description copied from interface: IBlockCipher

A correctness test that consists of basic symmetric encryption / decryption test(s) for all supported block and key sizes, as well as one (1) variable key Known Answer Test (KAT).

Specified by:
selfTest in interface IBlockCipher
Specified by:
selfTest in interface IBlockCipherSpi
Overrides:
selfTest in class BaseCipher
Returns:
true if the implementation passes simple correctness tests. Returns false otherwise.

For the latest news and information visit
The GNU Crypto project

Copyright © 2001, 2002, 2003 Free Software Foundation, Inc. All Rights Reserved.