2010-09-21 04:08:53 +08:00
|
|
|
/* contrib/pgcrypto/blf.h */
|
2001-08-21 09:32:01 +08:00
|
|
|
/*
|
2007-03-29 06:48:58 +08:00
|
|
|
* PuTTY is copyright 1997-2007 Simon Tatham.
|
2001-08-21 09:32:01 +08:00
|
|
|
*
|
2007-03-29 06:48:58 +08:00
|
|
|
* Portions copyright Robert de Bath, Joris van Rantwijk, Delian
|
|
|
|
* Delchev, Andreas Schultz, Jeroen Massar, Wez Furlong, Nicolas Barry,
|
|
|
|
* Justin Bradford, Ben Harris, Malcolm Smith, Ahmad Khalifa, Markus
|
|
|
|
* Kuhn, and CORE SDI S.A.
|
2001-08-21 09:32:01 +08:00
|
|
|
*
|
2007-03-29 06:48:58 +08:00
|
|
|
* Permission is hereby granted, free of charge, to any person
|
|
|
|
* obtaining a copy of this software and associated documentation files
|
|
|
|
* (the "Software"), to deal in the Software without restriction,
|
|
|
|
* including without limitation the rights to use, copy, modify, merge,
|
|
|
|
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
|
|
* and to permit persons to whom the Software is furnished to do so,
|
|
|
|
* subject to the following conditions:
|
2001-08-21 09:32:01 +08:00
|
|
|
*
|
2007-03-29 06:48:58 +08:00
|
|
|
* The above copyright notice and this permission notice shall be
|
|
|
|
* included in all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE
|
|
|
|
* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
|
|
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
|
|
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
2001-08-21 09:32:01 +08:00
|
|
|
*/
|
|
|
|
|
2007-03-29 06:48:58 +08:00
|
|
|
typedef struct
|
2001-10-25 13:50:21 +08:00
|
|
|
{
|
2007-03-29 06:48:58 +08:00
|
|
|
uint32 S0[256],
|
|
|
|
S1[256],
|
|
|
|
S2[256],
|
|
|
|
S3[256],
|
|
|
|
P[18];
|
|
|
|
uint32 iv0,
|
2007-11-16 05:14:46 +08:00
|
|
|
iv1; /* for CBC mode */
|
2009-06-11 22:49:15 +08:00
|
|
|
} BlowfishContext;
|
2001-10-28 14:26:15 +08:00
|
|
|
|
2009-06-11 22:49:15 +08:00
|
|
|
void blowfish_setkey(BlowfishContext *ctx, const uint8 *key, short keybytes);
|
|
|
|
void blowfish_setiv(BlowfishContext *ctx, const uint8 *iv);
|
|
|
|
void blowfish_encrypt_cbc(uint8 *blk, int len, BlowfishContext *ctx);
|
|
|
|
void blowfish_decrypt_cbc(uint8 *blk, int len, BlowfishContext *ctx);
|
|
|
|
void blowfish_encrypt_ecb(uint8 *blk, int len, BlowfishContext *ctx);
|
|
|
|
void blowfish_decrypt_ecb(uint8 *blk, int len, BlowfishContext *ctx);
|