| /* |
| * Copyright 1995-2016 The OpenSSL Project Authors. All Rights Reserved. |
| * |
| * Licensed under the OpenSSL license (the "License"). You may not use |
| * this file except in compliance with the License. You can obtain a copy |
| * in the file LICENSE in the source distribution or at |
| * https://www.openssl.org/source/license.html |
| */ |
| |
| #ifndef OPENSSL_HEADER_BLOWFISH_H |
| #define OPENSSL_HEADER_BLOWFISH_H |
| |
| #include <openssl/base.h> |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| |
| #define BF_ENCRYPT 1 |
| #define BF_DECRYPT 0 |
| |
| #define BF_ROUNDS 16 |
| #define BF_BLOCK 8 |
| |
| typedef struct bf_key_st { |
| uint32_t P[BF_ROUNDS + 2]; |
| uint32_t S[4 * 256]; |
| } BF_KEY; |
| |
| OPENSSL_EXPORT void BF_set_key(BF_KEY *key, size_t len, const uint8_t *data); |
| OPENSSL_EXPORT void BF_encrypt(uint32_t *data, const BF_KEY *key); |
| OPENSSL_EXPORT void BF_decrypt(uint32_t *data, const BF_KEY *key); |
| |
| OPENSSL_EXPORT void BF_ecb_encrypt(const uint8_t *in, uint8_t *out, |
| const BF_KEY *key, int enc); |
| OPENSSL_EXPORT void BF_cbc_encrypt(const uint8_t *in, uint8_t *out, |
| size_t length, const BF_KEY *schedule, |
| uint8_t *ivec, int enc); |
| |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #endif // OPENSSL_HEADER_BLOWFISH_H |