blob: 96256193cf49f1e01c3062b19c9458f9c0a2a309 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Jiri Bencf0706e82007-05-05 11:45:53 -07002/*
3 * Copyright 2003-2004, Instant802 Networks, Inc.
4 * Copyright 2006, Devicescape Software, Inc.
Jiri Bencf0706e82007-05-05 11:45:53 -07005 */
6
7#ifndef AES_CCM_H
8#define AES_CCM_H
9
Xiang Gao4133da72017-10-10 22:31:49 -040010#include "aead_api.h"
Jiri Bencf0706e82007-05-05 11:45:53 -070011
Ard Biesheuvelf4a067f2016-10-17 15:05:33 +010012#define CCM_AAD_LEN 32
13
Xiang Gao4133da72017-10-10 22:31:49 -040014static inline struct crypto_aead *
15ieee80211_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
20static inline int
21ieee80211_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
30static inline int
31ieee80211_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
40static inline void ieee80211_aes_key_free(struct crypto_aead *tfm)
41{
42 return aead_key_free(tfm);
43}
Jiri Bencf0706e82007-05-05 11:45:53 -070044
45#endif /* AES_CCM_H */