Marcelo H. Cerri | 8676590 | 2015-02-06 14:57:22 -0200 | [diff] [blame] | 1 | #include <linux/types.h> |
| 2 | #include <crypto/aes.h> |
| 3 | |
| 4 | #define AES_BLOCK_MASK (~(AES_BLOCK_SIZE-1)) |
| 5 | |
| 6 | struct aes_key { |
Herbert Xu | 4beb106 | 2015-06-15 16:55:46 +0800 | [diff] [blame] | 7 | u8 key[AES_MAX_KEYLENGTH]; |
| 8 | int rounds; |
Marcelo H. Cerri | 8676590 | 2015-02-06 14:57:22 -0200 | [diff] [blame] | 9 | }; |
| 10 | |
| 11 | int aes_p8_set_encrypt_key(const u8 *userKey, const int bits, |
Herbert Xu | 4beb106 | 2015-06-15 16:55:46 +0800 | [diff] [blame] | 12 | struct aes_key *key); |
Marcelo H. Cerri | 8676590 | 2015-02-06 14:57:22 -0200 | [diff] [blame] | 13 | int aes_p8_set_decrypt_key(const u8 *userKey, const int bits, |
Herbert Xu | 4beb106 | 2015-06-15 16:55:46 +0800 | [diff] [blame] | 14 | struct aes_key *key); |
Marcelo H. Cerri | 8676590 | 2015-02-06 14:57:22 -0200 | [diff] [blame] | 15 | void aes_p8_encrypt(const u8 *in, u8 *out, const struct aes_key *key); |
Herbert Xu | 4beb106 | 2015-06-15 16:55:46 +0800 | [diff] [blame] | 16 | void aes_p8_decrypt(const u8 *in, u8 *out, const struct aes_key *key); |
Marcelo H. Cerri | 8676590 | 2015-02-06 14:57:22 -0200 | [diff] [blame] | 17 | void aes_p8_cbc_encrypt(const u8 *in, u8 *out, size_t len, |
Herbert Xu | 4beb106 | 2015-06-15 16:55:46 +0800 | [diff] [blame] | 18 | const struct aes_key *key, u8 *iv, const int enc); |
Marcelo H. Cerri | 8676590 | 2015-02-06 14:57:22 -0200 | [diff] [blame] | 19 | void aes_p8_ctr32_encrypt_blocks(const u8 *in, u8 *out, |
Herbert Xu | 4beb106 | 2015-06-15 16:55:46 +0800 | [diff] [blame] | 20 | size_t len, const struct aes_key *key, |
| 21 | const u8 *iv); |
Paulo Flabiano Smorigo | 11c6e16 | 2016-07-18 12:26:25 -0300 | [diff] [blame] | 22 | void aes_p8_xts_encrypt(const u8 *in, u8 *out, size_t len, |
| 23 | const struct aes_key *key1, const struct aes_key *key2, u8 *iv); |
| 24 | void aes_p8_xts_decrypt(const u8 *in, u8 *out, size_t len, |
| 25 | const struct aes_key *key1, const struct aes_key *key2, u8 *iv); |