Select one of the symbols to view example projects that use it.
 
Outline
#define AES_H
#define N_ROW
#define N_COL
#define N_BLOCK
#define N_MAX_ROUNDS
uint_8t
return_type
length_type
aes_context
aes_set_key(const unsigned char *, length_type, aes_context *);
bluedroid_aes_encrypt(const unsigned char *, unsigned char *, const aes_context *);
aes_cbc_encrypt(const unsigned char *, unsigned char *, int, unsigned char *, const aes_context *);
bluedroid_aes_decrypt(const unsigned char *, unsigned char *, const aes_context *);
aes_cbc_decrypt(const unsigned char *, unsigned char *, int, unsigned char *, const aes_context *);
bluedroid_aes_encrypt_128(const unsigned char *, unsigned char *, const unsigned char *, unsigned char *);
bluedroid_aes_decrypt_128(const unsigned char *, unsigned char *, const unsigned char *, unsigned char *);
bluedroid_aes_encrypt_256(const unsigned char *, unsigned char *, const unsigned char *, unsigned char *);
bluedroid_aes_decrypt_256(const unsigned char *, unsigned char *, const unsigned char *, unsigned char *);
Files
loading (4/5)...
SourceVuESP-IDF Framework and ExamplesESP-IDFcomponents/bt/host/bluedroid/stack/smp/include/aes.h
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* --------------------------------------------------------------------------- Copyright (c) 1998-2008, Brian Gladman, Worcester, UK. All rights reserved. LICENSE TERMS The redistribution and use of this software (with or without changes) is allowed without the payment of fees or royalties provided that: 1. source code distributions include the above copyright notice, this list of conditions and the following disclaimer; 2. binary distributions include the above copyright notice, this list of conditions and the following disclaimer in their documentation; 3. the name of the copyright holder is not used to endorse products built using this software without specific written permission. DISCLAIMER This software is provided 'as is' with no explicit or implied warranties in respect of its properties, including, but not limited to, correctness and/or fitness for purpose. --------------------------------------------------------------------------- Issue 09/09/2006 This is an AES implementation that uses only 8-bit byte operations on the cipher state. *//* ... */ #ifndef AES_H #define AES_H #if 1 # define AES_ENC_PREKEYED /* AES encryption with a precomputed key schedule */ #endif #if 1 # define AES_DEC_PREKEYED /* AES decryption with a precomputed key schedule */ #endif #if 1 # define AES_ENC_128_OTFK /* AES encryption with 'on the fly' 128 bit keying */ #endif #if 1 # define AES_DEC_128_OTFK /* AES decryption with 'on the fly' 128 bit keying */ #endif #if 1 # define AES_ENC_256_OTFK /* AES encryption with 'on the fly' 256 bit keying */ #endif #if 1 # define AES_DEC_256_OTFK /* AES decryption with 'on the fly' 256 bit keying */ #endif #define N_ROW 4 #define N_COL 4 #define N_BLOCK (N_ROW * N_COL) #define N_MAX_ROUNDS 14 typedef unsigned char uint_8t; typedef uint_8t return_type; /* Warning: The key length for 256 bit keys overflows a byte (see comment below) *//* ... */ typedef uint_8t length_type; typedef struct { uint_8t ksch[(N_MAX_ROUNDS + 1) * N_BLOCK]; uint_8t rnd; }{ ... } aes_context; /* The following calls are for a precomputed key schedule NOTE: If the length_type used for the key length is an unsigned 8-bit character, a key length of 256 bits must be entered as a length in bytes (valid inputs are hence 128, 192, 16, 24 and 32). *//* ... */ #if defined( AES_ENC_PREKEYED ) || defined( AES_DEC_PREKEYED ) return_type aes_set_key( const unsigned char key[], length_type keylen, aes_context ctx[1] );/* ... */ #endif #if defined( AES_ENC_PREKEYED ) return_type bluedroid_aes_encrypt( const unsigned char in[N_BLOCK], unsigned char out[N_BLOCK], const aes_context ctx[1] ); return_type aes_cbc_encrypt( const unsigned char *in, unsigned char *out, int n_block, unsigned char iv[N_BLOCK], const aes_context ctx[1] );/* ... */ #endif #if defined( AES_DEC_PREKEYED ) return_type bluedroid_aes_decrypt( const unsigned char in[N_BLOCK], unsigned char out[N_BLOCK], const aes_context ctx[1] ); return_type aes_cbc_decrypt( const unsigned char *in, unsigned char *out, int n_block, unsigned char iv[N_BLOCK], const aes_context ctx[1] );/* ... */ #endif /* The following calls are for 'on the fly' keying. In this case the encryption and decryption keys are different. The encryption subroutines take a key in an array of bytes in key[L] where L is 16, 24 or 32 bytes for key lengths of 128, 192, and 256 bits respectively. They then encrypts the input data, in[] with this key and put the reult in the output array out[]. In addition, the second key array, o_key[L], is used to output the key that is needed by the decryption subroutine to reverse the encryption operation. The two key arrays can be the same array but in this case the original key will be overwritten. In the same way, the decryption subroutines output keys that can be used to reverse their effect when used for encryption. Only 128 and 256 bit keys are supported in these 'on the fly' modes. *//* ... */ #if defined( AES_ENC_128_OTFK ) void bluedroid_aes_encrypt_128( const unsigned char in[N_BLOCK], unsigned char out[N_BLOCK], const unsigned char key[N_BLOCK], uint_8t o_key[N_BLOCK] );/* ... */ #endif #if defined( AES_DEC_128_OTFK ) void bluedroid_aes_decrypt_128( const unsigned char in[N_BLOCK], unsigned char out[N_BLOCK], const unsigned char key[N_BLOCK], unsigned char o_key[N_BLOCK] );/* ... */ #endif #if defined( AES_ENC_256_OTFK ) void bluedroid_aes_encrypt_256( const unsigned char in[N_BLOCK], unsigned char out[N_BLOCK], const unsigned char key[2 * N_BLOCK], unsigned char o_key[2 * N_BLOCK] );/* ... */ #endif #if defined( AES_DEC_256_OTFK ) void bluedroid_aes_decrypt_256( const unsigned char in[N_BLOCK], unsigned char out[N_BLOCK], const unsigned char key[2 * N_BLOCK], unsigned char o_key[2 * N_BLOCK] );/* ... */ #endif /* ... */ #endif
Details
Show:
from
Types: Columns: