/////////////////////////////////////////////////////////////////////////////// // sparkle_ref.h: Reference C99 implementation of the SPARKLE permutation. // // This file is part of the SPARKLE submission to NIST's LW Crypto Project. // // Version 1.1.2 (2020-10-30), see 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 . // // ------------------------------------------------------------------------- // // 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 . // /////////////////////////////////////////////////////////////////////////////// #ifndef SPARKLE_REF_H #define SPARKLE_REF_H #if defined(_MSC_VER) && !defined(__clang__) && !defined(__ICL) typedef unsigned __int8 uint8_t; typedef unsigned __int32 uint32_t; #else #include #endif // _MSC_VER #define MAX_BRANCHES 8 typedef struct { uint32_t x[MAX_BRANCHES]; uint32_t y[MAX_BRANCHES]; } SparkleState; void sparkle_ref(SparkleState *state, int brans, int steps); void sparkle_inv_ref(SparkleState *state, int brans, int steps); void clear_state_ref(SparkleState *state, int brans); void print_state_ref(const SparkleState *state, int brans); void test_sparkle_ref(int brans, int steps); #endif // SPARKLE_REF_H