1 /*
2 * Copyright 2006-2022 The OpenSSL Project Authors. All Rights Reserved.
3 *
4 * Licensed under the Apache License 2.0 (the "License"). You may not use
5 * this file except in compliance with the License. You can obtain a copy
6 * in the file LICENSE in the source distribution or at
7 * https://www.openssl.org/source/license.html
8 */
9
10 /* ====================================================================
11 * Copyright 2006 NTT (Nippon Telegraph and Telephone Corporation) .
12 * ALL RIGHTS RESERVED.
13 *
14 * Intellectual Property information for Camellia:
15 * http://info.isl.ntt.co.jp/crypt/eng/info/chiteki.html
16 *
17 * News Release for Announcement of Camellia open source:
18 * http://www.ntt.co.jp/news/news06e/0604/060413a.html
19 *
20 * The Camellia Code included herein is developed by
21 * NTT (Nippon Telegraph and Telephone Corporation), and is contributed
22 * to the OpenSSL project.
23 */
24
25 /*
26 * Algorithm Specification
27 * http://info.isl.ntt.co.jp/crypt/eng/camellia/specifications.html
28 */
29
30 /*
31 * This release balances code size and performance. In particular key
32 * schedule setup is fully unrolled, because doing so *significantly*
33 * reduces amount of instructions per setup round and code increase is
34 * justifiable. In block functions on the other hand only inner loops
35 * are unrolled, as full unroll gives only nominal performance boost,
36 * while code size grows 4 or 7 times. Also, unlike previous versions
37 * this one "encourages" compiler to keep intermediate variables in
38 * registers, which should give better "all round" results, in other
39 * words reasonable performance even with not so modern compilers.
40 */
41
42 /*
43 * Camellia low level APIs are deprecated for public use, but still ok for
44 * internal use.
45 */
46 #include "internal/deprecated.h"
47
48 #include <openssl/camellia.h>
49 #include "cmll_local.h"
50 #include <string.h>
51 #include <stdlib.h>
52
53 #define RightRotate(x, s) ( ((x) >> (s)) + ((x) << (32 - s)) )
54 #define LeftRotate(x, s) ( ((x) << (s)) + ((x) >> (32 - s)) )
55
56 #define GETU32(p) (((u32)(p)[0] << 24) ^ ((u32)(p)[1] << 16) ^ ((u32)(p)[2] << 8) ^ ((u32)(p)[3]))
57 #define PUTU32(p,v) ((p)[0] = (u8)((v) >> 24), (p)[1] = (u8)((v) >> 16), (p)[2] = (u8)((v) >> 8), (p)[3] = (u8)(v))
58
59 /* S-box data */
60 #define SBOX1_1110 Camellia_SBOX[0]
61 #define SBOX4_4404 Camellia_SBOX[1]
62 #define SBOX2_0222 Camellia_SBOX[2]
63 #define SBOX3_3033 Camellia_SBOX[3]
64 static const u32 Camellia_SBOX[][256] = {
65 {0x70707000, 0x82828200, 0x2c2c2c00, 0xececec00, 0xb3b3b300, 0x27272700,
66 0xc0c0c000, 0xe5e5e500, 0xe4e4e400, 0x85858500, 0x57575700, 0x35353500,
67 0xeaeaea00, 0x0c0c0c00, 0xaeaeae00, 0x41414100, 0x23232300, 0xefefef00,
68 0x6b6b6b00, 0x93939300, 0x45454500, 0x19191900, 0xa5a5a500, 0x21212100,
69 0xededed00, 0x0e0e0e00, 0x4f4f4f00, 0x4e4e4e00, 0x1d1d1d00, 0x65656500,
70 0x92929200, 0xbdbdbd00, 0x86868600, 0xb8b8b800, 0xafafaf00, 0x8f8f8f00,
71 0x7c7c7c00, 0xebebeb00, 0x1f1f1f00, 0xcecece00, 0x3e3e3e00, 0x30303000,
72 0xdcdcdc00, 0x5f5f5f00, 0x5e5e5e00, 0xc5c5c500, 0x0b0b0b00, 0x1a1a1a00,
73 0xa6a6a600, 0xe1e1e100, 0x39393900, 0xcacaca00, 0xd5d5d500, 0x47474700,
74 0x5d5d5d00, 0x3d3d3d00, 0xd9d9d900, 0x01010100, 0x5a5a5a00, 0xd6d6d600,
75 0x51515100, 0x56565600, 0x6c6c6c00, 0x4d4d4d00, 0x8b8b8b00, 0x0d0d0d00,
76 0x9a9a9a00, 0x66666600, 0xfbfbfb00, 0xcccccc00, 0xb0b0b000, 0x2d2d2d00,
77 0x74747400, 0x12121200, 0x2b2b2b00, 0x20202000, 0xf0f0f000, 0xb1b1b100,
78 0x84848400, 0x99999900, 0xdfdfdf00, 0x4c4c4c00, 0xcbcbcb00, 0xc2c2c200,
79 0x34343400, 0x7e7e7e00, 0x76767600, 0x05050500, 0x6d6d6d00, 0xb7b7b700,
80 0xa9a9a900, 0x31313100, 0xd1d1d100, 0x17171700, 0x04040400, 0xd7d7d700,
81 0x14141400, 0x58585800, 0x3a3a3a00, 0x61616100, 0xdedede00, 0x1b1b1b00,
82 0x11111100, 0x1c1c1c00, 0x32323200, 0x0f0f0f00, 0x9c9c9c00, 0x16161600,
83 0x53535300, 0x18181800, 0xf2f2f200, 0x22222200, 0xfefefe00, 0x44444400,
84 0xcfcfcf00, 0xb2b2b200, 0xc3c3c300, 0xb5b5b500, 0x7a7a7a00, 0x91919100,
85 0x24242400, 0x08080800, 0xe8e8e800, 0xa8a8a800, 0x60606000, 0xfcfcfc00,
86 0x69696900, 0x50505000, 0xaaaaaa00, 0xd0d0d000, 0xa0a0a000, 0x7d7d7d00,
87 0xa1a1a100, 0x89898900, 0x62626200, 0x97979700, 0x54545400, 0x5b5b5b00,
88 0x1e1e1e00, 0x95959500, 0xe0e0e000, 0xffffff00, 0x64646400, 0xd2d2d200,
89 0x10101000, 0xc4c4c400, 0x00000000, 0x48484800, 0xa3a3a300, 0xf7f7f700,
90 0x75757500, 0xdbdbdb00, 0x8a8a8a00, 0x03030300, 0xe6e6e600, 0xdadada00,
91 0x09090900, 0x3f3f3f00, 0xdddddd00, 0x94949400, 0x87878700, 0x5c5c5c00,
92 0x83838300, 0x02020200, 0xcdcdcd00, 0x4a4a4a00, 0x90909000, 0x33333300,
93 0x73737300, 0x67676700, 0xf6f6f600, 0xf3f3f300, 0x9d9d9d00, 0x7f7f7f00,
94 0xbfbfbf00, 0xe2e2e200, 0x52525200, 0x9b9b9b00, 0xd8d8d800, 0x26262600,
95 0xc8c8c800, 0x37373700, 0xc6c6c600, 0x3b3b3b00, 0x81818100, 0x96969600,
96 0x6f6f6f00, 0x4b4b4b00, 0x13131300, 0xbebebe00, 0x63636300, 0x2e2e2e00,
97 0xe9e9e900, 0x79797900, 0xa7a7a700, 0x8c8c8c00, 0x9f9f9f00, 0x6e6e6e00,
98 0xbcbcbc00, 0x8e8e8e00, 0x29292900, 0xf5f5f500, 0xf9f9f900, 0xb6b6b600,
99 0x2f2f2f00, 0xfdfdfd00, 0xb4b4b400, 0x59595900, 0x78787800, 0x98989800,
100 0x06060600, 0x6a6a6a00, 0xe7e7e700, 0x46464600, 0x71717100, 0xbababa00,
101 0xd4d4d400, 0x25252500, 0xababab00, 0x42424200, 0x88888800, 0xa2a2a200,
102 0x8d8d8d00, 0xfafafa00, 0x72727200, 0x07070700, 0xb9b9b900, 0x55555500,
103 0xf8f8f800, 0xeeeeee00, 0xacacac00, 0x0a0a0a00, 0x36363600, 0x49494900,
104 0x2a2a2a00, 0x68686800, 0x3c3c3c00, 0x38383800, 0xf1f1f100, 0xa4a4a400,
105 0x40404000, 0x28282800, 0xd3d3d300, 0x7b7b7b00, 0xbbbbbb00, 0xc9c9c900,
106 0x43434300, 0xc1c1c100, 0x15151500, 0xe3e3e300, 0xadadad00, 0xf4f4f400,
107 0x77777700, 0xc7c7c700, 0x80808000, 0x9e9e9e00},
108 {0x70700070, 0x2c2c002c, 0xb3b300b3, 0xc0c000c0, 0xe4e400e4, 0x57570057,
109 0xeaea00ea, 0xaeae00ae, 0x23230023, 0x6b6b006b, 0x45450045, 0xa5a500a5,
110 0xeded00ed, 0x4f4f004f, 0x1d1d001d, 0x92920092, 0x86860086, 0xafaf00af,
111 0x7c7c007c, 0x1f1f001f, 0x3e3e003e, 0xdcdc00dc, 0x5e5e005e, 0x0b0b000b,
112 0xa6a600a6, 0x39390039, 0xd5d500d5, 0x5d5d005d, 0xd9d900d9, 0x5a5a005a,
113 0x51510051, 0x6c6c006c, 0x8b8b008b, 0x9a9a009a, 0xfbfb00fb, 0xb0b000b0,
114 0x74740074, 0x2b2b002b, 0xf0f000f0, 0x84840084, 0xdfdf00df, 0xcbcb00cb,
115 0x34340034, 0x76760076, 0x6d6d006d, 0xa9a900a9, 0xd1d100d1, 0x04040004,
116 0x14140014, 0x3a3a003a, 0xdede00de, 0x11110011, 0x32320032, 0x9c9c009c,
117 0x53530053, 0xf2f200f2, 0xfefe00fe, 0xcfcf00cf, 0xc3c300c3, 0x7a7a007a,
118 0x24240024, 0xe8e800e8, 0x60600060, 0x69690069, 0xaaaa00aa, 0xa0a000a0,
119 0xa1a100a1, 0x62620062, 0x54540054, 0x1e1e001e, 0xe0e000e0, 0x64640064,
120 0x10100010, 0x00000000, 0xa3a300a3, 0x75750075, 0x8a8a008a, 0xe6e600e6,
121 0x09090009, 0xdddd00dd, 0x87870087, 0x83830083, 0xcdcd00cd, 0x90900090,
122 0x73730073, 0xf6f600f6, 0x9d9d009d, 0xbfbf00bf, 0x52520052, 0xd8d800d8,
123 0xc8c800c8, 0xc6c600c6, 0x81810081, 0x6f6f006f, 0x13130013, 0x63630063,
124 0xe9e900e9, 0xa7a700a7, 0x9f9f009f, 0xbcbc00bc, 0x29290029, 0xf9f900f9,
125 0x2f2f002f, 0xb4b400b4, 0x78780078, 0x06060006, 0xe7e700e7, 0x71710071,
126 0xd4d400d4, 0xabab00ab, 0x88880088, 0x8d8d008d, 0x72720072, 0xb9b900b9,
127 0xf8f800f8, 0xacac00ac, 0x36360036, 0x2a2a002a, 0x3c3c003c, 0xf1f100f1,
128 0x40400040, 0xd3d300d3, 0xbbbb00bb, 0x43430043, 0x15150015, 0xadad00ad,
129 0x77770077, 0x80800080, 0x82820082, 0xecec00ec, 0x27270027, 0xe5e500e5,
130 0x85850085, 0x35350035, 0x0c0c000c, 0x41410041, 0xefef00ef, 0x93930093,
131 0x19190019, 0x21210021, 0x0e0e000e, 0x4e4e004e, 0x65650065, 0xbdbd00bd,
132 0xb8b800b8, 0x8f8f008f, 0xebeb00eb, 0xcece00ce, 0x30300030, 0x5f5f005f,
133 0xc5c500c5, 0x1a1a001a, 0xe1e100e1, 0xcaca00ca, 0x47470047, 0x3d3d003d,
134 0x01010001, 0xd6d600d6, 0x56560056, 0x4d4d004d, 0x0d0d000d, 0x66660066,
135 0xcccc00cc, 0x2d2d002d, 0x12120012, 0x20200020, 0xb1b100b1, 0x99990099,
136 0x4c4c004c, 0xc2c200c2, 0x7e7e007e, 0x05050005, 0xb7b700b7, 0x31310031,
137 0x17170017, 0xd7d700d7, 0x58580058, 0x61610061, 0x1b1b001b, 0x1c1c001c,
138 0x0f0f000f, 0x16160016, 0x18180018, 0x22220022, 0x44440044, 0xb2b200b2,
139 0xb5b500b5, 0x91910091, 0x08080008, 0xa8a800a8, 0xfcfc00fc, 0x50500050,
140 0xd0d000d0, 0x7d7d007d, 0x89890089, 0x97970097, 0x5b5b005b, 0x95950095,
141 0xffff00ff, 0xd2d200d2, 0xc4c400c4, 0x48480048, 0xf7f700f7, 0xdbdb00db,
142 0x03030003, 0xdada00da, 0x3f3f003f, 0x94940094, 0x5c5c005c, 0x02020002,
143 0x4a4a004a, 0x33330033, 0x67670067, 0xf3f300f3, 0x7f7f007f, 0xe2e200e2,
144 0x9b9b009b, 0x26260026, 0x37370037, 0x3b3b003b, 0x96960096, 0x4b4b004b,
145 0xbebe00be, 0x2e2e002e, 0x79790079, 0x8c8c008c, 0x6e6e006e, 0x8e8e008e,
146 0xf5f500f5, 0xb6b600b6, 0xfdfd00fd, 0x59590059, 0x98980098, 0x6a6a006a,
147 0x46460046, 0xbaba00ba, 0x25250025, 0x42420042, 0xa2a200a2, 0xfafa00fa,
148 0x07070007, 0x55550055, 0xeeee00ee, 0x0a0a000a, 0x49490049, 0x68680068,
149 0x38380038, 0xa4a400a4, 0x28280028, 0x7b7b007b, 0xc9c900c9, 0xc1c100c1,
150 0xe3e300e3, 0xf4f400f4, 0xc7c700c7, 0x9e9e009e},
151 {0x00e0e0e0, 0x00050505, 0x00585858, 0x00d9d9d9, 0x00676767, 0x004e4e4e,
152 0x00818181, 0x00cbcbcb, 0x00c9c9c9, 0x000b0b0b, 0x00aeaeae, 0x006a6a6a,
153 0x00d5d5d5, 0x00181818, 0x005d5d5d, 0x00828282, 0x00464646, 0x00dfdfdf,
154 0x00d6d6d6, 0x00272727, 0x008a8a8a, 0x00323232, 0x004b4b4b, 0x00424242,
155 0x00dbdbdb, 0x001c1c1c, 0x009e9e9e, 0x009c9c9c, 0x003a3a3a, 0x00cacaca,
156 0x00252525, 0x007b7b7b, 0x000d0d0d, 0x00717171, 0x005f5f5f, 0x001f1f1f,
157 0x00f8f8f8, 0x00d7d7d7, 0x003e3e3e, 0x009d9d9d, 0x007c7c7c, 0x00606060,
158 0x00b9b9b9, 0x00bebebe, 0x00bcbcbc, 0x008b8b8b, 0x00161616, 0x00343434,
159 0x004d4d4d, 0x00c3c3c3, 0x00727272, 0x00959595, 0x00ababab, 0x008e8e8e,
160 0x00bababa, 0x007a7a7a, 0x00b3b3b3, 0x00020202, 0x00b4b4b4, 0x00adadad,
161 0x00a2a2a2, 0x00acacac, 0x00d8d8d8, 0x009a9a9a, 0x00171717, 0x001a1a1a,
162 0x00353535, 0x00cccccc, 0x00f7f7f7, 0x00999999, 0x00616161, 0x005a5a5a,
163 0x00e8e8e8, 0x00242424, 0x00565656, 0x00404040, 0x00e1e1e1, 0x00636363,
164 0x00090909, 0x00333333, 0x00bfbfbf, 0x00989898, 0x00979797, 0x00858585,
165 0x00686868, 0x00fcfcfc, 0x00ececec, 0x000a0a0a, 0x00dadada, 0x006f6f6f,
166 0x00535353, 0x00626262, 0x00a3a3a3, 0x002e2e2e, 0x00080808, 0x00afafaf,
167 0x00282828, 0x00b0b0b0, 0x00747474, 0x00c2c2c2, 0x00bdbdbd, 0x00363636,
168 0x00222222, 0x00383838, 0x00646464, 0x001e1e1e, 0x00393939, 0x002c2c2c,
169 0x00a6a6a6, 0x00303030, 0x00e5e5e5, 0x00444444, 0x00fdfdfd, 0x00888888,
170 0x009f9f9f, 0x00656565, 0x00878787, 0x006b6b6b, 0x00f4f4f4, 0x00232323,
171 0x00484848, 0x00101010, 0x00d1d1d1, 0x00515151, 0x00c0c0c0, 0x00f9f9f9,
172 0x00d2d2d2, 0x00a0a0a0, 0x00555555, 0x00a1a1a1, 0x00414141, 0x00fafafa,
173 0x00434343, 0x00131313, 0x00c4c4c4, 0x002f2f2f, 0x00a8a8a8, 0x00b6b6b6,
174 0x003c3c3c, 0x002b2b2b, 0x00c1c1c1, 0x00ffffff, 0x00c8c8c8, 0x00a5a5a5,
175 0x00202020, 0x00898989, 0x00000000, 0x00909090, 0x00474747, 0x00efefef,
176 0x00eaeaea, 0x00b7b7b7, 0x00151515, 0x00060606, 0x00cdcdcd, 0x00b5b5b5,
177 0x00121212, 0x007e7e7e, 0x00bbbbbb, 0x00292929, 0x000f0f0f, 0x00b8b8b8,
178 0x00070707, 0x00040404, 0x009b9b9b, 0x00949494, 0x00212121, 0x00666666,
179 0x00e6e6e6, 0x00cecece, 0x00ededed, 0x00e7e7e7, 0x003b3b3b, 0x00fefefe,
180 0x007f7f7f, 0x00c5c5c5, 0x00a4a4a4, 0x00373737, 0x00b1b1b1, 0x004c4c4c,
181 0x00919191, 0x006e6e6e, 0x008d8d8d, 0x00767676, 0x00030303, 0x002d2d2d,
182 0x00dedede, 0x00969696, 0x00262626, 0x007d7d7d, 0x00c6c6c6, 0x005c5c5c,
183 0x00d3d3d3, 0x00f2f2f2, 0x004f4f4f, 0x00191919, 0x003f3f3f, 0x00dcdcdc,
184 0x00797979, 0x001d1d1d, 0x00525252, 0x00ebebeb, 0x00f3f3f3, 0x006d6d6d,
185 0x005e5e5e, 0x00fbfbfb, 0x00696969, 0x00b2b2b2, 0x00f0f0f0, 0x00313131,
186 0x000c0c0c, 0x00d4d4d4, 0x00cfcfcf, 0x008c8c8c, 0x00e2e2e2, 0x00757575,
187 0x00a9a9a9, 0x004a4a4a, 0x00575757, 0x00848484, 0x00111111, 0x00454545,
188 0x001b1b1b, 0x00f5f5f5, 0x00e4e4e4, 0x000e0e0e, 0x00737373, 0x00aaaaaa,
189 0x00f1f1f1, 0x00dddddd, 0x00595959, 0x00141414, 0x006c6c6c, 0x00929292,
190 0x00545454, 0x00d0d0d0, 0x00787878, 0x00707070, 0x00e3e3e3, 0x00494949,
191 0x00808080, 0x00505050, 0x00a7a7a7, 0x00f6f6f6, 0x00777777, 0x00939393,
192 0x00868686, 0x00838383, 0x002a2a2a, 0x00c7c7c7, 0x005b5b5b, 0x00e9e9e9,
193 0x00eeeeee, 0x008f8f8f, 0x00010101, 0x003d3d3d},
194 {0x38003838, 0x41004141, 0x16001616, 0x76007676, 0xd900d9d9, 0x93009393,
195 0x60006060, 0xf200f2f2, 0x72007272, 0xc200c2c2, 0xab00abab, 0x9a009a9a,
196 0x75007575, 0x06000606, 0x57005757, 0xa000a0a0, 0x91009191, 0xf700f7f7,
197 0xb500b5b5, 0xc900c9c9, 0xa200a2a2, 0x8c008c8c, 0xd200d2d2, 0x90009090,
198 0xf600f6f6, 0x07000707, 0xa700a7a7, 0x27002727, 0x8e008e8e, 0xb200b2b2,
199 0x49004949, 0xde00dede, 0x43004343, 0x5c005c5c, 0xd700d7d7, 0xc700c7c7,
200 0x3e003e3e, 0xf500f5f5, 0x8f008f8f, 0x67006767, 0x1f001f1f, 0x18001818,
201 0x6e006e6e, 0xaf00afaf, 0x2f002f2f, 0xe200e2e2, 0x85008585, 0x0d000d0d,
202 0x53005353, 0xf000f0f0, 0x9c009c9c, 0x65006565, 0xea00eaea, 0xa300a3a3,
203 0xae00aeae, 0x9e009e9e, 0xec00ecec, 0x80008080, 0x2d002d2d, 0x6b006b6b,
204 0xa800a8a8, 0x2b002b2b, 0x36003636, 0xa600a6a6, 0xc500c5c5, 0x86008686,
205 0x4d004d4d, 0x33003333, 0xfd00fdfd, 0x66006666, 0x58005858, 0x96009696,
206 0x3a003a3a, 0x09000909, 0x95009595, 0x10001010, 0x78007878, 0xd800d8d8,
207 0x42004242, 0xcc00cccc, 0xef00efef, 0x26002626, 0xe500e5e5, 0x61006161,
208 0x1a001a1a, 0x3f003f3f, 0x3b003b3b, 0x82008282, 0xb600b6b6, 0xdb00dbdb,
209 0xd400d4d4, 0x98009898, 0xe800e8e8, 0x8b008b8b, 0x02000202, 0xeb00ebeb,
210 0x0a000a0a, 0x2c002c2c, 0x1d001d1d, 0xb000b0b0, 0x6f006f6f, 0x8d008d8d,
211 0x88008888, 0x0e000e0e, 0x19001919, 0x87008787, 0x4e004e4e, 0x0b000b0b,
212 0xa900a9a9, 0x0c000c0c, 0x79007979, 0x11001111, 0x7f007f7f, 0x22002222,
213 0xe700e7e7, 0x59005959, 0xe100e1e1, 0xda00dada, 0x3d003d3d, 0xc800c8c8,
214 0x12001212, 0x04000404, 0x74007474, 0x54005454, 0x30003030, 0x7e007e7e,
215 0xb400b4b4, 0x28002828, 0x55005555, 0x68006868, 0x50005050, 0xbe00bebe,
216 0xd000d0d0, 0xc400c4c4, 0x31003131, 0xcb00cbcb, 0x2a002a2a, 0xad00adad,
217 0x0f000f0f, 0xca00caca, 0x70007070, 0xff00ffff, 0x32003232, 0x69006969,
218 0x08000808, 0x62006262, 0x00000000, 0x24002424, 0xd100d1d1, 0xfb00fbfb,
219 0xba00baba, 0xed00eded, 0x45004545, 0x81008181, 0x73007373, 0x6d006d6d,
220 0x84008484, 0x9f009f9f, 0xee00eeee, 0x4a004a4a, 0xc300c3c3, 0x2e002e2e,
221 0xc100c1c1, 0x01000101, 0xe600e6e6, 0x25002525, 0x48004848, 0x99009999,
222 0xb900b9b9, 0xb300b3b3, 0x7b007b7b, 0xf900f9f9, 0xce00cece, 0xbf00bfbf,
223 0xdf00dfdf, 0x71007171, 0x29002929, 0xcd00cdcd, 0x6c006c6c, 0x13001313,
224 0x64006464, 0x9b009b9b, 0x63006363, 0x9d009d9d, 0xc000c0c0, 0x4b004b4b,
225 0xb700b7b7, 0xa500a5a5, 0x89008989, 0x5f005f5f, 0xb100b1b1, 0x17001717,
226 0xf400f4f4, 0xbc00bcbc, 0xd300d3d3, 0x46004646, 0xcf00cfcf, 0x37003737,
227 0x5e005e5e, 0x47004747, 0x94009494, 0xfa00fafa, 0xfc00fcfc, 0x5b005b5b,
228 0x97009797, 0xfe00fefe, 0x5a005a5a, 0xac00acac, 0x3c003c3c, 0x4c004c4c,
229 0x03000303, 0x35003535, 0xf300f3f3, 0x23002323, 0xb800b8b8, 0x5d005d5d,
230 0x6a006a6a, 0x92009292, 0xd500d5d5, 0x21002121, 0x44004444, 0x51005151,
231 0xc600c6c6, 0x7d007d7d, 0x39003939, 0x83008383, 0xdc00dcdc, 0xaa00aaaa,
232 0x7c007c7c, 0x77007777, 0x56005656, 0x05000505, 0x1b001b1b, 0xa400a4a4,
233 0x15001515, 0x34003434, 0x1e001e1e, 0x1c001c1c, 0xf800f8f8, 0x52005252,
234 0x20002020, 0x14001414, 0xe900e9e9, 0xbd00bdbd, 0xdd00dddd, 0xe400e4e4,
235 0xa100a1a1, 0xe000e0e0, 0x8a008a8a, 0xf100f1f1, 0xd600d6d6, 0x7a007a7a,
236 0xbb00bbbb, 0xe300e3e3, 0x40004040, 0x4f004f4f}
237 };
238
239 /* Key generation constants */
240 static const u32 SIGMA[] = {
241 0xa09e667f, 0x3bcc908b, 0xb67ae858, 0x4caa73b2, 0xc6ef372f, 0xe94f82be,
242 0x54ff53a5, 0xf1d36f1c, 0x10e527fa, 0xde682d1d, 0xb05688c2, 0xb3e6c1fd
243 };
244
245 /* The phi algorithm given in C.2.7 of the Camellia spec document. */
246 /*
247 * This version does not attempt to minimize amount of temporary
248 * variables, but instead explicitly exposes algorithm's parallelism.
249 * It is therefore most appropriate for platforms with not less than
250 * ~16 registers. For platforms with less registers [well, x86 to be
251 * specific] assembler version should be/is provided anyway...
252 */
253 #define Camellia_Feistel(_s0,_s1,_s2,_s3,_key) do {\
254 register u32 _t0,_t1,_t2,_t3;\
255 \
256 _t0 = _s0 ^ (_key)[0];\
257 _t3 = SBOX4_4404[_t0&0xff];\
258 _t1 = _s1 ^ (_key)[1];\
259 _t3 ^= SBOX3_3033[(_t0 >> 8)&0xff];\
260 _t2 = SBOX1_1110[_t1&0xff];\
261 _t3 ^= SBOX2_0222[(_t0 >> 16)&0xff];\
262 _t2 ^= SBOX4_4404[(_t1 >> 8)&0xff];\
263 _t3 ^= SBOX1_1110[(_t0 >> 24)];\
264 _t2 ^= _t3;\
265 _t3 = RightRotate(_t3,8);\
266 _t2 ^= SBOX3_3033[(_t1 >> 16)&0xff];\
267 _s3 ^= _t3;\
268 _t2 ^= SBOX2_0222[(_t1 >> 24)];\
269 _s2 ^= _t2; \
270 _s3 ^= _t2;\
271 } while(0)
272
273 /*
274 * Note that n has to be less than 32. Rotations for larger amount
275 * of bits are achieved by "rotating" order of s-elements and
276 * adjusting n accordingly, e.g. RotLeft128(s1,s2,s3,s0,n-32).
277 */
278 #define RotLeft128(_s0,_s1,_s2,_s3,_n) do {\
279 u32 _t0=_s0>>(32-_n);\
280 _s0 = (_s0<<_n) | (_s1>>(32-_n));\
281 _s1 = (_s1<<_n) | (_s2>>(32-_n));\
282 _s2 = (_s2<<_n) | (_s3>>(32-_n));\
283 _s3 = (_s3<<_n) | _t0;\
284 } while (0)
285
Camellia_Ekeygen(int keyBitLength,const u8 * rawKey,KEY_TABLE_TYPE k)286 int Camellia_Ekeygen(int keyBitLength, const u8 *rawKey, KEY_TABLE_TYPE k)
287 {
288 register u32 s0, s1, s2, s3;
289
290 k[0] = s0 = GETU32(rawKey);
291 k[1] = s1 = GETU32(rawKey + 4);
292 k[2] = s2 = GETU32(rawKey + 8);
293 k[3] = s3 = GETU32(rawKey + 12);
294
295 if (keyBitLength != 128) {
296 k[8] = s0 = GETU32(rawKey + 16);
297 k[9] = s1 = GETU32(rawKey + 20);
298 if (keyBitLength == 192) {
299 k[10] = s2 = ~s0;
300 k[11] = s3 = ~s1;
301 } else {
302 k[10] = s2 = GETU32(rawKey + 24);
303 k[11] = s3 = GETU32(rawKey + 28);
304 }
305 s0 ^= k[0], s1 ^= k[1], s2 ^= k[2], s3 ^= k[3];
306 }
307
308 /* Use the Feistel routine to scramble the key material */
309 Camellia_Feistel(s0, s1, s2, s3, SIGMA + 0);
310 Camellia_Feistel(s2, s3, s0, s1, SIGMA + 2);
311
312 s0 ^= k[0], s1 ^= k[1], s2 ^= k[2], s3 ^= k[3];
313 Camellia_Feistel(s0, s1, s2, s3, SIGMA + 4);
314 Camellia_Feistel(s2, s3, s0, s1, SIGMA + 6);
315
316 /* Fill the keyTable. Requires many block rotations. */
317 if (keyBitLength == 128) {
318 k[4] = s0, k[5] = s1, k[6] = s2, k[7] = s3;
319 RotLeft128(s0, s1, s2, s3, 15); /* KA <<< 15 */
320 k[12] = s0, k[13] = s1, k[14] = s2, k[15] = s3;
321 RotLeft128(s0, s1, s2, s3, 15); /* KA <<< 30 */
322 k[16] = s0, k[17] = s1, k[18] = s2, k[19] = s3;
323 RotLeft128(s0, s1, s2, s3, 15); /* KA <<< 45 */
324 k[24] = s0, k[25] = s1;
325 RotLeft128(s0, s1, s2, s3, 15); /* KA <<< 60 */
326 k[28] = s0, k[29] = s1, k[30] = s2, k[31] = s3;
327 RotLeft128(s1, s2, s3, s0, 2); /* KA <<< 94 */
328 k[40] = s1, k[41] = s2, k[42] = s3, k[43] = s0;
329 RotLeft128(s1, s2, s3, s0, 17); /* KA <<<111 */
330 k[48] = s1, k[49] = s2, k[50] = s3, k[51] = s0;
331
332 s0 = k[0], s1 = k[1], s2 = k[2], s3 = k[3];
333 RotLeft128(s0, s1, s2, s3, 15); /* KL <<< 15 */
334 k[8] = s0, k[9] = s1, k[10] = s2, k[11] = s3;
335 RotLeft128(s0, s1, s2, s3, 30); /* KL <<< 45 */
336 k[20] = s0, k[21] = s1, k[22] = s2, k[23] = s3;
337 RotLeft128(s0, s1, s2, s3, 15); /* KL <<< 60 */
338 k[26] = s2, k[27] = s3;
339 RotLeft128(s0, s1, s2, s3, 17); /* KL <<< 77 */
340 k[32] = s0, k[33] = s1, k[34] = s2, k[35] = s3;
341 RotLeft128(s0, s1, s2, s3, 17); /* KL <<< 94 */
342 k[36] = s0, k[37] = s1, k[38] = s2, k[39] = s3;
343 RotLeft128(s0, s1, s2, s3, 17); /* KL <<<111 */
344 k[44] = s0, k[45] = s1, k[46] = s2, k[47] = s3;
345
346 return 3; /* grand rounds */
347 } else {
348 k[12] = s0, k[13] = s1, k[14] = s2, k[15] = s3;
349 s0 ^= k[8], s1 ^= k[9], s2 ^= k[10], s3 ^= k[11];
350 Camellia_Feistel(s0, s1, s2, s3, (SIGMA + 8));
351 Camellia_Feistel(s2, s3, s0, s1, (SIGMA + 10));
352
353 k[4] = s0, k[5] = s1, k[6] = s2, k[7] = s3;
354 RotLeft128(s0, s1, s2, s3, 30); /* KB <<< 30 */
355 k[20] = s0, k[21] = s1, k[22] = s2, k[23] = s3;
356 RotLeft128(s0, s1, s2, s3, 30); /* KB <<< 60 */
357 k[40] = s0, k[41] = s1, k[42] = s2, k[43] = s3;
358 RotLeft128(s1, s2, s3, s0, 19); /* KB <<<111 */
359 k[64] = s1, k[65] = s2, k[66] = s3, k[67] = s0;
360
361 s0 = k[8], s1 = k[9], s2 = k[10], s3 = k[11];
362 RotLeft128(s0, s1, s2, s3, 15); /* KR <<< 15 */
363 k[8] = s0, k[9] = s1, k[10] = s2, k[11] = s3;
364 RotLeft128(s0, s1, s2, s3, 15); /* KR <<< 30 */
365 k[16] = s0, k[17] = s1, k[18] = s2, k[19] = s3;
366 RotLeft128(s0, s1, s2, s3, 30); /* KR <<< 60 */
367 k[36] = s0, k[37] = s1, k[38] = s2, k[39] = s3;
368 RotLeft128(s1, s2, s3, s0, 2); /* KR <<< 94 */
369 k[52] = s1, k[53] = s2, k[54] = s3, k[55] = s0;
370
371 s0 = k[12], s1 = k[13], s2 = k[14], s3 = k[15];
372 RotLeft128(s0, s1, s2, s3, 15); /* KA <<< 15 */
373 k[12] = s0, k[13] = s1, k[14] = s2, k[15] = s3;
374 RotLeft128(s0, s1, s2, s3, 30); /* KA <<< 45 */
375 k[28] = s0, k[29] = s1, k[30] = s2, k[31] = s3;
376 /* KA <<< 77 */
377 k[48] = s1, k[49] = s2, k[50] = s3, k[51] = s0;
378 RotLeft128(s1, s2, s3, s0, 17); /* KA <<< 94 */
379 k[56] = s1, k[57] = s2, k[58] = s3, k[59] = s0;
380
381 s0 = k[0], s1 = k[1], s2 = k[2], s3 = k[3];
382 RotLeft128(s1, s2, s3, s0, 13); /* KL <<< 45 */
383 k[24] = s1, k[25] = s2, k[26] = s3, k[27] = s0;
384 RotLeft128(s1, s2, s3, s0, 15); /* KL <<< 60 */
385 k[32] = s1, k[33] = s2, k[34] = s3, k[35] = s0;
386 RotLeft128(s1, s2, s3, s0, 17); /* KL <<< 77 */
387 k[44] = s1, k[45] = s2, k[46] = s3, k[47] = s0;
388 RotLeft128(s2, s3, s0, s1, 2); /* KL <<<111 */
389 k[60] = s2, k[61] = s3, k[62] = s0, k[63] = s1;
390
391 return 4; /* grand rounds */
392 }
393 /*
394 * It is possible to perform certain precalculations, which
395 * would spare few cycles in block procedure. It's not done,
396 * because it upsets the performance balance between key
397 * setup and block procedures, negatively affecting overall
398 * throughput in applications operating on short messages
399 * and volatile keys.
400 */
401 }
402
Camellia_EncryptBlock_Rounds(int grandRounds,const u8 plaintext[],const KEY_TABLE_TYPE keyTable,u8 ciphertext[])403 void Camellia_EncryptBlock_Rounds(int grandRounds, const u8 plaintext[],
404 const KEY_TABLE_TYPE keyTable,
405 u8 ciphertext[])
406 {
407 register u32 s0, s1, s2, s3;
408 const u32 *k = keyTable, *kend = keyTable + grandRounds * 16;
409
410 s0 = GETU32(plaintext) ^ k[0];
411 s1 = GETU32(plaintext + 4) ^ k[1];
412 s2 = GETU32(plaintext + 8) ^ k[2];
413 s3 = GETU32(plaintext + 12) ^ k[3];
414 k += 4;
415
416 while (1) {
417 /* Camellia makes 6 Feistel rounds */
418 Camellia_Feistel(s0, s1, s2, s3, k + 0);
419 Camellia_Feistel(s2, s3, s0, s1, k + 2);
420 Camellia_Feistel(s0, s1, s2, s3, k + 4);
421 Camellia_Feistel(s2, s3, s0, s1, k + 6);
422 Camellia_Feistel(s0, s1, s2, s3, k + 8);
423 Camellia_Feistel(s2, s3, s0, s1, k + 10);
424 k += 12;
425
426 if (k == kend)
427 break;
428
429 /*
430 * This is the same function as the diffusion function D of the
431 * accompanying documentation. See section 3.2 for properties of the
432 * FLlayer function.
433 */
434 s1 ^= LeftRotate(s0 & k[0], 1);
435 s2 ^= s3 | k[3];
436 s0 ^= s1 | k[1];
437 s3 ^= LeftRotate(s2 & k[2], 1);
438 k += 4;
439 }
440
441 s2 ^= k[0], s3 ^= k[1], s0 ^= k[2], s1 ^= k[3];
442
443 PUTU32(ciphertext, s2);
444 PUTU32(ciphertext + 4, s3);
445 PUTU32(ciphertext + 8, s0);
446 PUTU32(ciphertext + 12, s1);
447 }
448
Camellia_EncryptBlock(int keyBitLength,const u8 plaintext[],const KEY_TABLE_TYPE keyTable,u8 ciphertext[])449 void Camellia_EncryptBlock(int keyBitLength, const u8 plaintext[],
450 const KEY_TABLE_TYPE keyTable, u8 ciphertext[])
451 {
452 Camellia_EncryptBlock_Rounds(keyBitLength == 128 ? 3 : 4,
453 plaintext, keyTable, ciphertext);
454 }
455
Camellia_DecryptBlock_Rounds(int grandRounds,const u8 ciphertext[],const KEY_TABLE_TYPE keyTable,u8 plaintext[])456 void Camellia_DecryptBlock_Rounds(int grandRounds, const u8 ciphertext[],
457 const KEY_TABLE_TYPE keyTable,
458 u8 plaintext[])
459 {
460 u32 s0, s1, s2, s3;
461 const u32 *k = keyTable + grandRounds * 16, *kend = keyTable + 4;
462
463 s0 = GETU32(ciphertext) ^ k[0];
464 s1 = GETU32(ciphertext + 4) ^ k[1];
465 s2 = GETU32(ciphertext + 8) ^ k[2];
466 s3 = GETU32(ciphertext + 12) ^ k[3];
467
468 while (1) {
469 /* Camellia makes 6 Feistel rounds */
470 k -= 12;
471 Camellia_Feistel(s0, s1, s2, s3, k + 10);
472 Camellia_Feistel(s2, s3, s0, s1, k + 8);
473 Camellia_Feistel(s0, s1, s2, s3, k + 6);
474 Camellia_Feistel(s2, s3, s0, s1, k + 4);
475 Camellia_Feistel(s0, s1, s2, s3, k + 2);
476 Camellia_Feistel(s2, s3, s0, s1, k + 0);
477
478 if (k == kend)
479 break;
480
481 /*
482 * This is the same function as the diffusion function D of the
483 * accompanying documentation. See section 3.2 for properties of the
484 * FLlayer function.
485 */
486 k -= 4;
487 s1 ^= LeftRotate(s0 & k[2], 1);
488 s2 ^= s3 | k[1];
489 s0 ^= s1 | k[3];
490 s3 ^= LeftRotate(s2 & k[0], 1);
491 }
492
493 k -= 4;
494 s2 ^= k[0], s3 ^= k[1], s0 ^= k[2], s1 ^= k[3];
495
496 PUTU32(plaintext, s2);
497 PUTU32(plaintext + 4, s3);
498 PUTU32(plaintext + 8, s0);
499 PUTU32(plaintext + 12, s1);
500 }
501
Camellia_DecryptBlock(int keyBitLength,const u8 ciphertext[],const KEY_TABLE_TYPE keyTable,u8 plaintext[])502 void Camellia_DecryptBlock(int keyBitLength, const u8 ciphertext[],
503 const KEY_TABLE_TYPE keyTable, u8 plaintext[])
504 {
505 Camellia_DecryptBlock_Rounds(keyBitLength == 128 ? 3 : 4,
506 ciphertext, keyTable, plaintext);
507 }
508