|
Packit Service |
8264ee |
/*
|
|
Packit Service |
8264ee |
*
|
|
Packit Service |
8264ee |
* Embedded Linux library
|
|
Packit Service |
8264ee |
*
|
|
Packit Service |
8264ee |
* Copyright (C) 2015 Intel Corporation. All rights reserved.
|
|
Packit Service |
8264ee |
*
|
|
Packit Service |
8264ee |
* This library is free software; you can redistribute it and/or
|
|
Packit Service |
8264ee |
* modify it under the terms of the GNU Lesser General Public
|
|
Packit Service |
8264ee |
* License as published by the Free Software Foundation; either
|
|
Packit Service |
8264ee |
* version 2.1 of the License, or (at your option) any later version.
|
|
Packit Service |
8264ee |
*
|
|
Packit Service |
8264ee |
* This library is distributed in the hope that it will be useful,
|
|
Packit Service |
8264ee |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit Service |
8264ee |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit Service |
8264ee |
* Lesser General Public License for more details.
|
|
Packit Service |
8264ee |
*
|
|
Packit Service |
8264ee |
* You should have received a copy of the GNU Lesser General Public
|
|
Packit Service |
8264ee |
* License along with this library; if not, write to the Free Software
|
|
Packit Service |
8264ee |
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
Packit Service |
8264ee |
*
|
|
Packit Service |
8264ee |
*/
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
#ifndef __ELL_CIPHER_H
|
|
Packit Service |
8264ee |
#define __ELL_CIPHER_H
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
#ifdef __cplusplus
|
|
Packit Service |
8264ee |
extern "C" {
|
|
Packit Service |
8264ee |
#endif
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
struct l_cipher;
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
enum l_cipher_type {
|
|
Packit Service |
8264ee |
L_CIPHER_AES = 0,
|
|
Packit Service |
8264ee |
L_CIPHER_AES_CBC,
|
|
Packit Service |
8264ee |
L_CIPHER_AES_CTR,
|
|
Packit Service |
8264ee |
L_CIPHER_ARC4,
|
|
Packit Service |
8264ee |
L_CIPHER_DES,
|
|
Packit Service |
8264ee |
L_CIPHER_DES_CBC,
|
|
Packit Service |
8264ee |
L_CIPHER_DES3_EDE_CBC,
|
|
Packit Service |
8264ee |
};
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
struct l_cipher *l_cipher_new(enum l_cipher_type type,
|
|
Packit Service |
8264ee |
const void *key, size_t key_length);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
void l_cipher_free(struct l_cipher *cipher);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
bool l_cipher_encrypt(struct l_cipher *cipher,
|
|
Packit Service |
8264ee |
const void *in, void *out, size_t len);
|
|
Packit Service |
8264ee |
bool l_cipher_encryptv(struct l_cipher *cipher,
|
|
Packit Service |
8264ee |
const struct iovec *in, size_t in_cnt,
|
|
Packit Service |
8264ee |
const struct iovec *out, size_t out_cnt);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
bool l_cipher_decrypt(struct l_cipher *cipher,
|
|
Packit Service |
8264ee |
const void *in, void *out, size_t len);
|
|
Packit Service |
8264ee |
bool l_cipher_decryptv(struct l_cipher *cipher,
|
|
Packit Service |
8264ee |
const struct iovec *in, size_t in_cnt,
|
|
Packit Service |
8264ee |
const struct iovec *out, size_t out_cnt);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
bool l_cipher_set_iv(struct l_cipher *cipher, const uint8_t *iv,
|
|
Packit Service |
8264ee |
size_t iv_length);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
struct l_aead_cipher;
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
enum l_aead_cipher_type {
|
|
Packit Service |
8264ee |
L_AEAD_CIPHER_AES_CCM = 0,
|
|
Packit Service |
8264ee |
L_AEAD_CIPHER_AES_GCM,
|
|
Packit Service |
8264ee |
};
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
struct l_aead_cipher *l_aead_cipher_new(enum l_aead_cipher_type type,
|
|
Packit Service |
8264ee |
const void *key, size_t key_length,
|
|
Packit Service |
8264ee |
size_t tag_length);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
void l_aead_cipher_free(struct l_aead_cipher *cipher);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
bool l_aead_cipher_encrypt(struct l_aead_cipher *cipher,
|
|
Packit Service |
8264ee |
const void *in, size_t in_len,
|
|
Packit Service |
8264ee |
const void *ad, size_t ad_len,
|
|
Packit Service |
8264ee |
const void *nonce, size_t nonce_len,
|
|
Packit Service |
8264ee |
void *out, size_t out_len);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
bool l_aead_cipher_decrypt(struct l_aead_cipher *cipher,
|
|
Packit Service |
8264ee |
const void *in, size_t in_len,
|
|
Packit Service |
8264ee |
const void *ad, size_t ad_len,
|
|
Packit Service |
8264ee |
const void *nonce, size_t nonce_len,
|
|
Packit Service |
8264ee |
void *out, size_t out_len);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
bool l_cipher_is_supported(enum l_cipher_type type);
|
|
Packit Service |
8264ee |
bool l_aead_cipher_is_supported(enum l_aead_cipher_type type);
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
#ifdef __cplusplus
|
|
Packit Service |
8264ee |
}
|
|
Packit Service |
8264ee |
#endif
|
|
Packit Service |
8264ee |
|
|
Packit Service |
8264ee |
#endif /* __ELL_CIPHER_H */
|