1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3 * Copyright 2003-2004, Instant802 Networks, Inc.
4 * Copyright 2006, Devicescape Software, Inc.
5 */
6
7 #ifndef AES_CCM_H
8 #define AES_CCM_H
9
10 #include "aead_api.h"
11
12 #define CCM_AAD_LEN 32
13
14 static inline struct crypto_aead *
ieee80211_aes_key_setup_encrypt(const u8 key[],size_t key_len,size_t mic_len)15 ieee80211_aes_key_setup_encrypt(const u8 key[], size_t key_len, size_t mic_len)
16 {
17 return aead_key_setup_encrypt("ccm(aes)", key, key_len, mic_len);
18 }
19
20 static inline int
ieee80211_aes_ccm_encrypt(struct crypto_aead * tfm,u8 * b_0,u8 * aad,u8 * data,size_t data_len,u8 * mic)21 ieee80211_aes_ccm_encrypt(struct crypto_aead *tfm,
22 u8 *b_0, u8 *aad, u8 *data,
23 size_t data_len, u8 *mic)
24 {
25 return aead_encrypt(tfm, b_0, aad + 2,
26 be16_to_cpup((__be16 *)aad),
27 data, data_len, mic);
28 }
29
30 static inline int
ieee80211_aes_ccm_decrypt(struct crypto_aead * tfm,u8 * b_0,u8 * aad,u8 * data,size_t data_len,u8 * mic)31 ieee80211_aes_ccm_decrypt(struct crypto_aead *tfm,
32 u8 *b_0, u8 *aad, u8 *data,
33 size_t data_len, u8 *mic)
34 {
35 return aead_decrypt(tfm, b_0, aad + 2,
36 be16_to_cpup((__be16 *)aad),
37 data, data_len, mic);
38 }
39
ieee80211_aes_key_free(struct crypto_aead * tfm)40 static inline void ieee80211_aes_key_free(struct crypto_aead *tfm)
41 {
42 return aead_key_free(tfm);
43 }
44
45 #endif /* AES_CCM_H */
46