1 /*
2 * Camellia implementation
3 *
4 * Copyright The Mbed TLS Contributors
5 * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
6 *
7 * This file is provided under the Apache License 2.0, or the
8 * GNU General Public License v2.0 or later.
9 *
10 * **********
11 * Apache License 2.0:
12 *
13 * Licensed under the Apache License, Version 2.0 (the "License"); you may
14 * not use this file except in compliance with the License.
15 * You may obtain a copy of the License at
16 *
17 * http://www.apache.org/licenses/LICENSE-2.0
18 *
19 * Unless required by applicable law or agreed to in writing, software
20 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
21 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
22 * See the License for the specific language governing permissions and
23 * limitations under the License.
24 *
25 * **********
26 *
27 * **********
28 * GNU General Public License v2.0 or later:
29 *
30 * This program is free software; you can redistribute it and/or modify
31 * it under the terms of the GNU General Public License as published by
32 * the Free Software Foundation; either version 2 of the License, or
33 * (at your option) any later version.
34 *
35 * This program is distributed in the hope that it will be useful,
36 * but WITHOUT ANY WARRANTY; without even the implied warranty of
37 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
38 * GNU General Public License for more details.
39 *
40 * You should have received a copy of the GNU General Public License along
41 * with this program; if not, write to the Free Software Foundation, Inc.,
42 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
43 *
44 * **********
45 */
46 /*
47 * The Camellia block cipher was designed by NTT and Mitsubishi Electric
48 * Corporation.
49 *
50 * http://info.isl.ntt.co.jp/crypt/eng/camellia/dl/01espec.pdf
51 */
52
53 #if !defined(MBEDTLS_CONFIG_FILE)
54 #include "mbedtls/config.h"
55 #else
56 #include MBEDTLS_CONFIG_FILE
57 #endif
58
59 #if defined(MBEDTLS_CAMELLIA_C)
60
61 #include "mbedtls/camellia.h"
62 #include "mbedtls/platform_util.h"
63
64 #include <string.h>
65
66 #if defined(MBEDTLS_SELF_TEST)
67 #if defined(MBEDTLS_PLATFORM_C)
68 #include "mbedtls/platform.h"
69 #else
70 #include <stdio.h>
71 #define mbedtls_printf printf
72 #endif /* MBEDTLS_PLATFORM_C */
73 #endif /* MBEDTLS_SELF_TEST */
74
75 #if !defined(MBEDTLS_CAMELLIA_ALT)
76
77 /* Parameter validation macros */
78 #define CAMELLIA_VALIDATE_RET( cond ) \
79 MBEDTLS_INTERNAL_VALIDATE_RET( cond, MBEDTLS_ERR_CAMELLIA_BAD_INPUT_DATA )
80 #define CAMELLIA_VALIDATE( cond ) \
81 MBEDTLS_INTERNAL_VALIDATE( cond )
82
83 /*
84 * 32-bit integer manipulation macros (big endian)
85 */
86 #ifndef GET_UINT32_BE
87 #define GET_UINT32_BE(n,b,i) \
88 { \
89 (n) = ( (uint32_t) (b)[(i) ] << 24 ) \
90 | ( (uint32_t) (b)[(i) + 1] << 16 ) \
91 | ( (uint32_t) (b)[(i) + 2] << 8 ) \
92 | ( (uint32_t) (b)[(i) + 3] ); \
93 }
94 #endif
95
96 #ifndef PUT_UINT32_BE
97 #define PUT_UINT32_BE(n,b,i) \
98 { \
99 (b)[(i) ] = (unsigned char) ( (n) >> 24 ); \
100 (b)[(i) + 1] = (unsigned char) ( (n) >> 16 ); \
101 (b)[(i) + 2] = (unsigned char) ( (n) >> 8 ); \
102 (b)[(i) + 3] = (unsigned char) ( (n) ); \
103 }
104 #endif
105
106 static const unsigned char SIGMA_CHARS[6][8] =
107 {
108 { 0xa0, 0x9e, 0x66, 0x7f, 0x3b, 0xcc, 0x90, 0x8b },
109 { 0xb6, 0x7a, 0xe8, 0x58, 0x4c, 0xaa, 0x73, 0xb2 },
110 { 0xc6, 0xef, 0x37, 0x2f, 0xe9, 0x4f, 0x82, 0xbe },
111 { 0x54, 0xff, 0x53, 0xa5, 0xf1, 0xd3, 0x6f, 0x1c },
112 { 0x10, 0xe5, 0x27, 0xfa, 0xde, 0x68, 0x2d, 0x1d },
113 { 0xb0, 0x56, 0x88, 0xc2, 0xb3, 0xe6, 0xc1, 0xfd }
114 };
115
116 #if defined(MBEDTLS_CAMELLIA_SMALL_MEMORY)
117
118 static const unsigned char FSb[256] =
119 {
120 112,130, 44,236,179, 39,192,229,228,133, 87, 53,234, 12,174, 65,
121 35,239,107,147, 69, 25,165, 33,237, 14, 79, 78, 29,101,146,189,
122 134,184,175,143,124,235, 31,206, 62, 48,220, 95, 94,197, 11, 26,
123 166,225, 57,202,213, 71, 93, 61,217, 1, 90,214, 81, 86,108, 77,
124 139, 13,154,102,251,204,176, 45,116, 18, 43, 32,240,177,132,153,
125 223, 76,203,194, 52,126,118, 5,109,183,169, 49,209, 23, 4,215,
126 20, 88, 58, 97,222, 27, 17, 28, 50, 15,156, 22, 83, 24,242, 34,
127 254, 68,207,178,195,181,122,145, 36, 8,232,168, 96,252,105, 80,
128 170,208,160,125,161,137, 98,151, 84, 91, 30,149,224,255,100,210,
129 16,196, 0, 72,163,247,117,219,138, 3,230,218, 9, 63,221,148,
130 135, 92,131, 2,205, 74,144, 51,115,103,246,243,157,127,191,226,
131 82,155,216, 38,200, 55,198, 59,129,150,111, 75, 19,190, 99, 46,
132 233,121,167,140,159,110,188,142, 41,245,249,182, 47,253,180, 89,
133 120,152, 6,106,231, 70,113,186,212, 37,171, 66,136,162,141,250,
134 114, 7,185, 85,248,238,172, 10, 54, 73, 42,104, 60, 56,241,164,
135 64, 40,211,123,187,201, 67,193, 21,227,173,244,119,199,128,158
136 };
137
138 #define SBOX1(n) FSb[(n)]
139 #define SBOX2(n) (unsigned char)((FSb[(n)] >> 7 ^ FSb[(n)] << 1) & 0xff)
140 #define SBOX3(n) (unsigned char)((FSb[(n)] >> 1 ^ FSb[(n)] << 7) & 0xff)
141 #define SBOX4(n) FSb[((n) << 1 ^ (n) >> 7) &0xff]
142
143 #else /* MBEDTLS_CAMELLIA_SMALL_MEMORY */
144
145 static const unsigned char FSb[256] =
146 {
147 112, 130, 44, 236, 179, 39, 192, 229, 228, 133, 87, 53, 234, 12, 174, 65,
148 35, 239, 107, 147, 69, 25, 165, 33, 237, 14, 79, 78, 29, 101, 146, 189,
149 134, 184, 175, 143, 124, 235, 31, 206, 62, 48, 220, 95, 94, 197, 11, 26,
150 166, 225, 57, 202, 213, 71, 93, 61, 217, 1, 90, 214, 81, 86, 108, 77,
151 139, 13, 154, 102, 251, 204, 176, 45, 116, 18, 43, 32, 240, 177, 132, 153,
152 223, 76, 203, 194, 52, 126, 118, 5, 109, 183, 169, 49, 209, 23, 4, 215,
153 20, 88, 58, 97, 222, 27, 17, 28, 50, 15, 156, 22, 83, 24, 242, 34,
154 254, 68, 207, 178, 195, 181, 122, 145, 36, 8, 232, 168, 96, 252, 105, 80,
155 170, 208, 160, 125, 161, 137, 98, 151, 84, 91, 30, 149, 224, 255, 100, 210,
156 16, 196, 0, 72, 163, 247, 117, 219, 138, 3, 230, 218, 9, 63, 221, 148,
157 135, 92, 131, 2, 205, 74, 144, 51, 115, 103, 246, 243, 157, 127, 191, 226,
158 82, 155, 216, 38, 200, 55, 198, 59, 129, 150, 111, 75, 19, 190, 99, 46,
159 233, 121, 167, 140, 159, 110, 188, 142, 41, 245, 249, 182, 47, 253, 180, 89,
160 120, 152, 6, 106, 231, 70, 113, 186, 212, 37, 171, 66, 136, 162, 141, 250,
161 114, 7, 185, 85, 248, 238, 172, 10, 54, 73, 42, 104, 60, 56, 241, 164,
162 64, 40, 211, 123, 187, 201, 67, 193, 21, 227, 173, 244, 119, 199, 128, 158
163 };
164
165 static const unsigned char FSb2[256] =
166 {
167 224, 5, 88, 217, 103, 78, 129, 203, 201, 11, 174, 106, 213, 24, 93, 130,
168 70, 223, 214, 39, 138, 50, 75, 66, 219, 28, 158, 156, 58, 202, 37, 123,
169 13, 113, 95, 31, 248, 215, 62, 157, 124, 96, 185, 190, 188, 139, 22, 52,
170 77, 195, 114, 149, 171, 142, 186, 122, 179, 2, 180, 173, 162, 172, 216, 154,
171 23, 26, 53, 204, 247, 153, 97, 90, 232, 36, 86, 64, 225, 99, 9, 51,
172 191, 152, 151, 133, 104, 252, 236, 10, 218, 111, 83, 98, 163, 46, 8, 175,
173 40, 176, 116, 194, 189, 54, 34, 56, 100, 30, 57, 44, 166, 48, 229, 68,
174 253, 136, 159, 101, 135, 107, 244, 35, 72, 16, 209, 81, 192, 249, 210, 160,
175 85, 161, 65, 250, 67, 19, 196, 47, 168, 182, 60, 43, 193, 255, 200, 165,
176 32, 137, 0, 144, 71, 239, 234, 183, 21, 6, 205, 181, 18, 126, 187, 41,
177 15, 184, 7, 4, 155, 148, 33, 102, 230, 206, 237, 231, 59, 254, 127, 197,
178 164, 55, 177, 76, 145, 110, 141, 118, 3, 45, 222, 150, 38, 125, 198, 92,
179 211, 242, 79, 25, 63, 220, 121, 29, 82, 235, 243, 109, 94, 251, 105, 178,
180 240, 49, 12, 212, 207, 140, 226, 117, 169, 74, 87, 132, 17, 69, 27, 245,
181 228, 14, 115, 170, 241, 221, 89, 20, 108, 146, 84, 208, 120, 112, 227, 73,
182 128, 80, 167, 246, 119, 147, 134, 131, 42, 199, 91, 233, 238, 143, 1, 61
183 };
184
185 static const unsigned char FSb3[256] =
186 {
187 56, 65, 22, 118, 217, 147, 96, 242, 114, 194, 171, 154, 117, 6, 87, 160,
188 145, 247, 181, 201, 162, 140, 210, 144, 246, 7, 167, 39, 142, 178, 73, 222,
189 67, 92, 215, 199, 62, 245, 143, 103, 31, 24, 110, 175, 47, 226, 133, 13,
190 83, 240, 156, 101, 234, 163, 174, 158, 236, 128, 45, 107, 168, 43, 54, 166,
191 197, 134, 77, 51, 253, 102, 88, 150, 58, 9, 149, 16, 120, 216, 66, 204,
192 239, 38, 229, 97, 26, 63, 59, 130, 182, 219, 212, 152, 232, 139, 2, 235,
193 10, 44, 29, 176, 111, 141, 136, 14, 25, 135, 78, 11, 169, 12, 121, 17,
194 127, 34, 231, 89, 225, 218, 61, 200, 18, 4, 116, 84, 48, 126, 180, 40,
195 85, 104, 80, 190, 208, 196, 49, 203, 42, 173, 15, 202, 112, 255, 50, 105,
196 8, 98, 0, 36, 209, 251, 186, 237, 69, 129, 115, 109, 132, 159, 238, 74,
197 195, 46, 193, 1, 230, 37, 72, 153, 185, 179, 123, 249, 206, 191, 223, 113,
198 41, 205, 108, 19, 100, 155, 99, 157, 192, 75, 183, 165, 137, 95, 177, 23,
199 244, 188, 211, 70, 207, 55, 94, 71, 148, 250, 252, 91, 151, 254, 90, 172,
200 60, 76, 3, 53, 243, 35, 184, 93, 106, 146, 213, 33, 68, 81, 198, 125,
201 57, 131, 220, 170, 124, 119, 86, 5, 27, 164, 21, 52, 30, 28, 248, 82,
202 32, 20, 233, 189, 221, 228, 161, 224, 138, 241, 214, 122, 187, 227, 64, 79
203 };
204
205 static const unsigned char FSb4[256] =
206 {
207 112, 44, 179, 192, 228, 87, 234, 174, 35, 107, 69, 165, 237, 79, 29, 146,
208 134, 175, 124, 31, 62, 220, 94, 11, 166, 57, 213, 93, 217, 90, 81, 108,
209 139, 154, 251, 176, 116, 43, 240, 132, 223, 203, 52, 118, 109, 169, 209, 4,
210 20, 58, 222, 17, 50, 156, 83, 242, 254, 207, 195, 122, 36, 232, 96, 105,
211 170, 160, 161, 98, 84, 30, 224, 100, 16, 0, 163, 117, 138, 230, 9, 221,
212 135, 131, 205, 144, 115, 246, 157, 191, 82, 216, 200, 198, 129, 111, 19, 99,
213 233, 167, 159, 188, 41, 249, 47, 180, 120, 6, 231, 113, 212, 171, 136, 141,
214 114, 185, 248, 172, 54, 42, 60, 241, 64, 211, 187, 67, 21, 173, 119, 128,
215 130, 236, 39, 229, 133, 53, 12, 65, 239, 147, 25, 33, 14, 78, 101, 189,
216 184, 143, 235, 206, 48, 95, 197, 26, 225, 202, 71, 61, 1, 214, 86, 77,
217 13, 102, 204, 45, 18, 32, 177, 153, 76, 194, 126, 5, 183, 49, 23, 215,
218 88, 97, 27, 28, 15, 22, 24, 34, 68, 178, 181, 145, 8, 168, 252, 80,
219 208, 125, 137, 151, 91, 149, 255, 210, 196, 72, 247, 219, 3, 218, 63, 148,
220 92, 2, 74, 51, 103, 243, 127, 226, 155, 38, 55, 59, 150, 75, 190, 46,
221 121, 140, 110, 142, 245, 182, 253, 89, 152, 106, 70, 186, 37, 66, 162, 250,
222 7, 85, 238, 10, 73, 104, 56, 164, 40, 123, 201, 193, 227, 244, 199, 158
223 };
224
225 #define SBOX1(n) FSb[(n)]
226 #define SBOX2(n) FSb2[(n)]
227 #define SBOX3(n) FSb3[(n)]
228 #define SBOX4(n) FSb4[(n)]
229
230 #endif /* MBEDTLS_CAMELLIA_SMALL_MEMORY */
231
232 static const unsigned char shifts[2][4][4] =
233 {
234 {
235 { 1, 1, 1, 1 }, /* KL */
236 { 0, 0, 0, 0 }, /* KR */
237 { 1, 1, 1, 1 }, /* KA */
238 { 0, 0, 0, 0 } /* KB */
239 },
240 {
241 { 1, 0, 1, 1 }, /* KL */
242 { 1, 1, 0, 1 }, /* KR */
243 { 1, 1, 1, 0 }, /* KA */
244 { 1, 1, 0, 1 } /* KB */
245 }
246 };
247
248 static const signed char indexes[2][4][20] =
249 {
250 {
251 { 0, 1, 2, 3, 8, 9, 10, 11, 38, 39,
252 36, 37, 23, 20, 21, 22, 27, -1, -1, 26 }, /* KL -> RK */
253 { -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
254 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 }, /* KR -> RK */
255 { 4, 5, 6, 7, 12, 13, 14, 15, 16, 17,
256 18, 19, -1, 24, 25, -1, 31, 28, 29, 30 }, /* KA -> RK */
257 { -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
258 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 } /* KB -> RK */
259 },
260 {
261 { 0, 1, 2, 3, 61, 62, 63, 60, -1, -1,
262 -1, -1, 27, 24, 25, 26, 35, 32, 33, 34 }, /* KL -> RK */
263 { -1, -1, -1, -1, 8, 9, 10, 11, 16, 17,
264 18, 19, -1, -1, -1, -1, 39, 36, 37, 38 }, /* KR -> RK */
265 { -1, -1, -1, -1, 12, 13, 14, 15, 58, 59,
266 56, 57, 31, 28, 29, 30, -1, -1, -1, -1 }, /* KA -> RK */
267 { 4, 5, 6, 7, 65, 66, 67, 64, 20, 21,
268 22, 23, -1, -1, -1, -1, 43, 40, 41, 42 } /* KB -> RK */
269 }
270 };
271
272 static const signed char transposes[2][20] =
273 {
274 {
275 21, 22, 23, 20,
276 -1, -1, -1, -1,
277 18, 19, 16, 17,
278 11, 8, 9, 10,
279 15, 12, 13, 14
280 },
281 {
282 25, 26, 27, 24,
283 29, 30, 31, 28,
284 18, 19, 16, 17,
285 -1, -1, -1, -1,
286 -1, -1, -1, -1
287 }
288 };
289
290 /* Shift macro for 128 bit strings with rotation smaller than 32 bits (!) */
291 #define ROTL(DEST, SRC, SHIFT) \
292 { \
293 (DEST)[0] = (SRC)[0] << (SHIFT) ^ (SRC)[1] >> (32 - (SHIFT)); \
294 (DEST)[1] = (SRC)[1] << (SHIFT) ^ (SRC)[2] >> (32 - (SHIFT)); \
295 (DEST)[2] = (SRC)[2] << (SHIFT) ^ (SRC)[3] >> (32 - (SHIFT)); \
296 (DEST)[3] = (SRC)[3] << (SHIFT) ^ (SRC)[0] >> (32 - (SHIFT)); \
297 }
298
299 #define FL(XL, XR, KL, KR) \
300 { \
301 (XR) = ((((XL) & (KL)) << 1) | (((XL) & (KL)) >> 31)) ^ (XR); \
302 (XL) = ((XR) | (KR)) ^ (XL); \
303 }
304
305 #define FLInv(YL, YR, KL, KR) \
306 { \
307 (YL) = ((YR) | (KR)) ^ (YL); \
308 (YR) = ((((YL) & (KL)) << 1) | (((YL) & (KL)) >> 31)) ^ (YR); \
309 }
310
311 #define SHIFT_AND_PLACE(INDEX, OFFSET) \
312 { \
313 TK[0] = KC[(OFFSET) * 4 + 0]; \
314 TK[1] = KC[(OFFSET) * 4 + 1]; \
315 TK[2] = KC[(OFFSET) * 4 + 2]; \
316 TK[3] = KC[(OFFSET) * 4 + 3]; \
317 \
318 for( i = 1; i <= 4; i++ ) \
319 if( shifts[(INDEX)][(OFFSET)][i -1] ) \
320 ROTL(TK + i * 4, TK, ( 15 * i ) % 32); \
321 \
322 for( i = 0; i < 20; i++ ) \
323 if( indexes[(INDEX)][(OFFSET)][i] != -1 ) { \
324 RK[indexes[(INDEX)][(OFFSET)][i]] = TK[ i ]; \
325 } \
326 }
327
camellia_feistel(const uint32_t x[2],const uint32_t k[2],uint32_t z[2])328 static void camellia_feistel( const uint32_t x[2], const uint32_t k[2],
329 uint32_t z[2])
330 {
331 uint32_t I0, I1;
332 I0 = x[0] ^ k[0];
333 I1 = x[1] ^ k[1];
334
335 I0 = ((uint32_t) SBOX1((I0 >> 24) & 0xFF) << 24) |
336 ((uint32_t) SBOX2((I0 >> 16) & 0xFF) << 16) |
337 ((uint32_t) SBOX3((I0 >> 8) & 0xFF) << 8) |
338 ((uint32_t) SBOX4((I0 ) & 0xFF) );
339 I1 = ((uint32_t) SBOX2((I1 >> 24) & 0xFF) << 24) |
340 ((uint32_t) SBOX3((I1 >> 16) & 0xFF) << 16) |
341 ((uint32_t) SBOX4((I1 >> 8) & 0xFF) << 8) |
342 ((uint32_t) SBOX1((I1 ) & 0xFF) );
343
344 I0 ^= (I1 << 8) | (I1 >> 24);
345 I1 ^= (I0 << 16) | (I0 >> 16);
346 I0 ^= (I1 >> 8) | (I1 << 24);
347 I1 ^= (I0 >> 8) | (I0 << 24);
348
349 z[0] ^= I1;
350 z[1] ^= I0;
351 }
352
mbedtls_camellia_init(mbedtls_camellia_context * ctx)353 void mbedtls_camellia_init( mbedtls_camellia_context *ctx )
354 {
355 CAMELLIA_VALIDATE( ctx != NULL );
356 memset( ctx, 0, sizeof( mbedtls_camellia_context ) );
357 }
358
mbedtls_camellia_free(mbedtls_camellia_context * ctx)359 void mbedtls_camellia_free( mbedtls_camellia_context *ctx )
360 {
361 if( ctx == NULL )
362 return;
363
364 mbedtls_platform_zeroize( ctx, sizeof( mbedtls_camellia_context ) );
365 }
366
367 /*
368 * Camellia key schedule (encryption)
369 */
mbedtls_camellia_setkey_enc(mbedtls_camellia_context * ctx,const unsigned char * key,unsigned int keybits)370 int mbedtls_camellia_setkey_enc( mbedtls_camellia_context *ctx,
371 const unsigned char *key,
372 unsigned int keybits )
373 {
374 int idx;
375 size_t i;
376 uint32_t *RK;
377 unsigned char t[64];
378 uint32_t SIGMA[6][2];
379 uint32_t KC[16];
380 uint32_t TK[20];
381
382 CAMELLIA_VALIDATE_RET( ctx != NULL );
383 CAMELLIA_VALIDATE_RET( key != NULL );
384
385 RK = ctx->rk;
386
387 memset( t, 0, 64 );
388 memset( RK, 0, sizeof(ctx->rk) );
389
390 switch( keybits )
391 {
392 case 128: ctx->nr = 3; idx = 0; break;
393 case 192:
394 case 256: ctx->nr = 4; idx = 1; break;
395 default : return( MBEDTLS_ERR_CAMELLIA_BAD_INPUT_DATA );
396 }
397
398 for( i = 0; i < keybits / 8; ++i )
399 t[i] = key[i];
400
401 if( keybits == 192 ) {
402 for( i = 0; i < 8; i++ )
403 t[24 + i] = ~t[16 + i];
404 }
405
406 /*
407 * Prepare SIGMA values
408 */
409 for( i = 0; i < 6; i++ ) {
410 GET_UINT32_BE( SIGMA[i][0], SIGMA_CHARS[i], 0 );
411 GET_UINT32_BE( SIGMA[i][1], SIGMA_CHARS[i], 4 );
412 }
413
414 /*
415 * Key storage in KC
416 * Order: KL, KR, KA, KB
417 */
418 memset( KC, 0, sizeof(KC) );
419
420 /* Store KL, KR */
421 for( i = 0; i < 8; i++ )
422 GET_UINT32_BE( KC[i], t, i * 4 );
423
424 /* Generate KA */
425 for( i = 0; i < 4; ++i )
426 KC[8 + i] = KC[i] ^ KC[4 + i];
427
428 camellia_feistel( KC + 8, SIGMA[0], KC + 10 );
429 camellia_feistel( KC + 10, SIGMA[1], KC + 8 );
430
431 for( i = 0; i < 4; ++i )
432 KC[8 + i] ^= KC[i];
433
434 camellia_feistel( KC + 8, SIGMA[2], KC + 10 );
435 camellia_feistel( KC + 10, SIGMA[3], KC + 8 );
436
437 if( keybits > 128 ) {
438 /* Generate KB */
439 for( i = 0; i < 4; ++i )
440 KC[12 + i] = KC[4 + i] ^ KC[8 + i];
441
442 camellia_feistel( KC + 12, SIGMA[4], KC + 14 );
443 camellia_feistel( KC + 14, SIGMA[5], KC + 12 );
444 }
445
446 /*
447 * Generating subkeys
448 */
449
450 /* Manipulating KL */
451 SHIFT_AND_PLACE( idx, 0 );
452
453 /* Manipulating KR */
454 if( keybits > 128 ) {
455 SHIFT_AND_PLACE( idx, 1 );
456 }
457
458 /* Manipulating KA */
459 SHIFT_AND_PLACE( idx, 2 );
460
461 /* Manipulating KB */
462 if( keybits > 128 ) {
463 SHIFT_AND_PLACE( idx, 3 );
464 }
465
466 /* Do transpositions */
467 for( i = 0; i < 20; i++ ) {
468 if( transposes[idx][i] != -1 ) {
469 RK[32 + 12 * idx + i] = RK[transposes[idx][i]];
470 }
471 }
472
473 return( 0 );
474 }
475
476 /*
477 * Camellia key schedule (decryption)
478 */
mbedtls_camellia_setkey_dec(mbedtls_camellia_context * ctx,const unsigned char * key,unsigned int keybits)479 int mbedtls_camellia_setkey_dec( mbedtls_camellia_context *ctx,
480 const unsigned char *key,
481 unsigned int keybits )
482 {
483 int idx, ret;
484 size_t i;
485 mbedtls_camellia_context cty;
486 uint32_t *RK;
487 uint32_t *SK;
488 CAMELLIA_VALIDATE_RET( ctx != NULL );
489 CAMELLIA_VALIDATE_RET( key != NULL );
490
491 mbedtls_camellia_init( &cty );
492
493 /* Also checks keybits */
494 if( ( ret = mbedtls_camellia_setkey_enc( &cty, key, keybits ) ) != 0 )
495 goto exit;
496
497 ctx->nr = cty.nr;
498 idx = ( ctx->nr == 4 );
499
500 RK = ctx->rk;
501 SK = cty.rk + 24 * 2 + 8 * idx * 2;
502
503 *RK++ = *SK++;
504 *RK++ = *SK++;
505 *RK++ = *SK++;
506 *RK++ = *SK++;
507
508 for( i = 22 + 8 * idx, SK -= 6; i > 0; i--, SK -= 4 )
509 {
510 *RK++ = *SK++;
511 *RK++ = *SK++;
512 }
513
514 SK -= 2;
515
516 *RK++ = *SK++;
517 *RK++ = *SK++;
518 *RK++ = *SK++;
519 *RK++ = *SK++;
520
521 exit:
522 mbedtls_camellia_free( &cty );
523
524 return( ret );
525 }
526
527 /*
528 * Camellia-ECB block encryption/decryption
529 */
mbedtls_camellia_crypt_ecb(mbedtls_camellia_context * ctx,int mode,const unsigned char input[16],unsigned char output[16])530 int mbedtls_camellia_crypt_ecb( mbedtls_camellia_context *ctx,
531 int mode,
532 const unsigned char input[16],
533 unsigned char output[16] )
534 {
535 int NR;
536 uint32_t *RK, X[4];
537 CAMELLIA_VALIDATE_RET( ctx != NULL );
538 CAMELLIA_VALIDATE_RET( mode == MBEDTLS_CAMELLIA_ENCRYPT ||
539 mode == MBEDTLS_CAMELLIA_DECRYPT );
540 CAMELLIA_VALIDATE_RET( input != NULL );
541 CAMELLIA_VALIDATE_RET( output != NULL );
542
543 ( (void) mode );
544
545 NR = ctx->nr;
546 RK = ctx->rk;
547
548 GET_UINT32_BE( X[0], input, 0 );
549 GET_UINT32_BE( X[1], input, 4 );
550 GET_UINT32_BE( X[2], input, 8 );
551 GET_UINT32_BE( X[3], input, 12 );
552
553 X[0] ^= *RK++;
554 X[1] ^= *RK++;
555 X[2] ^= *RK++;
556 X[3] ^= *RK++;
557
558 while( NR ) {
559 --NR;
560 camellia_feistel( X, RK, X + 2 );
561 RK += 2;
562 camellia_feistel( X + 2, RK, X );
563 RK += 2;
564 camellia_feistel( X, RK, X + 2 );
565 RK += 2;
566 camellia_feistel( X + 2, RK, X );
567 RK += 2;
568 camellia_feistel( X, RK, X + 2 );
569 RK += 2;
570 camellia_feistel( X + 2, RK, X );
571 RK += 2;
572
573 if( NR ) {
574 FL(X[0], X[1], RK[0], RK[1]);
575 RK += 2;
576 FLInv(X[2], X[3], RK[0], RK[1]);
577 RK += 2;
578 }
579 }
580
581 X[2] ^= *RK++;
582 X[3] ^= *RK++;
583 X[0] ^= *RK++;
584 X[1] ^= *RK++;
585
586 PUT_UINT32_BE( X[2], output, 0 );
587 PUT_UINT32_BE( X[3], output, 4 );
588 PUT_UINT32_BE( X[0], output, 8 );
589 PUT_UINT32_BE( X[1], output, 12 );
590
591 return( 0 );
592 }
593
594 #if defined(MBEDTLS_CIPHER_MODE_CBC)
595 /*
596 * Camellia-CBC buffer encryption/decryption
597 */
mbedtls_camellia_crypt_cbc(mbedtls_camellia_context * ctx,int mode,size_t length,unsigned char iv[16],const unsigned char * input,unsigned char * output)598 int mbedtls_camellia_crypt_cbc( mbedtls_camellia_context *ctx,
599 int mode,
600 size_t length,
601 unsigned char iv[16],
602 const unsigned char *input,
603 unsigned char *output )
604 {
605 int i;
606 unsigned char temp[16];
607 CAMELLIA_VALIDATE_RET( ctx != NULL );
608 CAMELLIA_VALIDATE_RET( mode == MBEDTLS_CAMELLIA_ENCRYPT ||
609 mode == MBEDTLS_CAMELLIA_DECRYPT );
610 CAMELLIA_VALIDATE_RET( iv != NULL );
611 CAMELLIA_VALIDATE_RET( length == 0 || input != NULL );
612 CAMELLIA_VALIDATE_RET( length == 0 || output != NULL );
613
614 if( length % 16 )
615 return( MBEDTLS_ERR_CAMELLIA_INVALID_INPUT_LENGTH );
616
617 if( mode == MBEDTLS_CAMELLIA_DECRYPT )
618 {
619 while( length > 0 )
620 {
621 memcpy( temp, input, 16 );
622 mbedtls_camellia_crypt_ecb( ctx, mode, input, output );
623
624 for( i = 0; i < 16; i++ )
625 output[i] = (unsigned char)( output[i] ^ iv[i] );
626
627 memcpy( iv, temp, 16 );
628
629 input += 16;
630 output += 16;
631 length -= 16;
632 }
633 }
634 else
635 {
636 while( length > 0 )
637 {
638 for( i = 0; i < 16; i++ )
639 output[i] = (unsigned char)( input[i] ^ iv[i] );
640
641 mbedtls_camellia_crypt_ecb( ctx, mode, output, output );
642 memcpy( iv, output, 16 );
643
644 input += 16;
645 output += 16;
646 length -= 16;
647 }
648 }
649
650 return( 0 );
651 }
652 #endif /* MBEDTLS_CIPHER_MODE_CBC */
653
654 #if defined(MBEDTLS_CIPHER_MODE_CFB)
655 /*
656 * Camellia-CFB128 buffer encryption/decryption
657 */
mbedtls_camellia_crypt_cfb128(mbedtls_camellia_context * ctx,int mode,size_t length,size_t * iv_off,unsigned char iv[16],const unsigned char * input,unsigned char * output)658 int mbedtls_camellia_crypt_cfb128( mbedtls_camellia_context *ctx,
659 int mode,
660 size_t length,
661 size_t *iv_off,
662 unsigned char iv[16],
663 const unsigned char *input,
664 unsigned char *output )
665 {
666 int c;
667 size_t n;
668 CAMELLIA_VALIDATE_RET( ctx != NULL );
669 CAMELLIA_VALIDATE_RET( mode == MBEDTLS_CAMELLIA_ENCRYPT ||
670 mode == MBEDTLS_CAMELLIA_DECRYPT );
671 CAMELLIA_VALIDATE_RET( iv != NULL );
672 CAMELLIA_VALIDATE_RET( iv_off != NULL );
673 CAMELLIA_VALIDATE_RET( length == 0 || input != NULL );
674 CAMELLIA_VALIDATE_RET( length == 0 || output != NULL );
675
676 n = *iv_off;
677 if( n >= 16 )
678 return( MBEDTLS_ERR_CAMELLIA_BAD_INPUT_DATA );
679
680 if( mode == MBEDTLS_CAMELLIA_DECRYPT )
681 {
682 while( length-- )
683 {
684 if( n == 0 )
685 mbedtls_camellia_crypt_ecb( ctx, MBEDTLS_CAMELLIA_ENCRYPT, iv, iv );
686
687 c = *input++;
688 *output++ = (unsigned char)( c ^ iv[n] );
689 iv[n] = (unsigned char) c;
690
691 n = ( n + 1 ) & 0x0F;
692 }
693 }
694 else
695 {
696 while( length-- )
697 {
698 if( n == 0 )
699 mbedtls_camellia_crypt_ecb( ctx, MBEDTLS_CAMELLIA_ENCRYPT, iv, iv );
700
701 iv[n] = *output++ = (unsigned char)( iv[n] ^ *input++ );
702
703 n = ( n + 1 ) & 0x0F;
704 }
705 }
706
707 *iv_off = n;
708
709 return( 0 );
710 }
711 #endif /* MBEDTLS_CIPHER_MODE_CFB */
712
713 #if defined(MBEDTLS_CIPHER_MODE_CTR)
714 /*
715 * Camellia-CTR buffer encryption/decryption
716 */
mbedtls_camellia_crypt_ctr(mbedtls_camellia_context * ctx,size_t length,size_t * nc_off,unsigned char nonce_counter[16],unsigned char stream_block[16],const unsigned char * input,unsigned char * output)717 int mbedtls_camellia_crypt_ctr( mbedtls_camellia_context *ctx,
718 size_t length,
719 size_t *nc_off,
720 unsigned char nonce_counter[16],
721 unsigned char stream_block[16],
722 const unsigned char *input,
723 unsigned char *output )
724 {
725 int c, i;
726 size_t n;
727 CAMELLIA_VALIDATE_RET( ctx != NULL );
728 CAMELLIA_VALIDATE_RET( nonce_counter != NULL );
729 CAMELLIA_VALIDATE_RET( stream_block != NULL );
730 CAMELLIA_VALIDATE_RET( nc_off != NULL );
731 CAMELLIA_VALIDATE_RET( length == 0 || input != NULL );
732 CAMELLIA_VALIDATE_RET( length == 0 || output != NULL );
733
734 n = *nc_off;
735 if( n >= 16 )
736 return( MBEDTLS_ERR_CAMELLIA_BAD_INPUT_DATA );
737
738 while( length-- )
739 {
740 if( n == 0 ) {
741 mbedtls_camellia_crypt_ecb( ctx, MBEDTLS_CAMELLIA_ENCRYPT, nonce_counter,
742 stream_block );
743
744 for( i = 16; i > 0; i-- )
745 if( ++nonce_counter[i - 1] != 0 )
746 break;
747 }
748 c = *input++;
749 *output++ = (unsigned char)( c ^ stream_block[n] );
750
751 n = ( n + 1 ) & 0x0F;
752 }
753
754 *nc_off = n;
755
756 return( 0 );
757 }
758 #endif /* MBEDTLS_CIPHER_MODE_CTR */
759 #endif /* !MBEDTLS_CAMELLIA_ALT */
760
761 #if defined(MBEDTLS_SELF_TEST)
762
763 /*
764 * Camellia test vectors from:
765 *
766 * http://info.isl.ntt.co.jp/crypt/eng/camellia/technology.html:
767 * http://info.isl.ntt.co.jp/crypt/eng/camellia/dl/cryptrec/intermediate.txt
768 * http://info.isl.ntt.co.jp/crypt/eng/camellia/dl/cryptrec/t_camellia.txt
769 * (For each bitlength: Key 0, Nr 39)
770 */
771 #define CAMELLIA_TESTS_ECB 2
772
773 static const unsigned char camellia_test_ecb_key[3][CAMELLIA_TESTS_ECB][32] =
774 {
775 {
776 { 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef,
777 0xfe, 0xdc, 0xba, 0x98, 0x76, 0x54, 0x32, 0x10 },
778 { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
779 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }
780 },
781 {
782 { 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef,
783 0xfe, 0xdc, 0xba, 0x98, 0x76, 0x54, 0x32, 0x10,
784 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77 },
785 { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
786 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
787 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }
788 },
789 {
790 { 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef,
791 0xfe, 0xdc, 0xba, 0x98, 0x76, 0x54, 0x32, 0x10,
792 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77,
793 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff },
794 { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
795 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
796 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
797 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }
798 },
799 };
800
801 static const unsigned char camellia_test_ecb_plain[CAMELLIA_TESTS_ECB][16] =
802 {
803 { 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef,
804 0xfe, 0xdc, 0xba, 0x98, 0x76, 0x54, 0x32, 0x10 },
805 { 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00,
806 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }
807 };
808
809 static const unsigned char camellia_test_ecb_cipher[3][CAMELLIA_TESTS_ECB][16] =
810 {
811 {
812 { 0x67, 0x67, 0x31, 0x38, 0x54, 0x96, 0x69, 0x73,
813 0x08, 0x57, 0x06, 0x56, 0x48, 0xea, 0xbe, 0x43 },
814 { 0x38, 0x3C, 0x6C, 0x2A, 0xAB, 0xEF, 0x7F, 0xDE,
815 0x25, 0xCD, 0x47, 0x0B, 0xF7, 0x74, 0xA3, 0x31 }
816 },
817 {
818 { 0xb4, 0x99, 0x34, 0x01, 0xb3, 0xe9, 0x96, 0xf8,
819 0x4e, 0xe5, 0xce, 0xe7, 0xd7, 0x9b, 0x09, 0xb9 },
820 { 0xD1, 0x76, 0x3F, 0xC0, 0x19, 0xD7, 0x7C, 0xC9,
821 0x30, 0xBF, 0xF2, 0xA5, 0x6F, 0x7C, 0x93, 0x64 }
822 },
823 {
824 { 0x9a, 0xcc, 0x23, 0x7d, 0xff, 0x16, 0xd7, 0x6c,
825 0x20, 0xef, 0x7c, 0x91, 0x9e, 0x3a, 0x75, 0x09 },
826 { 0x05, 0x03, 0xFB, 0x10, 0xAB, 0x24, 0x1E, 0x7C,
827 0xF4, 0x5D, 0x8C, 0xDE, 0xEE, 0x47, 0x43, 0x35 }
828 }
829 };
830
831 #if defined(MBEDTLS_CIPHER_MODE_CBC)
832 #define CAMELLIA_TESTS_CBC 3
833
834 static const unsigned char camellia_test_cbc_key[3][32] =
835 {
836 { 0x2B, 0x7E, 0x15, 0x16, 0x28, 0xAE, 0xD2, 0xA6,
837 0xAB, 0xF7, 0x15, 0x88, 0x09, 0xCF, 0x4F, 0x3C }
838 ,
839 { 0x8E, 0x73, 0xB0, 0xF7, 0xDA, 0x0E, 0x64, 0x52,
840 0xC8, 0x10, 0xF3, 0x2B, 0x80, 0x90, 0x79, 0xE5,
841 0x62, 0xF8, 0xEA, 0xD2, 0x52, 0x2C, 0x6B, 0x7B }
842 ,
843 { 0x60, 0x3D, 0xEB, 0x10, 0x15, 0xCA, 0x71, 0xBE,
844 0x2B, 0x73, 0xAE, 0xF0, 0x85, 0x7D, 0x77, 0x81,
845 0x1F, 0x35, 0x2C, 0x07, 0x3B, 0x61, 0x08, 0xD7,
846 0x2D, 0x98, 0x10, 0xA3, 0x09, 0x14, 0xDF, 0xF4 }
847 };
848
849 static const unsigned char camellia_test_cbc_iv[16] =
850
851 { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
852 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F }
853 ;
854
855 static const unsigned char camellia_test_cbc_plain[CAMELLIA_TESTS_CBC][16] =
856 {
857 { 0x6B, 0xC1, 0xBE, 0xE2, 0x2E, 0x40, 0x9F, 0x96,
858 0xE9, 0x3D, 0x7E, 0x11, 0x73, 0x93, 0x17, 0x2A },
859 { 0xAE, 0x2D, 0x8A, 0x57, 0x1E, 0x03, 0xAC, 0x9C,
860 0x9E, 0xB7, 0x6F, 0xAC, 0x45, 0xAF, 0x8E, 0x51 },
861 { 0x30, 0xC8, 0x1C, 0x46, 0xA3, 0x5C, 0xE4, 0x11,
862 0xE5, 0xFB, 0xC1, 0x19, 0x1A, 0x0A, 0x52, 0xEF }
863
864 };
865
866 static const unsigned char camellia_test_cbc_cipher[3][CAMELLIA_TESTS_CBC][16] =
867 {
868 {
869 { 0x16, 0x07, 0xCF, 0x49, 0x4B, 0x36, 0xBB, 0xF0,
870 0x0D, 0xAE, 0xB0, 0xB5, 0x03, 0xC8, 0x31, 0xAB },
871 { 0xA2, 0xF2, 0xCF, 0x67, 0x16, 0x29, 0xEF, 0x78,
872 0x40, 0xC5, 0xA5, 0xDF, 0xB5, 0x07, 0x48, 0x87 },
873 { 0x0F, 0x06, 0x16, 0x50, 0x08, 0xCF, 0x8B, 0x8B,
874 0x5A, 0x63, 0x58, 0x63, 0x62, 0x54, 0x3E, 0x54 }
875 },
876 {
877 { 0x2A, 0x48, 0x30, 0xAB, 0x5A, 0xC4, 0xA1, 0xA2,
878 0x40, 0x59, 0x55, 0xFD, 0x21, 0x95, 0xCF, 0x93 },
879 { 0x5D, 0x5A, 0x86, 0x9B, 0xD1, 0x4C, 0xE5, 0x42,
880 0x64, 0xF8, 0x92, 0xA6, 0xDD, 0x2E, 0xC3, 0xD5 },
881 { 0x37, 0xD3, 0x59, 0xC3, 0x34, 0x98, 0x36, 0xD8,
882 0x84, 0xE3, 0x10, 0xAD, 0xDF, 0x68, 0xC4, 0x49 }
883 },
884 {
885 { 0xE6, 0xCF, 0xA3, 0x5F, 0xC0, 0x2B, 0x13, 0x4A,
886 0x4D, 0x2C, 0x0B, 0x67, 0x37, 0xAC, 0x3E, 0xDA },
887 { 0x36, 0xCB, 0xEB, 0x73, 0xBD, 0x50, 0x4B, 0x40,
888 0x70, 0xB1, 0xB7, 0xDE, 0x2B, 0x21, 0xEB, 0x50 },
889 { 0xE3, 0x1A, 0x60, 0x55, 0x29, 0x7D, 0x96, 0xCA,
890 0x33, 0x30, 0xCD, 0xF1, 0xB1, 0x86, 0x0A, 0x83 }
891 }
892 };
893 #endif /* MBEDTLS_CIPHER_MODE_CBC */
894
895 #if defined(MBEDTLS_CIPHER_MODE_CTR)
896 /*
897 * Camellia-CTR test vectors from:
898 *
899 * http://www.faqs.org/rfcs/rfc5528.html
900 */
901
902 static const unsigned char camellia_test_ctr_key[3][16] =
903 {
904 { 0xAE, 0x68, 0x52, 0xF8, 0x12, 0x10, 0x67, 0xCC,
905 0x4B, 0xF7, 0xA5, 0x76, 0x55, 0x77, 0xF3, 0x9E },
906 { 0x7E, 0x24, 0x06, 0x78, 0x17, 0xFA, 0xE0, 0xD7,
907 0x43, 0xD6, 0xCE, 0x1F, 0x32, 0x53, 0x91, 0x63 },
908 { 0x76, 0x91, 0xBE, 0x03, 0x5E, 0x50, 0x20, 0xA8,
909 0xAC, 0x6E, 0x61, 0x85, 0x29, 0xF9, 0xA0, 0xDC }
910 };
911
912 static const unsigned char camellia_test_ctr_nonce_counter[3][16] =
913 {
914 { 0x00, 0x00, 0x00, 0x30, 0x00, 0x00, 0x00, 0x00,
915 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01 },
916 { 0x00, 0x6C, 0xB6, 0xDB, 0xC0, 0x54, 0x3B, 0x59,
917 0xDA, 0x48, 0xD9, 0x0B, 0x00, 0x00, 0x00, 0x01 },
918 { 0x00, 0xE0, 0x01, 0x7B, 0x27, 0x77, 0x7F, 0x3F,
919 0x4A, 0x17, 0x86, 0xF0, 0x00, 0x00, 0x00, 0x01 }
920 };
921
922 static const unsigned char camellia_test_ctr_pt[3][48] =
923 {
924 { 0x53, 0x69, 0x6E, 0x67, 0x6C, 0x65, 0x20, 0x62,
925 0x6C, 0x6F, 0x63, 0x6B, 0x20, 0x6D, 0x73, 0x67 },
926
927 { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
928 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F,
929 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
930 0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F },
931
932 { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
933 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F,
934 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
935 0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F,
936 0x20, 0x21, 0x22, 0x23 }
937 };
938
939 static const unsigned char camellia_test_ctr_ct[3][48] =
940 {
941 { 0xD0, 0x9D, 0xC2, 0x9A, 0x82, 0x14, 0x61, 0x9A,
942 0x20, 0x87, 0x7C, 0x76, 0xDB, 0x1F, 0x0B, 0x3F },
943 { 0xDB, 0xF3, 0xC7, 0x8D, 0xC0, 0x83, 0x96, 0xD4,
944 0xDA, 0x7C, 0x90, 0x77, 0x65, 0xBB, 0xCB, 0x44,
945 0x2B, 0x8E, 0x8E, 0x0F, 0x31, 0xF0, 0xDC, 0xA7,
946 0x2C, 0x74, 0x17, 0xE3, 0x53, 0x60, 0xE0, 0x48 },
947 { 0xB1, 0x9D, 0x1F, 0xCD, 0xCB, 0x75, 0xEB, 0x88,
948 0x2F, 0x84, 0x9C, 0xE2, 0x4D, 0x85, 0xCF, 0x73,
949 0x9C, 0xE6, 0x4B, 0x2B, 0x5C, 0x9D, 0x73, 0xF1,
950 0x4F, 0x2D, 0x5D, 0x9D, 0xCE, 0x98, 0x89, 0xCD,
951 0xDF, 0x50, 0x86, 0x96 }
952 };
953
954 static const int camellia_test_ctr_len[3] =
955 { 16, 32, 36 };
956 #endif /* MBEDTLS_CIPHER_MODE_CTR */
957
958 /*
959 * Checkup routine
960 */
mbedtls_camellia_self_test(int verbose)961 int mbedtls_camellia_self_test( int verbose )
962 {
963 int i, j, u, v;
964 unsigned char key[32];
965 unsigned char buf[64];
966 unsigned char src[16];
967 unsigned char dst[16];
968 #if defined(MBEDTLS_CIPHER_MODE_CBC)
969 unsigned char iv[16];
970 #endif
971 #if defined(MBEDTLS_CIPHER_MODE_CTR)
972 size_t offset, len;
973 unsigned char nonce_counter[16];
974 unsigned char stream_block[16];
975 #endif
976 int ret = 1;
977
978 mbedtls_camellia_context ctx;
979
980 mbedtls_camellia_init( &ctx );
981 memset( key, 0, 32 );
982
983 for( j = 0; j < 6; j++ ) {
984 u = j >> 1;
985 v = j & 1;
986
987 if( verbose != 0 )
988 mbedtls_printf( " CAMELLIA-ECB-%3d (%s): ", 128 + u * 64,
989 (v == MBEDTLS_CAMELLIA_DECRYPT) ? "dec" : "enc");
990
991 for( i = 0; i < CAMELLIA_TESTS_ECB; i++ ) {
992 memcpy( key, camellia_test_ecb_key[u][i], 16 + 8 * u );
993
994 if( v == MBEDTLS_CAMELLIA_DECRYPT ) {
995 mbedtls_camellia_setkey_dec( &ctx, key, 128 + u * 64 );
996 memcpy( src, camellia_test_ecb_cipher[u][i], 16 );
997 memcpy( dst, camellia_test_ecb_plain[i], 16 );
998 } else { /* MBEDTLS_CAMELLIA_ENCRYPT */
999 mbedtls_camellia_setkey_enc( &ctx, key, 128 + u * 64 );
1000 memcpy( src, camellia_test_ecb_plain[i], 16 );
1001 memcpy( dst, camellia_test_ecb_cipher[u][i], 16 );
1002 }
1003
1004 mbedtls_camellia_crypt_ecb( &ctx, v, src, buf );
1005
1006 if( memcmp( buf, dst, 16 ) != 0 )
1007 {
1008 if( verbose != 0 )
1009 mbedtls_printf( "failed\n" );
1010 goto exit;
1011 }
1012 }
1013
1014 if( verbose != 0 )
1015 mbedtls_printf( "passed\n" );
1016 }
1017
1018 if( verbose != 0 )
1019 mbedtls_printf( "\n" );
1020
1021 #if defined(MBEDTLS_CIPHER_MODE_CBC)
1022 /*
1023 * CBC mode
1024 */
1025 for( j = 0; j < 6; j++ )
1026 {
1027 u = j >> 1;
1028 v = j & 1;
1029
1030 if( verbose != 0 )
1031 mbedtls_printf( " CAMELLIA-CBC-%3d (%s): ", 128 + u * 64,
1032 ( v == MBEDTLS_CAMELLIA_DECRYPT ) ? "dec" : "enc" );
1033
1034 memcpy( src, camellia_test_cbc_iv, 16 );
1035 memcpy( dst, camellia_test_cbc_iv, 16 );
1036 memcpy( key, camellia_test_cbc_key[u], 16 + 8 * u );
1037
1038 if( v == MBEDTLS_CAMELLIA_DECRYPT ) {
1039 mbedtls_camellia_setkey_dec( &ctx, key, 128 + u * 64 );
1040 } else {
1041 mbedtls_camellia_setkey_enc( &ctx, key, 128 + u * 64 );
1042 }
1043
1044 for( i = 0; i < CAMELLIA_TESTS_CBC; i++ ) {
1045
1046 if( v == MBEDTLS_CAMELLIA_DECRYPT ) {
1047 memcpy( iv , src, 16 );
1048 memcpy( src, camellia_test_cbc_cipher[u][i], 16 );
1049 memcpy( dst, camellia_test_cbc_plain[i], 16 );
1050 } else { /* MBEDTLS_CAMELLIA_ENCRYPT */
1051 memcpy( iv , dst, 16 );
1052 memcpy( src, camellia_test_cbc_plain[i], 16 );
1053 memcpy( dst, camellia_test_cbc_cipher[u][i], 16 );
1054 }
1055
1056 mbedtls_camellia_crypt_cbc( &ctx, v, 16, iv, src, buf );
1057
1058 if( memcmp( buf, dst, 16 ) != 0 )
1059 {
1060 if( verbose != 0 )
1061 mbedtls_printf( "failed\n" );
1062 goto exit;
1063 }
1064 }
1065
1066 if( verbose != 0 )
1067 mbedtls_printf( "passed\n" );
1068 }
1069 #endif /* MBEDTLS_CIPHER_MODE_CBC */
1070
1071 if( verbose != 0 )
1072 mbedtls_printf( "\n" );
1073
1074 #if defined(MBEDTLS_CIPHER_MODE_CTR)
1075 /*
1076 * CTR mode
1077 */
1078 for( i = 0; i < 6; i++ )
1079 {
1080 u = i >> 1;
1081 v = i & 1;
1082
1083 if( verbose != 0 )
1084 mbedtls_printf( " CAMELLIA-CTR-128 (%s): ",
1085 ( v == MBEDTLS_CAMELLIA_DECRYPT ) ? "dec" : "enc" );
1086
1087 memcpy( nonce_counter, camellia_test_ctr_nonce_counter[u], 16 );
1088 memcpy( key, camellia_test_ctr_key[u], 16 );
1089
1090 offset = 0;
1091 mbedtls_camellia_setkey_enc( &ctx, key, 128 );
1092
1093 if( v == MBEDTLS_CAMELLIA_DECRYPT )
1094 {
1095 len = camellia_test_ctr_len[u];
1096 memcpy( buf, camellia_test_ctr_ct[u], len );
1097
1098 mbedtls_camellia_crypt_ctr( &ctx, len, &offset, nonce_counter, stream_block,
1099 buf, buf );
1100
1101 if( memcmp( buf, camellia_test_ctr_pt[u], len ) != 0 )
1102 {
1103 if( verbose != 0 )
1104 mbedtls_printf( "failed\n" );
1105 goto exit;
1106 }
1107 }
1108 else
1109 {
1110 len = camellia_test_ctr_len[u];
1111 memcpy( buf, camellia_test_ctr_pt[u], len );
1112
1113 mbedtls_camellia_crypt_ctr( &ctx, len, &offset, nonce_counter, stream_block,
1114 buf, buf );
1115
1116 if( memcmp( buf, camellia_test_ctr_ct[u], len ) != 0 )
1117 {
1118 if( verbose != 0 )
1119 mbedtls_printf( "failed\n" );
1120 goto exit;
1121 }
1122 }
1123
1124 if( verbose != 0 )
1125 mbedtls_printf( "passed\n" );
1126 }
1127
1128 if( verbose != 0 )
1129 mbedtls_printf( "\n" );
1130 #endif /* MBEDTLS_CIPHER_MODE_CTR */
1131
1132 ret = 0;
1133
1134 exit:
1135 mbedtls_camellia_free( &ctx );
1136 return( ret );
1137 }
1138
1139 #endif /* MBEDTLS_SELF_TEST */
1140
1141 #endif /* MBEDTLS_CAMELLIA_C */
1142