schwaemm_cfg.h 3.64 KB
Newer Older
Johann Großschädl committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
///////////////////////////////////////////////////////////////////////////////
// schwaemm_cfg.h: Configuration of instances of AEAD algorithm SCHWAEMM.    //
// This file is part of the SPARKLE submission to NIST's LW Crypto Project.  //
// Version 1.1.2 (2020-10-30), see <http://www.cryptolux.org/> for updates.  //
// Authors: The SPARKLE Group (C. Beierle, A. Biryukov, L. Cardoso dos       //
// Santos, J. Groszschaedl, L. Perrin, A. Udovenko, V. Velichkov, Q. Wang).  //
// License: GPLv3 (see LICENSE file), other licenses available upon request. //
// Copyright (C) 2019-2020 University of Luxembourg <http://www.uni.lu/>.    //
// ------------------------------------------------------------------------- //
// This program is free software: you can redistribute it and/or modify it   //
// under the terms of the GNU General Public License as published by the     //
// Free Software Foundation, either version 3 of the License, or (at your    //
// option) any later version. This program is distributed in the hope that   //
// it will be useful, but WITHOUT ANY WARRANTY; without even the implied     //
// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the  //
// GNU General Public License for more details. You should have received a   //
// copy of the GNU General Public License along with this program. If not,   //
// see <http://www.gnu.org/licenses/>.                                       //
///////////////////////////////////////////////////////////////////////////////


#ifndef SCHWAEMM_CFG_H
#define SCHWAEMM_CFG_H

// Define the SCHWAEMM instance here (api.h has to match!). The main instance
// is SCHWAEMM256_128, which has a block size of 256 bits and a key size of 128
// bits. Other instances of SCHWAEMM are SCHWAEMM128_128, SCHWAEMM192_192, and
// SCHWAEMM256_256.

#define SCHWAEMM128_128

// The identifier SPARKLE_ASSEMBLER determines whether the low-level functions 
// in encrypt.c use the C implementation or an assembler implementation of the
// SPARKLE permutation. Currently, assembler code for SPARKLE exists for the
// AVR and ARM architecture.

#define SPARKLE_ASSEMBLER


///////////////////////////
#if defined SCHWAEMM128_128
///////////////////////////

#define SCHWAEMM_KEY_LEN    128
#define SCHWAEMM_NONCE_LEN  128
#define SCHWAEMM_TAG_LEN    128

#define SPARKLE_STATE       256
#define SPARKLE_RATE        128
#define SPARKLE_CAPACITY    128

#define SPARKLE_STEPS_SLIM  7
#define SPARKLE_STEPS_BIG   10


/////////////////////////////
#elif defined SCHWAEMM256_128
/////////////////////////////

#define SCHWAEMM_KEY_LEN    128
#define SCHWAEMM_NONCE_LEN  256
#define SCHWAEMM_TAG_LEN    128

#define SPARKLE_STATE       384
#define SPARKLE_RATE        256
#define SPARKLE_CAPACITY    128

#define SPARKLE_STEPS_SLIM  7
#define SPARKLE_STEPS_BIG   11


/////////////////////////////
#elif defined SCHWAEMM192_192
/////////////////////////////

#define SCHWAEMM_KEY_LEN    192
#define SCHWAEMM_NONCE_LEN  192
#define SCHWAEMM_TAG_LEN    192

#define SPARKLE_STATE       384
#define SPARKLE_RATE        192
#define SPARKLE_CAPACITY    192

#define SPARKLE_STEPS_SLIM  7
#define SPARKLE_STEPS_BIG   11


/////////////////////////////
#elif defined SCHWAEMM256_256
/////////////////////////////

#define SCHWAEMM_KEY_LEN    256
#define SCHWAEMM_NONCE_LEN  256
#define SCHWAEMM_TAG_LEN    256

#define SPARKLE_STATE       512
#define SPARKLE_RATE        256
#define SPARKLE_CAPACITY    256

#define SPARKLE_STEPS_SLIM  8
#define SPARKLE_STEPS_BIG   12


#else
#error "Invalid definition of SCHWAEMM instance!"
#endif

#endif  // SCHWAEMM_CFG_H