2009-09-23 23:32:31 +02:00
|
|
|
#ifndef RIJNDAEL_INCLUDED
|
|
|
|
#define RIJNDAEL_INCLUDED
|
|
|
|
|
2006-12-31 01:02:27 +01:00
|
|
|
/* Copyright (C) 2002 MySQL AB
|
2002-06-14 15:14:30 +04:00
|
|
|
|
|
|
|
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
|
2006-12-23 20:17:15 +01:00
|
|
|
the Free Software Foundation; version 2 of the License.
|
2002-06-19 00:22:30 +03:00
|
|
|
|
2002-06-14 15:14:30 +04:00
|
|
|
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.
|
2002-06-19 00:22:30 +03:00
|
|
|
|
2002-06-14 15:14:30 +04:00
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
2002-06-19 00:22:30 +03:00
|
|
|
|
|
|
|
|
2002-06-11 13:37:48 +04:00
|
|
|
/*
|
2002-06-19 00:22:30 +03:00
|
|
|
rijndael-alg-fst.h
|
|
|
|
|
|
|
|
@version 3.0 (December 2000)
|
|
|
|
Optimised ANSI C code for the Rijndael cipher (now AES)
|
|
|
|
@author Vincent Rijmen <vincent.rijmen@esat.kuleuven.ac.be>
|
|
|
|
@author Antoon Bosselaers <antoon.bosselaers@esat.kuleuven.ac.be>
|
|
|
|
@author Paulo Barreto <paulo.barreto@terra.com.br>
|
|
|
|
|
|
|
|
This code is hereby placed in the public domain.
|
|
|
|
Modified by Peter Zaitsev to fit MySQL coding style.
|
2002-06-11 13:37:48 +04:00
|
|
|
*/
|
|
|
|
|
2002-06-19 00:22:30 +03:00
|
|
|
#define AES_MAXKC (256/32)
|
|
|
|
#define AES_MAXKB (256/8)
|
|
|
|
#define AES_MAXNR 14
|
2002-06-11 13:37:48 +04:00
|
|
|
|
2002-06-19 00:22:30 +03:00
|
|
|
int rijndaelKeySetupEnc(uint32 rk[/*4*(Nr + 1)*/], const uint8 cipherKey[],
|
|
|
|
int keyBits);
|
2002-06-11 13:37:48 +04:00
|
|
|
int rijndaelKeySetupDec(uint32 rk[/*4*(Nr + 1)*/], const uint8 cipherKey[],
|
2002-06-19 00:22:30 +03:00
|
|
|
int keyBits);
|
2002-06-11 13:37:48 +04:00
|
|
|
void rijndaelEncrypt(const uint32 rk[/*4*(Nr + 1)*/], int Nr,
|
2002-06-19 00:22:30 +03:00
|
|
|
const uint8 pt[16], uint8 ct[16]);
|
2002-06-11 13:37:48 +04:00
|
|
|
void rijndaelDecrypt(const uint32 rk[/*4*(Nr + 1)*/], int Nr,
|
2002-06-19 00:22:30 +03:00
|
|
|
const uint8 ct[16], uint8 pt[16]);
|
2009-09-23 23:32:31 +02:00
|
|
|
|
|
|
|
#endif /* RIJNDAEL_INCLUDED */
|