[svn] / ecrypt / trunk / submissions / abc / abc.h  

svn: ecrypt/trunk/submissions/abc/abc.h

File: [svn] / ecrypt / trunk / submissions / abc / abc.h (download) (as text)
Revision: 70, Sun Aug 21 15:54:34 2005 UTC (7 years, 9 months ago) by cdecanni
File size: 2022 byte(s)
* moved tables to a separate file (the extremely long macros did not compile
  on some compilers).
* changed the order of the variants in order to use the fastest ones first.
/* abc.h */

/*
 * Header with ABC implementation-specific constants and macros
 *
 * ABC reference imlementation
 * Vladimir Anashin, Andrey Bogdanov, Ilya Kizhvatov
 * 5 March 2005
 */

#ifndef ABC_H__
#define ABC_H__

#include "ecrypt-sync.h"


/* Optimization window size and cycle unroll count */
#if (ECRYPT_VARIANT == 10)
    #define ABC_WINDOW_1
    #define ABC_UNROLL_1
#elif (ECRYPT_VARIANT == 9)
    #define ABC_WINDOW_2
    #define ABC_UNROLL_4
#elif (ECRYPT_VARIANT == 8)
    #define ABC_WINDOW_2
    #define ABC_UNROLL_8
#elif (ECRYPT_VARIANT == 7)
    #define ABC_WINDOW_4
    #define ABC_UNROLL_4
#elif (ECRYPT_VARIANT == 6)
    #define ABC_WINDOW_4
    #define ABC_UNROLL_8
#elif (ECRYPT_VARIANT == 5)
    #define ABC_WINDOW_4
    #define ABC_UNROLL_16
#elif (ECRYPT_VARIANT == 4)
    #define ABC_WINDOW_8
    #define ABC_UNROLL_4
#elif (ECRYPT_VARIANT == 3)
    #define ABC_WINDOW_8
    #define ABC_UNROLL_8
#elif (ECRYPT_VARIANT == 2)
    #define ABC_WINDOW_8
    #define ABC_UNROLL_16
#elif (ECRYPT_VARIANT == 1)
    #define ABC_WINDOW_12
    #define ABC_UNROLL_16
#endif


/* ------------------------------------------------------------------------- */

/* A, Linear feedback shift registre */
#define ABC_A_MASK U32C(0x00000002) /* Mask for making LFSR state nonzero */

/* ------------------------------------------------------------------------- */

/* B, top function */
#define ABC_B_COEF_AND_MASK U32C(0xfffffffc) /* Mask making coefs 0 (mod 4) */
#define ABC_B_COEF_OR_MASK U32C(0x00000001)  /* Mask making coefs 1 (mod 2) */
#define ABC_B_KEYSETUP_D0 U32C(0x0c376d75)   /* Coefficients for key setup  */
#define ABC_B_KEYSETUP_D1 U32C(0xbbb5b0b4)

/* ------------------------------------------------------------------------- */

/* C, filter function */
#define ABC_C_COEF_NUM 33               /* Number of coefs           */
#define ABC_C_AND_MASK U32C(0xffff0000) /* Mask for 31st coefficient */
#define ABC_C_OR_MASK  U32C(0x00010000) /* Mask for 31st coefficient */


#endif /* ABC_H__ */

eSTREAM Project

Powered by ViewCVS 1.0-dev
(Powered by Apache)

ViewCVS and CVS Help