xref: /linux/crypto/aes_generic.c (revision 0883c2c06fb5bcf5b9e008270827e63c09a88c1e)
1 /*
2  * Cryptographic API.
3  *
4  * AES Cipher Algorithm.
5  *
6  * Based on Brian Gladman's code.
7  *
8  * Linux developers:
9  *  Alexander Kjeldaas <astor@fast.no>
10  *  Herbert Valerio Riedel <hvr@hvrlab.org>
11  *  Kyle McMartin <kyle@debian.org>
12  *  Adam J. Richter <adam@yggdrasil.com> (conversion to 2.5 API).
13  *
14  * This program is free software; you can redistribute it and/or modify
15  * it under the terms of the GNU General Public License as published by
16  * the Free Software Foundation; either version 2 of the License, or
17  * (at your option) any later version.
18  *
19  * ---------------------------------------------------------------------------
20  * Copyright (c) 2002, Dr Brian Gladman <brg@gladman.me.uk>, Worcester, UK.
21  * All rights reserved.
22  *
23  * LICENSE TERMS
24  *
25  * The free distribution and use of this software in both source and binary
26  * form is allowed (with or without changes) provided that:
27  *
28  *   1. distributions of this source code include the above copyright
29  *      notice, this list of conditions and the following disclaimer;
30  *
31  *   2. distributions in binary form include the above copyright
32  *      notice, this list of conditions and the following disclaimer
33  *      in the documentation and/or other associated materials;
34  *
35  *   3. the copyright holder's name is not used to endorse products
36  *      built using this software without specific written permission.
37  *
38  * ALTERNATIVELY, provided that this notice is retained in full, this product
39  * may be distributed under the terms of the GNU General Public License (GPL),
40  * in which case the provisions of the GPL apply INSTEAD OF those given above.
41  *
42  * DISCLAIMER
43  *
44  * This software is provided 'as is' with no explicit or implied warranties
45  * in respect of its properties, including, but not limited to, correctness
46  * and/or fitness for purpose.
47  * ---------------------------------------------------------------------------
48  */
49 
50 #include <crypto/aes.h>
51 #include <linux/module.h>
52 #include <linux/init.h>
53 #include <linux/types.h>
54 #include <linux/errno.h>
55 #include <linux/crypto.h>
56 #include <asm/byteorder.h>
57 
58 static inline u8 byte(const u32 x, const unsigned n)
59 {
60 	return x >> (n << 3);
61 }
62 
63 static const u32 rco_tab[10] = { 1, 2, 4, 8, 16, 32, 64, 128, 27, 54 };
64 
65 __visible const u32 crypto_ft_tab[4][256] = {
66 	{
67 		0xa56363c6, 0x847c7cf8, 0x997777ee, 0x8d7b7bf6,
68 		0x0df2f2ff, 0xbd6b6bd6, 0xb16f6fde, 0x54c5c591,
69 		0x50303060, 0x03010102, 0xa96767ce, 0x7d2b2b56,
70 		0x19fefee7, 0x62d7d7b5, 0xe6abab4d, 0x9a7676ec,
71 		0x45caca8f, 0x9d82821f, 0x40c9c989, 0x877d7dfa,
72 		0x15fafaef, 0xeb5959b2, 0xc947478e, 0x0bf0f0fb,
73 		0xecadad41, 0x67d4d4b3, 0xfda2a25f, 0xeaafaf45,
74 		0xbf9c9c23, 0xf7a4a453, 0x967272e4, 0x5bc0c09b,
75 		0xc2b7b775, 0x1cfdfde1, 0xae93933d, 0x6a26264c,
76 		0x5a36366c, 0x413f3f7e, 0x02f7f7f5, 0x4fcccc83,
77 		0x5c343468, 0xf4a5a551, 0x34e5e5d1, 0x08f1f1f9,
78 		0x937171e2, 0x73d8d8ab, 0x53313162, 0x3f15152a,
79 		0x0c040408, 0x52c7c795, 0x65232346, 0x5ec3c39d,
80 		0x28181830, 0xa1969637, 0x0f05050a, 0xb59a9a2f,
81 		0x0907070e, 0x36121224, 0x9b80801b, 0x3de2e2df,
82 		0x26ebebcd, 0x6927274e, 0xcdb2b27f, 0x9f7575ea,
83 		0x1b090912, 0x9e83831d, 0x742c2c58, 0x2e1a1a34,
84 		0x2d1b1b36, 0xb26e6edc, 0xee5a5ab4, 0xfba0a05b,
85 		0xf65252a4, 0x4d3b3b76, 0x61d6d6b7, 0xceb3b37d,
86 		0x7b292952, 0x3ee3e3dd, 0x712f2f5e, 0x97848413,
87 		0xf55353a6, 0x68d1d1b9, 0x00000000, 0x2cededc1,
88 		0x60202040, 0x1ffcfce3, 0xc8b1b179, 0xed5b5bb6,
89 		0xbe6a6ad4, 0x46cbcb8d, 0xd9bebe67, 0x4b393972,
90 		0xde4a4a94, 0xd44c4c98, 0xe85858b0, 0x4acfcf85,
91 		0x6bd0d0bb, 0x2aefefc5, 0xe5aaaa4f, 0x16fbfbed,
92 		0xc5434386, 0xd74d4d9a, 0x55333366, 0x94858511,
93 		0xcf45458a, 0x10f9f9e9, 0x06020204, 0x817f7ffe,
94 		0xf05050a0, 0x443c3c78, 0xba9f9f25, 0xe3a8a84b,
95 		0xf35151a2, 0xfea3a35d, 0xc0404080, 0x8a8f8f05,
96 		0xad92923f, 0xbc9d9d21, 0x48383870, 0x04f5f5f1,
97 		0xdfbcbc63, 0xc1b6b677, 0x75dadaaf, 0x63212142,
98 		0x30101020, 0x1affffe5, 0x0ef3f3fd, 0x6dd2d2bf,
99 		0x4ccdcd81, 0x140c0c18, 0x35131326, 0x2fececc3,
100 		0xe15f5fbe, 0xa2979735, 0xcc444488, 0x3917172e,
101 		0x57c4c493, 0xf2a7a755, 0x827e7efc, 0x473d3d7a,
102 		0xac6464c8, 0xe75d5dba, 0x2b191932, 0x957373e6,
103 		0xa06060c0, 0x98818119, 0xd14f4f9e, 0x7fdcdca3,
104 		0x66222244, 0x7e2a2a54, 0xab90903b, 0x8388880b,
105 		0xca46468c, 0x29eeeec7, 0xd3b8b86b, 0x3c141428,
106 		0x79dedea7, 0xe25e5ebc, 0x1d0b0b16, 0x76dbdbad,
107 		0x3be0e0db, 0x56323264, 0x4e3a3a74, 0x1e0a0a14,
108 		0xdb494992, 0x0a06060c, 0x6c242448, 0xe45c5cb8,
109 		0x5dc2c29f, 0x6ed3d3bd, 0xefacac43, 0xa66262c4,
110 		0xa8919139, 0xa4959531, 0x37e4e4d3, 0x8b7979f2,
111 		0x32e7e7d5, 0x43c8c88b, 0x5937376e, 0xb76d6dda,
112 		0x8c8d8d01, 0x64d5d5b1, 0xd24e4e9c, 0xe0a9a949,
113 		0xb46c6cd8, 0xfa5656ac, 0x07f4f4f3, 0x25eaeacf,
114 		0xaf6565ca, 0x8e7a7af4, 0xe9aeae47, 0x18080810,
115 		0xd5baba6f, 0x887878f0, 0x6f25254a, 0x722e2e5c,
116 		0x241c1c38, 0xf1a6a657, 0xc7b4b473, 0x51c6c697,
117 		0x23e8e8cb, 0x7cdddda1, 0x9c7474e8, 0x211f1f3e,
118 		0xdd4b4b96, 0xdcbdbd61, 0x868b8b0d, 0x858a8a0f,
119 		0x907070e0, 0x423e3e7c, 0xc4b5b571, 0xaa6666cc,
120 		0xd8484890, 0x05030306, 0x01f6f6f7, 0x120e0e1c,
121 		0xa36161c2, 0x5f35356a, 0xf95757ae, 0xd0b9b969,
122 		0x91868617, 0x58c1c199, 0x271d1d3a, 0xb99e9e27,
123 		0x38e1e1d9, 0x13f8f8eb, 0xb398982b, 0x33111122,
124 		0xbb6969d2, 0x70d9d9a9, 0x898e8e07, 0xa7949433,
125 		0xb69b9b2d, 0x221e1e3c, 0x92878715, 0x20e9e9c9,
126 		0x49cece87, 0xff5555aa, 0x78282850, 0x7adfdfa5,
127 		0x8f8c8c03, 0xf8a1a159, 0x80898909, 0x170d0d1a,
128 		0xdabfbf65, 0x31e6e6d7, 0xc6424284, 0xb86868d0,
129 		0xc3414182, 0xb0999929, 0x772d2d5a, 0x110f0f1e,
130 		0xcbb0b07b, 0xfc5454a8, 0xd6bbbb6d, 0x3a16162c,
131 	}, {
132 		0x6363c6a5, 0x7c7cf884, 0x7777ee99, 0x7b7bf68d,
133 		0xf2f2ff0d, 0x6b6bd6bd, 0x6f6fdeb1, 0xc5c59154,
134 		0x30306050, 0x01010203, 0x6767cea9, 0x2b2b567d,
135 		0xfefee719, 0xd7d7b562, 0xabab4de6, 0x7676ec9a,
136 		0xcaca8f45, 0x82821f9d, 0xc9c98940, 0x7d7dfa87,
137 		0xfafaef15, 0x5959b2eb, 0x47478ec9, 0xf0f0fb0b,
138 		0xadad41ec, 0xd4d4b367, 0xa2a25ffd, 0xafaf45ea,
139 		0x9c9c23bf, 0xa4a453f7, 0x7272e496, 0xc0c09b5b,
140 		0xb7b775c2, 0xfdfde11c, 0x93933dae, 0x26264c6a,
141 		0x36366c5a, 0x3f3f7e41, 0xf7f7f502, 0xcccc834f,
142 		0x3434685c, 0xa5a551f4, 0xe5e5d134, 0xf1f1f908,
143 		0x7171e293, 0xd8d8ab73, 0x31316253, 0x15152a3f,
144 		0x0404080c, 0xc7c79552, 0x23234665, 0xc3c39d5e,
145 		0x18183028, 0x969637a1, 0x05050a0f, 0x9a9a2fb5,
146 		0x07070e09, 0x12122436, 0x80801b9b, 0xe2e2df3d,
147 		0xebebcd26, 0x27274e69, 0xb2b27fcd, 0x7575ea9f,
148 		0x0909121b, 0x83831d9e, 0x2c2c5874, 0x1a1a342e,
149 		0x1b1b362d, 0x6e6edcb2, 0x5a5ab4ee, 0xa0a05bfb,
150 		0x5252a4f6, 0x3b3b764d, 0xd6d6b761, 0xb3b37dce,
151 		0x2929527b, 0xe3e3dd3e, 0x2f2f5e71, 0x84841397,
152 		0x5353a6f5, 0xd1d1b968, 0x00000000, 0xededc12c,
153 		0x20204060, 0xfcfce31f, 0xb1b179c8, 0x5b5bb6ed,
154 		0x6a6ad4be, 0xcbcb8d46, 0xbebe67d9, 0x3939724b,
155 		0x4a4a94de, 0x4c4c98d4, 0x5858b0e8, 0xcfcf854a,
156 		0xd0d0bb6b, 0xefefc52a, 0xaaaa4fe5, 0xfbfbed16,
157 		0x434386c5, 0x4d4d9ad7, 0x33336655, 0x85851194,
158 		0x45458acf, 0xf9f9e910, 0x02020406, 0x7f7ffe81,
159 		0x5050a0f0, 0x3c3c7844, 0x9f9f25ba, 0xa8a84be3,
160 		0x5151a2f3, 0xa3a35dfe, 0x404080c0, 0x8f8f058a,
161 		0x92923fad, 0x9d9d21bc, 0x38387048, 0xf5f5f104,
162 		0xbcbc63df, 0xb6b677c1, 0xdadaaf75, 0x21214263,
163 		0x10102030, 0xffffe51a, 0xf3f3fd0e, 0xd2d2bf6d,
164 		0xcdcd814c, 0x0c0c1814, 0x13132635, 0xececc32f,
165 		0x5f5fbee1, 0x979735a2, 0x444488cc, 0x17172e39,
166 		0xc4c49357, 0xa7a755f2, 0x7e7efc82, 0x3d3d7a47,
167 		0x6464c8ac, 0x5d5dbae7, 0x1919322b, 0x7373e695,
168 		0x6060c0a0, 0x81811998, 0x4f4f9ed1, 0xdcdca37f,
169 		0x22224466, 0x2a2a547e, 0x90903bab, 0x88880b83,
170 		0x46468cca, 0xeeeec729, 0xb8b86bd3, 0x1414283c,
171 		0xdedea779, 0x5e5ebce2, 0x0b0b161d, 0xdbdbad76,
172 		0xe0e0db3b, 0x32326456, 0x3a3a744e, 0x0a0a141e,
173 		0x494992db, 0x06060c0a, 0x2424486c, 0x5c5cb8e4,
174 		0xc2c29f5d, 0xd3d3bd6e, 0xacac43ef, 0x6262c4a6,
175 		0x919139a8, 0x959531a4, 0xe4e4d337, 0x7979f28b,
176 		0xe7e7d532, 0xc8c88b43, 0x37376e59, 0x6d6ddab7,
177 		0x8d8d018c, 0xd5d5b164, 0x4e4e9cd2, 0xa9a949e0,
178 		0x6c6cd8b4, 0x5656acfa, 0xf4f4f307, 0xeaeacf25,
179 		0x6565caaf, 0x7a7af48e, 0xaeae47e9, 0x08081018,
180 		0xbaba6fd5, 0x7878f088, 0x25254a6f, 0x2e2e5c72,
181 		0x1c1c3824, 0xa6a657f1, 0xb4b473c7, 0xc6c69751,
182 		0xe8e8cb23, 0xdddda17c, 0x7474e89c, 0x1f1f3e21,
183 		0x4b4b96dd, 0xbdbd61dc, 0x8b8b0d86, 0x8a8a0f85,
184 		0x7070e090, 0x3e3e7c42, 0xb5b571c4, 0x6666ccaa,
185 		0x484890d8, 0x03030605, 0xf6f6f701, 0x0e0e1c12,
186 		0x6161c2a3, 0x35356a5f, 0x5757aef9, 0xb9b969d0,
187 		0x86861791, 0xc1c19958, 0x1d1d3a27, 0x9e9e27b9,
188 		0xe1e1d938, 0xf8f8eb13, 0x98982bb3, 0x11112233,
189 		0x6969d2bb, 0xd9d9a970, 0x8e8e0789, 0x949433a7,
190 		0x9b9b2db6, 0x1e1e3c22, 0x87871592, 0xe9e9c920,
191 		0xcece8749, 0x5555aaff, 0x28285078, 0xdfdfa57a,
192 		0x8c8c038f, 0xa1a159f8, 0x89890980, 0x0d0d1a17,
193 		0xbfbf65da, 0xe6e6d731, 0x424284c6, 0x6868d0b8,
194 		0x414182c3, 0x999929b0, 0x2d2d5a77, 0x0f0f1e11,
195 		0xb0b07bcb, 0x5454a8fc, 0xbbbb6dd6, 0x16162c3a,
196 	}, {
197 		0x63c6a563, 0x7cf8847c, 0x77ee9977, 0x7bf68d7b,
198 		0xf2ff0df2, 0x6bd6bd6b, 0x6fdeb16f, 0xc59154c5,
199 		0x30605030, 0x01020301, 0x67cea967, 0x2b567d2b,
200 		0xfee719fe, 0xd7b562d7, 0xab4de6ab, 0x76ec9a76,
201 		0xca8f45ca, 0x821f9d82, 0xc98940c9, 0x7dfa877d,
202 		0xfaef15fa, 0x59b2eb59, 0x478ec947, 0xf0fb0bf0,
203 		0xad41ecad, 0xd4b367d4, 0xa25ffda2, 0xaf45eaaf,
204 		0x9c23bf9c, 0xa453f7a4, 0x72e49672, 0xc09b5bc0,
205 		0xb775c2b7, 0xfde11cfd, 0x933dae93, 0x264c6a26,
206 		0x366c5a36, 0x3f7e413f, 0xf7f502f7, 0xcc834fcc,
207 		0x34685c34, 0xa551f4a5, 0xe5d134e5, 0xf1f908f1,
208 		0x71e29371, 0xd8ab73d8, 0x31625331, 0x152a3f15,
209 		0x04080c04, 0xc79552c7, 0x23466523, 0xc39d5ec3,
210 		0x18302818, 0x9637a196, 0x050a0f05, 0x9a2fb59a,
211 		0x070e0907, 0x12243612, 0x801b9b80, 0xe2df3de2,
212 		0xebcd26eb, 0x274e6927, 0xb27fcdb2, 0x75ea9f75,
213 		0x09121b09, 0x831d9e83, 0x2c58742c, 0x1a342e1a,
214 		0x1b362d1b, 0x6edcb26e, 0x5ab4ee5a, 0xa05bfba0,
215 		0x52a4f652, 0x3b764d3b, 0xd6b761d6, 0xb37dceb3,
216 		0x29527b29, 0xe3dd3ee3, 0x2f5e712f, 0x84139784,
217 		0x53a6f553, 0xd1b968d1, 0x00000000, 0xedc12ced,
218 		0x20406020, 0xfce31ffc, 0xb179c8b1, 0x5bb6ed5b,
219 		0x6ad4be6a, 0xcb8d46cb, 0xbe67d9be, 0x39724b39,
220 		0x4a94de4a, 0x4c98d44c, 0x58b0e858, 0xcf854acf,
221 		0xd0bb6bd0, 0xefc52aef, 0xaa4fe5aa, 0xfbed16fb,
222 		0x4386c543, 0x4d9ad74d, 0x33665533, 0x85119485,
223 		0x458acf45, 0xf9e910f9, 0x02040602, 0x7ffe817f,
224 		0x50a0f050, 0x3c78443c, 0x9f25ba9f, 0xa84be3a8,
225 		0x51a2f351, 0xa35dfea3, 0x4080c040, 0x8f058a8f,
226 		0x923fad92, 0x9d21bc9d, 0x38704838, 0xf5f104f5,
227 		0xbc63dfbc, 0xb677c1b6, 0xdaaf75da, 0x21426321,
228 		0x10203010, 0xffe51aff, 0xf3fd0ef3, 0xd2bf6dd2,
229 		0xcd814ccd, 0x0c18140c, 0x13263513, 0xecc32fec,
230 		0x5fbee15f, 0x9735a297, 0x4488cc44, 0x172e3917,
231 		0xc49357c4, 0xa755f2a7, 0x7efc827e, 0x3d7a473d,
232 		0x64c8ac64, 0x5dbae75d, 0x19322b19, 0x73e69573,
233 		0x60c0a060, 0x81199881, 0x4f9ed14f, 0xdca37fdc,
234 		0x22446622, 0x2a547e2a, 0x903bab90, 0x880b8388,
235 		0x468cca46, 0xeec729ee, 0xb86bd3b8, 0x14283c14,
236 		0xdea779de, 0x5ebce25e, 0x0b161d0b, 0xdbad76db,
237 		0xe0db3be0, 0x32645632, 0x3a744e3a, 0x0a141e0a,
238 		0x4992db49, 0x060c0a06, 0x24486c24, 0x5cb8e45c,
239 		0xc29f5dc2, 0xd3bd6ed3, 0xac43efac, 0x62c4a662,
240 		0x9139a891, 0x9531a495, 0xe4d337e4, 0x79f28b79,
241 		0xe7d532e7, 0xc88b43c8, 0x376e5937, 0x6ddab76d,
242 		0x8d018c8d, 0xd5b164d5, 0x4e9cd24e, 0xa949e0a9,
243 		0x6cd8b46c, 0x56acfa56, 0xf4f307f4, 0xeacf25ea,
244 		0x65caaf65, 0x7af48e7a, 0xae47e9ae, 0x08101808,
245 		0xba6fd5ba, 0x78f08878, 0x254a6f25, 0x2e5c722e,
246 		0x1c38241c, 0xa657f1a6, 0xb473c7b4, 0xc69751c6,
247 		0xe8cb23e8, 0xdda17cdd, 0x74e89c74, 0x1f3e211f,
248 		0x4b96dd4b, 0xbd61dcbd, 0x8b0d868b, 0x8a0f858a,
249 		0x70e09070, 0x3e7c423e, 0xb571c4b5, 0x66ccaa66,
250 		0x4890d848, 0x03060503, 0xf6f701f6, 0x0e1c120e,
251 		0x61c2a361, 0x356a5f35, 0x57aef957, 0xb969d0b9,
252 		0x86179186, 0xc19958c1, 0x1d3a271d, 0x9e27b99e,
253 		0xe1d938e1, 0xf8eb13f8, 0x982bb398, 0x11223311,
254 		0x69d2bb69, 0xd9a970d9, 0x8e07898e, 0x9433a794,
255 		0x9b2db69b, 0x1e3c221e, 0x87159287, 0xe9c920e9,
256 		0xce8749ce, 0x55aaff55, 0x28507828, 0xdfa57adf,
257 		0x8c038f8c, 0xa159f8a1, 0x89098089, 0x0d1a170d,
258 		0xbf65dabf, 0xe6d731e6, 0x4284c642, 0x68d0b868,
259 		0x4182c341, 0x9929b099, 0x2d5a772d, 0x0f1e110f,
260 		0xb07bcbb0, 0x54a8fc54, 0xbb6dd6bb, 0x162c3a16,
261 	}, {
262 		0xc6a56363, 0xf8847c7c, 0xee997777, 0xf68d7b7b,
263 		0xff0df2f2, 0xd6bd6b6b, 0xdeb16f6f, 0x9154c5c5,
264 		0x60503030, 0x02030101, 0xcea96767, 0x567d2b2b,
265 		0xe719fefe, 0xb562d7d7, 0x4de6abab, 0xec9a7676,
266 		0x8f45caca, 0x1f9d8282, 0x8940c9c9, 0xfa877d7d,
267 		0xef15fafa, 0xb2eb5959, 0x8ec94747, 0xfb0bf0f0,
268 		0x41ecadad, 0xb367d4d4, 0x5ffda2a2, 0x45eaafaf,
269 		0x23bf9c9c, 0x53f7a4a4, 0xe4967272, 0x9b5bc0c0,
270 		0x75c2b7b7, 0xe11cfdfd, 0x3dae9393, 0x4c6a2626,
271 		0x6c5a3636, 0x7e413f3f, 0xf502f7f7, 0x834fcccc,
272 		0x685c3434, 0x51f4a5a5, 0xd134e5e5, 0xf908f1f1,
273 		0xe2937171, 0xab73d8d8, 0x62533131, 0x2a3f1515,
274 		0x080c0404, 0x9552c7c7, 0x46652323, 0x9d5ec3c3,
275 		0x30281818, 0x37a19696, 0x0a0f0505, 0x2fb59a9a,
276 		0x0e090707, 0x24361212, 0x1b9b8080, 0xdf3de2e2,
277 		0xcd26ebeb, 0x4e692727, 0x7fcdb2b2, 0xea9f7575,
278 		0x121b0909, 0x1d9e8383, 0x58742c2c, 0x342e1a1a,
279 		0x362d1b1b, 0xdcb26e6e, 0xb4ee5a5a, 0x5bfba0a0,
280 		0xa4f65252, 0x764d3b3b, 0xb761d6d6, 0x7dceb3b3,
281 		0x527b2929, 0xdd3ee3e3, 0x5e712f2f, 0x13978484,
282 		0xa6f55353, 0xb968d1d1, 0x00000000, 0xc12ceded,
283 		0x40602020, 0xe31ffcfc, 0x79c8b1b1, 0xb6ed5b5b,
284 		0xd4be6a6a, 0x8d46cbcb, 0x67d9bebe, 0x724b3939,
285 		0x94de4a4a, 0x98d44c4c, 0xb0e85858, 0x854acfcf,
286 		0xbb6bd0d0, 0xc52aefef, 0x4fe5aaaa, 0xed16fbfb,
287 		0x86c54343, 0x9ad74d4d, 0x66553333, 0x11948585,
288 		0x8acf4545, 0xe910f9f9, 0x04060202, 0xfe817f7f,
289 		0xa0f05050, 0x78443c3c, 0x25ba9f9f, 0x4be3a8a8,
290 		0xa2f35151, 0x5dfea3a3, 0x80c04040, 0x058a8f8f,
291 		0x3fad9292, 0x21bc9d9d, 0x70483838, 0xf104f5f5,
292 		0x63dfbcbc, 0x77c1b6b6, 0xaf75dada, 0x42632121,
293 		0x20301010, 0xe51affff, 0xfd0ef3f3, 0xbf6dd2d2,
294 		0x814ccdcd, 0x18140c0c, 0x26351313, 0xc32fecec,
295 		0xbee15f5f, 0x35a29797, 0x88cc4444, 0x2e391717,
296 		0x9357c4c4, 0x55f2a7a7, 0xfc827e7e, 0x7a473d3d,
297 		0xc8ac6464, 0xbae75d5d, 0x322b1919, 0xe6957373,
298 		0xc0a06060, 0x19988181, 0x9ed14f4f, 0xa37fdcdc,
299 		0x44662222, 0x547e2a2a, 0x3bab9090, 0x0b838888,
300 		0x8cca4646, 0xc729eeee, 0x6bd3b8b8, 0x283c1414,
301 		0xa779dede, 0xbce25e5e, 0x161d0b0b, 0xad76dbdb,
302 		0xdb3be0e0, 0x64563232, 0x744e3a3a, 0x141e0a0a,
303 		0x92db4949, 0x0c0a0606, 0x486c2424, 0xb8e45c5c,
304 		0x9f5dc2c2, 0xbd6ed3d3, 0x43efacac, 0xc4a66262,
305 		0x39a89191, 0x31a49595, 0xd337e4e4, 0xf28b7979,
306 		0xd532e7e7, 0x8b43c8c8, 0x6e593737, 0xdab76d6d,
307 		0x018c8d8d, 0xb164d5d5, 0x9cd24e4e, 0x49e0a9a9,
308 		0xd8b46c6c, 0xacfa5656, 0xf307f4f4, 0xcf25eaea,
309 		0xcaaf6565, 0xf48e7a7a, 0x47e9aeae, 0x10180808,
310 		0x6fd5baba, 0xf0887878, 0x4a6f2525, 0x5c722e2e,
311 		0x38241c1c, 0x57f1a6a6, 0x73c7b4b4, 0x9751c6c6,
312 		0xcb23e8e8, 0xa17cdddd, 0xe89c7474, 0x3e211f1f,
313 		0x96dd4b4b, 0x61dcbdbd, 0x0d868b8b, 0x0f858a8a,
314 		0xe0907070, 0x7c423e3e, 0x71c4b5b5, 0xccaa6666,
315 		0x90d84848, 0x06050303, 0xf701f6f6, 0x1c120e0e,
316 		0xc2a36161, 0x6a5f3535, 0xaef95757, 0x69d0b9b9,
317 		0x17918686, 0x9958c1c1, 0x3a271d1d, 0x27b99e9e,
318 		0xd938e1e1, 0xeb13f8f8, 0x2bb39898, 0x22331111,
319 		0xd2bb6969, 0xa970d9d9, 0x07898e8e, 0x33a79494,
320 		0x2db69b9b, 0x3c221e1e, 0x15928787, 0xc920e9e9,
321 		0x8749cece, 0xaaff5555, 0x50782828, 0xa57adfdf,
322 		0x038f8c8c, 0x59f8a1a1, 0x09808989, 0x1a170d0d,
323 		0x65dabfbf, 0xd731e6e6, 0x84c64242, 0xd0b86868,
324 		0x82c34141, 0x29b09999, 0x5a772d2d, 0x1e110f0f,
325 		0x7bcbb0b0, 0xa8fc5454, 0x6dd6bbbb, 0x2c3a1616,
326 	}
327 };
328 
329 __visible const u32 crypto_fl_tab[4][256] = {
330 	{
331 		0x00000063, 0x0000007c, 0x00000077, 0x0000007b,
332 		0x000000f2, 0x0000006b, 0x0000006f, 0x000000c5,
333 		0x00000030, 0x00000001, 0x00000067, 0x0000002b,
334 		0x000000fe, 0x000000d7, 0x000000ab, 0x00000076,
335 		0x000000ca, 0x00000082, 0x000000c9, 0x0000007d,
336 		0x000000fa, 0x00000059, 0x00000047, 0x000000f0,
337 		0x000000ad, 0x000000d4, 0x000000a2, 0x000000af,
338 		0x0000009c, 0x000000a4, 0x00000072, 0x000000c0,
339 		0x000000b7, 0x000000fd, 0x00000093, 0x00000026,
340 		0x00000036, 0x0000003f, 0x000000f7, 0x000000cc,
341 		0x00000034, 0x000000a5, 0x000000e5, 0x000000f1,
342 		0x00000071, 0x000000d8, 0x00000031, 0x00000015,
343 		0x00000004, 0x000000c7, 0x00000023, 0x000000c3,
344 		0x00000018, 0x00000096, 0x00000005, 0x0000009a,
345 		0x00000007, 0x00000012, 0x00000080, 0x000000e2,
346 		0x000000eb, 0x00000027, 0x000000b2, 0x00000075,
347 		0x00000009, 0x00000083, 0x0000002c, 0x0000001a,
348 		0x0000001b, 0x0000006e, 0x0000005a, 0x000000a0,
349 		0x00000052, 0x0000003b, 0x000000d6, 0x000000b3,
350 		0x00000029, 0x000000e3, 0x0000002f, 0x00000084,
351 		0x00000053, 0x000000d1, 0x00000000, 0x000000ed,
352 		0x00000020, 0x000000fc, 0x000000b1, 0x0000005b,
353 		0x0000006a, 0x000000cb, 0x000000be, 0x00000039,
354 		0x0000004a, 0x0000004c, 0x00000058, 0x000000cf,
355 		0x000000d0, 0x000000ef, 0x000000aa, 0x000000fb,
356 		0x00000043, 0x0000004d, 0x00000033, 0x00000085,
357 		0x00000045, 0x000000f9, 0x00000002, 0x0000007f,
358 		0x00000050, 0x0000003c, 0x0000009f, 0x000000a8,
359 		0x00000051, 0x000000a3, 0x00000040, 0x0000008f,
360 		0x00000092, 0x0000009d, 0x00000038, 0x000000f5,
361 		0x000000bc, 0x000000b6, 0x000000da, 0x00000021,
362 		0x00000010, 0x000000ff, 0x000000f3, 0x000000d2,
363 		0x000000cd, 0x0000000c, 0x00000013, 0x000000ec,
364 		0x0000005f, 0x00000097, 0x00000044, 0x00000017,
365 		0x000000c4, 0x000000a7, 0x0000007e, 0x0000003d,
366 		0x00000064, 0x0000005d, 0x00000019, 0x00000073,
367 		0x00000060, 0x00000081, 0x0000004f, 0x000000dc,
368 		0x00000022, 0x0000002a, 0x00000090, 0x00000088,
369 		0x00000046, 0x000000ee, 0x000000b8, 0x00000014,
370 		0x000000de, 0x0000005e, 0x0000000b, 0x000000db,
371 		0x000000e0, 0x00000032, 0x0000003a, 0x0000000a,
372 		0x00000049, 0x00000006, 0x00000024, 0x0000005c,
373 		0x000000c2, 0x000000d3, 0x000000ac, 0x00000062,
374 		0x00000091, 0x00000095, 0x000000e4, 0x00000079,
375 		0x000000e7, 0x000000c8, 0x00000037, 0x0000006d,
376 		0x0000008d, 0x000000d5, 0x0000004e, 0x000000a9,
377 		0x0000006c, 0x00000056, 0x000000f4, 0x000000ea,
378 		0x00000065, 0x0000007a, 0x000000ae, 0x00000008,
379 		0x000000ba, 0x00000078, 0x00000025, 0x0000002e,
380 		0x0000001c, 0x000000a6, 0x000000b4, 0x000000c6,
381 		0x000000e8, 0x000000dd, 0x00000074, 0x0000001f,
382 		0x0000004b, 0x000000bd, 0x0000008b, 0x0000008a,
383 		0x00000070, 0x0000003e, 0x000000b5, 0x00000066,
384 		0x00000048, 0x00000003, 0x000000f6, 0x0000000e,
385 		0x00000061, 0x00000035, 0x00000057, 0x000000b9,
386 		0x00000086, 0x000000c1, 0x0000001d, 0x0000009e,
387 		0x000000e1, 0x000000f8, 0x00000098, 0x00000011,
388 		0x00000069, 0x000000d9, 0x0000008e, 0x00000094,
389 		0x0000009b, 0x0000001e, 0x00000087, 0x000000e9,
390 		0x000000ce, 0x00000055, 0x00000028, 0x000000df,
391 		0x0000008c, 0x000000a1, 0x00000089, 0x0000000d,
392 		0x000000bf, 0x000000e6, 0x00000042, 0x00000068,
393 		0x00000041, 0x00000099, 0x0000002d, 0x0000000f,
394 		0x000000b0, 0x00000054, 0x000000bb, 0x00000016,
395 	}, {
396 		0x00006300, 0x00007c00, 0x00007700, 0x00007b00,
397 		0x0000f200, 0x00006b00, 0x00006f00, 0x0000c500,
398 		0x00003000, 0x00000100, 0x00006700, 0x00002b00,
399 		0x0000fe00, 0x0000d700, 0x0000ab00, 0x00007600,
400 		0x0000ca00, 0x00008200, 0x0000c900, 0x00007d00,
401 		0x0000fa00, 0x00005900, 0x00004700, 0x0000f000,
402 		0x0000ad00, 0x0000d400, 0x0000a200, 0x0000af00,
403 		0x00009c00, 0x0000a400, 0x00007200, 0x0000c000,
404 		0x0000b700, 0x0000fd00, 0x00009300, 0x00002600,
405 		0x00003600, 0x00003f00, 0x0000f700, 0x0000cc00,
406 		0x00003400, 0x0000a500, 0x0000e500, 0x0000f100,
407 		0x00007100, 0x0000d800, 0x00003100, 0x00001500,
408 		0x00000400, 0x0000c700, 0x00002300, 0x0000c300,
409 		0x00001800, 0x00009600, 0x00000500, 0x00009a00,
410 		0x00000700, 0x00001200, 0x00008000, 0x0000e200,
411 		0x0000eb00, 0x00002700, 0x0000b200, 0x00007500,
412 		0x00000900, 0x00008300, 0x00002c00, 0x00001a00,
413 		0x00001b00, 0x00006e00, 0x00005a00, 0x0000a000,
414 		0x00005200, 0x00003b00, 0x0000d600, 0x0000b300,
415 		0x00002900, 0x0000e300, 0x00002f00, 0x00008400,
416 		0x00005300, 0x0000d100, 0x00000000, 0x0000ed00,
417 		0x00002000, 0x0000fc00, 0x0000b100, 0x00005b00,
418 		0x00006a00, 0x0000cb00, 0x0000be00, 0x00003900,
419 		0x00004a00, 0x00004c00, 0x00005800, 0x0000cf00,
420 		0x0000d000, 0x0000ef00, 0x0000aa00, 0x0000fb00,
421 		0x00004300, 0x00004d00, 0x00003300, 0x00008500,
422 		0x00004500, 0x0000f900, 0x00000200, 0x00007f00,
423 		0x00005000, 0x00003c00, 0x00009f00, 0x0000a800,
424 		0x00005100, 0x0000a300, 0x00004000, 0x00008f00,
425 		0x00009200, 0x00009d00, 0x00003800, 0x0000f500,
426 		0x0000bc00, 0x0000b600, 0x0000da00, 0x00002100,
427 		0x00001000, 0x0000ff00, 0x0000f300, 0x0000d200,
428 		0x0000cd00, 0x00000c00, 0x00001300, 0x0000ec00,
429 		0x00005f00, 0x00009700, 0x00004400, 0x00001700,
430 		0x0000c400, 0x0000a700, 0x00007e00, 0x00003d00,
431 		0x00006400, 0x00005d00, 0x00001900, 0x00007300,
432 		0x00006000, 0x00008100, 0x00004f00, 0x0000dc00,
433 		0x00002200, 0x00002a00, 0x00009000, 0x00008800,
434 		0x00004600, 0x0000ee00, 0x0000b800, 0x00001400,
435 		0x0000de00, 0x00005e00, 0x00000b00, 0x0000db00,
436 		0x0000e000, 0x00003200, 0x00003a00, 0x00000a00,
437 		0x00004900, 0x00000600, 0x00002400, 0x00005c00,
438 		0x0000c200, 0x0000d300, 0x0000ac00, 0x00006200,
439 		0x00009100, 0x00009500, 0x0000e400, 0x00007900,
440 		0x0000e700, 0x0000c800, 0x00003700, 0x00006d00,
441 		0x00008d00, 0x0000d500, 0x00004e00, 0x0000a900,
442 		0x00006c00, 0x00005600, 0x0000f400, 0x0000ea00,
443 		0x00006500, 0x00007a00, 0x0000ae00, 0x00000800,
444 		0x0000ba00, 0x00007800, 0x00002500, 0x00002e00,
445 		0x00001c00, 0x0000a600, 0x0000b400, 0x0000c600,
446 		0x0000e800, 0x0000dd00, 0x00007400, 0x00001f00,
447 		0x00004b00, 0x0000bd00, 0x00008b00, 0x00008a00,
448 		0x00007000, 0x00003e00, 0x0000b500, 0x00006600,
449 		0x00004800, 0x00000300, 0x0000f600, 0x00000e00,
450 		0x00006100, 0x00003500, 0x00005700, 0x0000b900,
451 		0x00008600, 0x0000c100, 0x00001d00, 0x00009e00,
452 		0x0000e100, 0x0000f800, 0x00009800, 0x00001100,
453 		0x00006900, 0x0000d900, 0x00008e00, 0x00009400,
454 		0x00009b00, 0x00001e00, 0x00008700, 0x0000e900,
455 		0x0000ce00, 0x00005500, 0x00002800, 0x0000df00,
456 		0x00008c00, 0x0000a100, 0x00008900, 0x00000d00,
457 		0x0000bf00, 0x0000e600, 0x00004200, 0x00006800,
458 		0x00004100, 0x00009900, 0x00002d00, 0x00000f00,
459 		0x0000b000, 0x00005400, 0x0000bb00, 0x00001600,
460 	}, {
461 		0x00630000, 0x007c0000, 0x00770000, 0x007b0000,
462 		0x00f20000, 0x006b0000, 0x006f0000, 0x00c50000,
463 		0x00300000, 0x00010000, 0x00670000, 0x002b0000,
464 		0x00fe0000, 0x00d70000, 0x00ab0000, 0x00760000,
465 		0x00ca0000, 0x00820000, 0x00c90000, 0x007d0000,
466 		0x00fa0000, 0x00590000, 0x00470000, 0x00f00000,
467 		0x00ad0000, 0x00d40000, 0x00a20000, 0x00af0000,
468 		0x009c0000, 0x00a40000, 0x00720000, 0x00c00000,
469 		0x00b70000, 0x00fd0000, 0x00930000, 0x00260000,
470 		0x00360000, 0x003f0000, 0x00f70000, 0x00cc0000,
471 		0x00340000, 0x00a50000, 0x00e50000, 0x00f10000,
472 		0x00710000, 0x00d80000, 0x00310000, 0x00150000,
473 		0x00040000, 0x00c70000, 0x00230000, 0x00c30000,
474 		0x00180000, 0x00960000, 0x00050000, 0x009a0000,
475 		0x00070000, 0x00120000, 0x00800000, 0x00e20000,
476 		0x00eb0000, 0x00270000, 0x00b20000, 0x00750000,
477 		0x00090000, 0x00830000, 0x002c0000, 0x001a0000,
478 		0x001b0000, 0x006e0000, 0x005a0000, 0x00a00000,
479 		0x00520000, 0x003b0000, 0x00d60000, 0x00b30000,
480 		0x00290000, 0x00e30000, 0x002f0000, 0x00840000,
481 		0x00530000, 0x00d10000, 0x00000000, 0x00ed0000,
482 		0x00200000, 0x00fc0000, 0x00b10000, 0x005b0000,
483 		0x006a0000, 0x00cb0000, 0x00be0000, 0x00390000,
484 		0x004a0000, 0x004c0000, 0x00580000, 0x00cf0000,
485 		0x00d00000, 0x00ef0000, 0x00aa0000, 0x00fb0000,
486 		0x00430000, 0x004d0000, 0x00330000, 0x00850000,
487 		0x00450000, 0x00f90000, 0x00020000, 0x007f0000,
488 		0x00500000, 0x003c0000, 0x009f0000, 0x00a80000,
489 		0x00510000, 0x00a30000, 0x00400000, 0x008f0000,
490 		0x00920000, 0x009d0000, 0x00380000, 0x00f50000,
491 		0x00bc0000, 0x00b60000, 0x00da0000, 0x00210000,
492 		0x00100000, 0x00ff0000, 0x00f30000, 0x00d20000,
493 		0x00cd0000, 0x000c0000, 0x00130000, 0x00ec0000,
494 		0x005f0000, 0x00970000, 0x00440000, 0x00170000,
495 		0x00c40000, 0x00a70000, 0x007e0000, 0x003d0000,
496 		0x00640000, 0x005d0000, 0x00190000, 0x00730000,
497 		0x00600000, 0x00810000, 0x004f0000, 0x00dc0000,
498 		0x00220000, 0x002a0000, 0x00900000, 0x00880000,
499 		0x00460000, 0x00ee0000, 0x00b80000, 0x00140000,
500 		0x00de0000, 0x005e0000, 0x000b0000, 0x00db0000,
501 		0x00e00000, 0x00320000, 0x003a0000, 0x000a0000,
502 		0x00490000, 0x00060000, 0x00240000, 0x005c0000,
503 		0x00c20000, 0x00d30000, 0x00ac0000, 0x00620000,
504 		0x00910000, 0x00950000, 0x00e40000, 0x00790000,
505 		0x00e70000, 0x00c80000, 0x00370000, 0x006d0000,
506 		0x008d0000, 0x00d50000, 0x004e0000, 0x00a90000,
507 		0x006c0000, 0x00560000, 0x00f40000, 0x00ea0000,
508 		0x00650000, 0x007a0000, 0x00ae0000, 0x00080000,
509 		0x00ba0000, 0x00780000, 0x00250000, 0x002e0000,
510 		0x001c0000, 0x00a60000, 0x00b40000, 0x00c60000,
511 		0x00e80000, 0x00dd0000, 0x00740000, 0x001f0000,
512 		0x004b0000, 0x00bd0000, 0x008b0000, 0x008a0000,
513 		0x00700000, 0x003e0000, 0x00b50000, 0x00660000,
514 		0x00480000, 0x00030000, 0x00f60000, 0x000e0000,
515 		0x00610000, 0x00350000, 0x00570000, 0x00b90000,
516 		0x00860000, 0x00c10000, 0x001d0000, 0x009e0000,
517 		0x00e10000, 0x00f80000, 0x00980000, 0x00110000,
518 		0x00690000, 0x00d90000, 0x008e0000, 0x00940000,
519 		0x009b0000, 0x001e0000, 0x00870000, 0x00e90000,
520 		0x00ce0000, 0x00550000, 0x00280000, 0x00df0000,
521 		0x008c0000, 0x00a10000, 0x00890000, 0x000d0000,
522 		0x00bf0000, 0x00e60000, 0x00420000, 0x00680000,
523 		0x00410000, 0x00990000, 0x002d0000, 0x000f0000,
524 		0x00b00000, 0x00540000, 0x00bb0000, 0x00160000,
525 	}, {
526 		0x63000000, 0x7c000000, 0x77000000, 0x7b000000,
527 		0xf2000000, 0x6b000000, 0x6f000000, 0xc5000000,
528 		0x30000000, 0x01000000, 0x67000000, 0x2b000000,
529 		0xfe000000, 0xd7000000, 0xab000000, 0x76000000,
530 		0xca000000, 0x82000000, 0xc9000000, 0x7d000000,
531 		0xfa000000, 0x59000000, 0x47000000, 0xf0000000,
532 		0xad000000, 0xd4000000, 0xa2000000, 0xaf000000,
533 		0x9c000000, 0xa4000000, 0x72000000, 0xc0000000,
534 		0xb7000000, 0xfd000000, 0x93000000, 0x26000000,
535 		0x36000000, 0x3f000000, 0xf7000000, 0xcc000000,
536 		0x34000000, 0xa5000000, 0xe5000000, 0xf1000000,
537 		0x71000000, 0xd8000000, 0x31000000, 0x15000000,
538 		0x04000000, 0xc7000000, 0x23000000, 0xc3000000,
539 		0x18000000, 0x96000000, 0x05000000, 0x9a000000,
540 		0x07000000, 0x12000000, 0x80000000, 0xe2000000,
541 		0xeb000000, 0x27000000, 0xb2000000, 0x75000000,
542 		0x09000000, 0x83000000, 0x2c000000, 0x1a000000,
543 		0x1b000000, 0x6e000000, 0x5a000000, 0xa0000000,
544 		0x52000000, 0x3b000000, 0xd6000000, 0xb3000000,
545 		0x29000000, 0xe3000000, 0x2f000000, 0x84000000,
546 		0x53000000, 0xd1000000, 0x00000000, 0xed000000,
547 		0x20000000, 0xfc000000, 0xb1000000, 0x5b000000,
548 		0x6a000000, 0xcb000000, 0xbe000000, 0x39000000,
549 		0x4a000000, 0x4c000000, 0x58000000, 0xcf000000,
550 		0xd0000000, 0xef000000, 0xaa000000, 0xfb000000,
551 		0x43000000, 0x4d000000, 0x33000000, 0x85000000,
552 		0x45000000, 0xf9000000, 0x02000000, 0x7f000000,
553 		0x50000000, 0x3c000000, 0x9f000000, 0xa8000000,
554 		0x51000000, 0xa3000000, 0x40000000, 0x8f000000,
555 		0x92000000, 0x9d000000, 0x38000000, 0xf5000000,
556 		0xbc000000, 0xb6000000, 0xda000000, 0x21000000,
557 		0x10000000, 0xff000000, 0xf3000000, 0xd2000000,
558 		0xcd000000, 0x0c000000, 0x13000000, 0xec000000,
559 		0x5f000000, 0x97000000, 0x44000000, 0x17000000,
560 		0xc4000000, 0xa7000000, 0x7e000000, 0x3d000000,
561 		0x64000000, 0x5d000000, 0x19000000, 0x73000000,
562 		0x60000000, 0x81000000, 0x4f000000, 0xdc000000,
563 		0x22000000, 0x2a000000, 0x90000000, 0x88000000,
564 		0x46000000, 0xee000000, 0xb8000000, 0x14000000,
565 		0xde000000, 0x5e000000, 0x0b000000, 0xdb000000,
566 		0xe0000000, 0x32000000, 0x3a000000, 0x0a000000,
567 		0x49000000, 0x06000000, 0x24000000, 0x5c000000,
568 		0xc2000000, 0xd3000000, 0xac000000, 0x62000000,
569 		0x91000000, 0x95000000, 0xe4000000, 0x79000000,
570 		0xe7000000, 0xc8000000, 0x37000000, 0x6d000000,
571 		0x8d000000, 0xd5000000, 0x4e000000, 0xa9000000,
572 		0x6c000000, 0x56000000, 0xf4000000, 0xea000000,
573 		0x65000000, 0x7a000000, 0xae000000, 0x08000000,
574 		0xba000000, 0x78000000, 0x25000000, 0x2e000000,
575 		0x1c000000, 0xa6000000, 0xb4000000, 0xc6000000,
576 		0xe8000000, 0xdd000000, 0x74000000, 0x1f000000,
577 		0x4b000000, 0xbd000000, 0x8b000000, 0x8a000000,
578 		0x70000000, 0x3e000000, 0xb5000000, 0x66000000,
579 		0x48000000, 0x03000000, 0xf6000000, 0x0e000000,
580 		0x61000000, 0x35000000, 0x57000000, 0xb9000000,
581 		0x86000000, 0xc1000000, 0x1d000000, 0x9e000000,
582 		0xe1000000, 0xf8000000, 0x98000000, 0x11000000,
583 		0x69000000, 0xd9000000, 0x8e000000, 0x94000000,
584 		0x9b000000, 0x1e000000, 0x87000000, 0xe9000000,
585 		0xce000000, 0x55000000, 0x28000000, 0xdf000000,
586 		0x8c000000, 0xa1000000, 0x89000000, 0x0d000000,
587 		0xbf000000, 0xe6000000, 0x42000000, 0x68000000,
588 		0x41000000, 0x99000000, 0x2d000000, 0x0f000000,
589 		0xb0000000, 0x54000000, 0xbb000000, 0x16000000,
590 	}
591 };
592 
593 __visible const u32 crypto_it_tab[4][256] = {
594 	{
595 		0x50a7f451, 0x5365417e, 0xc3a4171a, 0x965e273a,
596 		0xcb6bab3b, 0xf1459d1f, 0xab58faac, 0x9303e34b,
597 		0x55fa3020, 0xf66d76ad, 0x9176cc88, 0x254c02f5,
598 		0xfcd7e54f, 0xd7cb2ac5, 0x80443526, 0x8fa362b5,
599 		0x495ab1de, 0x671bba25, 0x980eea45, 0xe1c0fe5d,
600 		0x02752fc3, 0x12f04c81, 0xa397468d, 0xc6f9d36b,
601 		0xe75f8f03, 0x959c9215, 0xeb7a6dbf, 0xda595295,
602 		0x2d83bed4, 0xd3217458, 0x2969e049, 0x44c8c98e,
603 		0x6a89c275, 0x78798ef4, 0x6b3e5899, 0xdd71b927,
604 		0xb64fe1be, 0x17ad88f0, 0x66ac20c9, 0xb43ace7d,
605 		0x184adf63, 0x82311ae5, 0x60335197, 0x457f5362,
606 		0xe07764b1, 0x84ae6bbb, 0x1ca081fe, 0x942b08f9,
607 		0x58684870, 0x19fd458f, 0x876cde94, 0xb7f87b52,
608 		0x23d373ab, 0xe2024b72, 0x578f1fe3, 0x2aab5566,
609 		0x0728ebb2, 0x03c2b52f, 0x9a7bc586, 0xa50837d3,
610 		0xf2872830, 0xb2a5bf23, 0xba6a0302, 0x5c8216ed,
611 		0x2b1ccf8a, 0x92b479a7, 0xf0f207f3, 0xa1e2694e,
612 		0xcdf4da65, 0xd5be0506, 0x1f6234d1, 0x8afea6c4,
613 		0x9d532e34, 0xa055f3a2, 0x32e18a05, 0x75ebf6a4,
614 		0x39ec830b, 0xaaef6040, 0x069f715e, 0x51106ebd,
615 		0xf98a213e, 0x3d06dd96, 0xae053edd, 0x46bde64d,
616 		0xb58d5491, 0x055dc471, 0x6fd40604, 0xff155060,
617 		0x24fb9819, 0x97e9bdd6, 0xcc434089, 0x779ed967,
618 		0xbd42e8b0, 0x888b8907, 0x385b19e7, 0xdbeec879,
619 		0x470a7ca1, 0xe90f427c, 0xc91e84f8, 0x00000000,
620 		0x83868009, 0x48ed2b32, 0xac70111e, 0x4e725a6c,
621 		0xfbff0efd, 0x5638850f, 0x1ed5ae3d, 0x27392d36,
622 		0x64d90f0a, 0x21a65c68, 0xd1545b9b, 0x3a2e3624,
623 		0xb1670a0c, 0x0fe75793, 0xd296eeb4, 0x9e919b1b,
624 		0x4fc5c080, 0xa220dc61, 0x694b775a, 0x161a121c,
625 		0x0aba93e2, 0xe52aa0c0, 0x43e0223c, 0x1d171b12,
626 		0x0b0d090e, 0xadc78bf2, 0xb9a8b62d, 0xc8a91e14,
627 		0x8519f157, 0x4c0775af, 0xbbdd99ee, 0xfd607fa3,
628 		0x9f2601f7, 0xbcf5725c, 0xc53b6644, 0x347efb5b,
629 		0x7629438b, 0xdcc623cb, 0x68fcedb6, 0x63f1e4b8,
630 		0xcadc31d7, 0x10856342, 0x40229713, 0x2011c684,
631 		0x7d244a85, 0xf83dbbd2, 0x1132f9ae, 0x6da129c7,
632 		0x4b2f9e1d, 0xf330b2dc, 0xec52860d, 0xd0e3c177,
633 		0x6c16b32b, 0x99b970a9, 0xfa489411, 0x2264e947,
634 		0xc48cfca8, 0x1a3ff0a0, 0xd82c7d56, 0xef903322,
635 		0xc74e4987, 0xc1d138d9, 0xfea2ca8c, 0x360bd498,
636 		0xcf81f5a6, 0x28de7aa5, 0x268eb7da, 0xa4bfad3f,
637 		0xe49d3a2c, 0x0d927850, 0x9bcc5f6a, 0x62467e54,
638 		0xc2138df6, 0xe8b8d890, 0x5ef7392e, 0xf5afc382,
639 		0xbe805d9f, 0x7c93d069, 0xa92dd56f, 0xb31225cf,
640 		0x3b99acc8, 0xa77d1810, 0x6e639ce8, 0x7bbb3bdb,
641 		0x097826cd, 0xf418596e, 0x01b79aec, 0xa89a4f83,
642 		0x656e95e6, 0x7ee6ffaa, 0x08cfbc21, 0xe6e815ef,
643 		0xd99be7ba, 0xce366f4a, 0xd4099fea, 0xd67cb029,
644 		0xafb2a431, 0x31233f2a, 0x3094a5c6, 0xc066a235,
645 		0x37bc4e74, 0xa6ca82fc, 0xb0d090e0, 0x15d8a733,
646 		0x4a9804f1, 0xf7daec41, 0x0e50cd7f, 0x2ff69117,
647 		0x8dd64d76, 0x4db0ef43, 0x544daacc, 0xdf0496e4,
648 		0xe3b5d19e, 0x1b886a4c, 0xb81f2cc1, 0x7f516546,
649 		0x04ea5e9d, 0x5d358c01, 0x737487fa, 0x2e410bfb,
650 		0x5a1d67b3, 0x52d2db92, 0x335610e9, 0x1347d66d,
651 		0x8c61d79a, 0x7a0ca137, 0x8e14f859, 0x893c13eb,
652 		0xee27a9ce, 0x35c961b7, 0xede51ce1, 0x3cb1477a,
653 		0x59dfd29c, 0x3f73f255, 0x79ce1418, 0xbf37c773,
654 		0xeacdf753, 0x5baafd5f, 0x146f3ddf, 0x86db4478,
655 		0x81f3afca, 0x3ec468b9, 0x2c342438, 0x5f40a3c2,
656 		0x72c31d16, 0x0c25e2bc, 0x8b493c28, 0x41950dff,
657 		0x7101a839, 0xdeb30c08, 0x9ce4b4d8, 0x90c15664,
658 		0x6184cb7b, 0x70b632d5, 0x745c6c48, 0x4257b8d0,
659 	}, {
660 		0xa7f45150, 0x65417e53, 0xa4171ac3, 0x5e273a96,
661 		0x6bab3bcb, 0x459d1ff1, 0x58faacab, 0x03e34b93,
662 		0xfa302055, 0x6d76adf6, 0x76cc8891, 0x4c02f525,
663 		0xd7e54ffc, 0xcb2ac5d7, 0x44352680, 0xa362b58f,
664 		0x5ab1de49, 0x1bba2567, 0x0eea4598, 0xc0fe5de1,
665 		0x752fc302, 0xf04c8112, 0x97468da3, 0xf9d36bc6,
666 		0x5f8f03e7, 0x9c921595, 0x7a6dbfeb, 0x595295da,
667 		0x83bed42d, 0x217458d3, 0x69e04929, 0xc8c98e44,
668 		0x89c2756a, 0x798ef478, 0x3e58996b, 0x71b927dd,
669 		0x4fe1beb6, 0xad88f017, 0xac20c966, 0x3ace7db4,
670 		0x4adf6318, 0x311ae582, 0x33519760, 0x7f536245,
671 		0x7764b1e0, 0xae6bbb84, 0xa081fe1c, 0x2b08f994,
672 		0x68487058, 0xfd458f19, 0x6cde9487, 0xf87b52b7,
673 		0xd373ab23, 0x024b72e2, 0x8f1fe357, 0xab55662a,
674 		0x28ebb207, 0xc2b52f03, 0x7bc5869a, 0x0837d3a5,
675 		0x872830f2, 0xa5bf23b2, 0x6a0302ba, 0x8216ed5c,
676 		0x1ccf8a2b, 0xb479a792, 0xf207f3f0, 0xe2694ea1,
677 		0xf4da65cd, 0xbe0506d5, 0x6234d11f, 0xfea6c48a,
678 		0x532e349d, 0x55f3a2a0, 0xe18a0532, 0xebf6a475,
679 		0xec830b39, 0xef6040aa, 0x9f715e06, 0x106ebd51,
680 		0x8a213ef9, 0x06dd963d, 0x053eddae, 0xbde64d46,
681 		0x8d5491b5, 0x5dc47105, 0xd406046f, 0x155060ff,
682 		0xfb981924, 0xe9bdd697, 0x434089cc, 0x9ed96777,
683 		0x42e8b0bd, 0x8b890788, 0x5b19e738, 0xeec879db,
684 		0x0a7ca147, 0x0f427ce9, 0x1e84f8c9, 0x00000000,
685 		0x86800983, 0xed2b3248, 0x70111eac, 0x725a6c4e,
686 		0xff0efdfb, 0x38850f56, 0xd5ae3d1e, 0x392d3627,
687 		0xd90f0a64, 0xa65c6821, 0x545b9bd1, 0x2e36243a,
688 		0x670a0cb1, 0xe757930f, 0x96eeb4d2, 0x919b1b9e,
689 		0xc5c0804f, 0x20dc61a2, 0x4b775a69, 0x1a121c16,
690 		0xba93e20a, 0x2aa0c0e5, 0xe0223c43, 0x171b121d,
691 		0x0d090e0b, 0xc78bf2ad, 0xa8b62db9, 0xa91e14c8,
692 		0x19f15785, 0x0775af4c, 0xdd99eebb, 0x607fa3fd,
693 		0x2601f79f, 0xf5725cbc, 0x3b6644c5, 0x7efb5b34,
694 		0x29438b76, 0xc623cbdc, 0xfcedb668, 0xf1e4b863,
695 		0xdc31d7ca, 0x85634210, 0x22971340, 0x11c68420,
696 		0x244a857d, 0x3dbbd2f8, 0x32f9ae11, 0xa129c76d,
697 		0x2f9e1d4b, 0x30b2dcf3, 0x52860dec, 0xe3c177d0,
698 		0x16b32b6c, 0xb970a999, 0x489411fa, 0x64e94722,
699 		0x8cfca8c4, 0x3ff0a01a, 0x2c7d56d8, 0x903322ef,
700 		0x4e4987c7, 0xd138d9c1, 0xa2ca8cfe, 0x0bd49836,
701 		0x81f5a6cf, 0xde7aa528, 0x8eb7da26, 0xbfad3fa4,
702 		0x9d3a2ce4, 0x9278500d, 0xcc5f6a9b, 0x467e5462,
703 		0x138df6c2, 0xb8d890e8, 0xf7392e5e, 0xafc382f5,
704 		0x805d9fbe, 0x93d0697c, 0x2dd56fa9, 0x1225cfb3,
705 		0x99acc83b, 0x7d1810a7, 0x639ce86e, 0xbb3bdb7b,
706 		0x7826cd09, 0x18596ef4, 0xb79aec01, 0x9a4f83a8,
707 		0x6e95e665, 0xe6ffaa7e, 0xcfbc2108, 0xe815efe6,
708 		0x9be7bad9, 0x366f4ace, 0x099fead4, 0x7cb029d6,
709 		0xb2a431af, 0x233f2a31, 0x94a5c630, 0x66a235c0,
710 		0xbc4e7437, 0xca82fca6, 0xd090e0b0, 0xd8a73315,
711 		0x9804f14a, 0xdaec41f7, 0x50cd7f0e, 0xf691172f,
712 		0xd64d768d, 0xb0ef434d, 0x4daacc54, 0x0496e4df,
713 		0xb5d19ee3, 0x886a4c1b, 0x1f2cc1b8, 0x5165467f,
714 		0xea5e9d04, 0x358c015d, 0x7487fa73, 0x410bfb2e,
715 		0x1d67b35a, 0xd2db9252, 0x5610e933, 0x47d66d13,
716 		0x61d79a8c, 0x0ca1377a, 0x14f8598e, 0x3c13eb89,
717 		0x27a9ceee, 0xc961b735, 0xe51ce1ed, 0xb1477a3c,
718 		0xdfd29c59, 0x73f2553f, 0xce141879, 0x37c773bf,
719 		0xcdf753ea, 0xaafd5f5b, 0x6f3ddf14, 0xdb447886,
720 		0xf3afca81, 0xc468b93e, 0x3424382c, 0x40a3c25f,
721 		0xc31d1672, 0x25e2bc0c, 0x493c288b, 0x950dff41,
722 		0x01a83971, 0xb30c08de, 0xe4b4d89c, 0xc1566490,
723 		0x84cb7b61, 0xb632d570, 0x5c6c4874, 0x57b8d042,
724 	}, {
725 		0xf45150a7, 0x417e5365, 0x171ac3a4, 0x273a965e,
726 		0xab3bcb6b, 0x9d1ff145, 0xfaacab58, 0xe34b9303,
727 		0x302055fa, 0x76adf66d, 0xcc889176, 0x02f5254c,
728 		0xe54ffcd7, 0x2ac5d7cb, 0x35268044, 0x62b58fa3,
729 		0xb1de495a, 0xba25671b, 0xea45980e, 0xfe5de1c0,
730 		0x2fc30275, 0x4c8112f0, 0x468da397, 0xd36bc6f9,
731 		0x8f03e75f, 0x9215959c, 0x6dbfeb7a, 0x5295da59,
732 		0xbed42d83, 0x7458d321, 0xe0492969, 0xc98e44c8,
733 		0xc2756a89, 0x8ef47879, 0x58996b3e, 0xb927dd71,
734 		0xe1beb64f, 0x88f017ad, 0x20c966ac, 0xce7db43a,
735 		0xdf63184a, 0x1ae58231, 0x51976033, 0x5362457f,
736 		0x64b1e077, 0x6bbb84ae, 0x81fe1ca0, 0x08f9942b,
737 		0x48705868, 0x458f19fd, 0xde94876c, 0x7b52b7f8,
738 		0x73ab23d3, 0x4b72e202, 0x1fe3578f, 0x55662aab,
739 		0xebb20728, 0xb52f03c2, 0xc5869a7b, 0x37d3a508,
740 		0x2830f287, 0xbf23b2a5, 0x0302ba6a, 0x16ed5c82,
741 		0xcf8a2b1c, 0x79a792b4, 0x07f3f0f2, 0x694ea1e2,
742 		0xda65cdf4, 0x0506d5be, 0x34d11f62, 0xa6c48afe,
743 		0x2e349d53, 0xf3a2a055, 0x8a0532e1, 0xf6a475eb,
744 		0x830b39ec, 0x6040aaef, 0x715e069f, 0x6ebd5110,
745 		0x213ef98a, 0xdd963d06, 0x3eddae05, 0xe64d46bd,
746 		0x5491b58d, 0xc471055d, 0x06046fd4, 0x5060ff15,
747 		0x981924fb, 0xbdd697e9, 0x4089cc43, 0xd967779e,
748 		0xe8b0bd42, 0x8907888b, 0x19e7385b, 0xc879dbee,
749 		0x7ca1470a, 0x427ce90f, 0x84f8c91e, 0x00000000,
750 		0x80098386, 0x2b3248ed, 0x111eac70, 0x5a6c4e72,
751 		0x0efdfbff, 0x850f5638, 0xae3d1ed5, 0x2d362739,
752 		0x0f0a64d9, 0x5c6821a6, 0x5b9bd154, 0x36243a2e,
753 		0x0a0cb167, 0x57930fe7, 0xeeb4d296, 0x9b1b9e91,
754 		0xc0804fc5, 0xdc61a220, 0x775a694b, 0x121c161a,
755 		0x93e20aba, 0xa0c0e52a, 0x223c43e0, 0x1b121d17,
756 		0x090e0b0d, 0x8bf2adc7, 0xb62db9a8, 0x1e14c8a9,
757 		0xf1578519, 0x75af4c07, 0x99eebbdd, 0x7fa3fd60,
758 		0x01f79f26, 0x725cbcf5, 0x6644c53b, 0xfb5b347e,
759 		0x438b7629, 0x23cbdcc6, 0xedb668fc, 0xe4b863f1,
760 		0x31d7cadc, 0x63421085, 0x97134022, 0xc6842011,
761 		0x4a857d24, 0xbbd2f83d, 0xf9ae1132, 0x29c76da1,
762 		0x9e1d4b2f, 0xb2dcf330, 0x860dec52, 0xc177d0e3,
763 		0xb32b6c16, 0x70a999b9, 0x9411fa48, 0xe9472264,
764 		0xfca8c48c, 0xf0a01a3f, 0x7d56d82c, 0x3322ef90,
765 		0x4987c74e, 0x38d9c1d1, 0xca8cfea2, 0xd498360b,
766 		0xf5a6cf81, 0x7aa528de, 0xb7da268e, 0xad3fa4bf,
767 		0x3a2ce49d, 0x78500d92, 0x5f6a9bcc, 0x7e546246,
768 		0x8df6c213, 0xd890e8b8, 0x392e5ef7, 0xc382f5af,
769 		0x5d9fbe80, 0xd0697c93, 0xd56fa92d, 0x25cfb312,
770 		0xacc83b99, 0x1810a77d, 0x9ce86e63, 0x3bdb7bbb,
771 		0x26cd0978, 0x596ef418, 0x9aec01b7, 0x4f83a89a,
772 		0x95e6656e, 0xffaa7ee6, 0xbc2108cf, 0x15efe6e8,
773 		0xe7bad99b, 0x6f4ace36, 0x9fead409, 0xb029d67c,
774 		0xa431afb2, 0x3f2a3123, 0xa5c63094, 0xa235c066,
775 		0x4e7437bc, 0x82fca6ca, 0x90e0b0d0, 0xa73315d8,
776 		0x04f14a98, 0xec41f7da, 0xcd7f0e50, 0x91172ff6,
777 		0x4d768dd6, 0xef434db0, 0xaacc544d, 0x96e4df04,
778 		0xd19ee3b5, 0x6a4c1b88, 0x2cc1b81f, 0x65467f51,
779 		0x5e9d04ea, 0x8c015d35, 0x87fa7374, 0x0bfb2e41,
780 		0x67b35a1d, 0xdb9252d2, 0x10e93356, 0xd66d1347,
781 		0xd79a8c61, 0xa1377a0c, 0xf8598e14, 0x13eb893c,
782 		0xa9ceee27, 0x61b735c9, 0x1ce1ede5, 0x477a3cb1,
783 		0xd29c59df, 0xf2553f73, 0x141879ce, 0xc773bf37,
784 		0xf753eacd, 0xfd5f5baa, 0x3ddf146f, 0x447886db,
785 		0xafca81f3, 0x68b93ec4, 0x24382c34, 0xa3c25f40,
786 		0x1d1672c3, 0xe2bc0c25, 0x3c288b49, 0x0dff4195,
787 		0xa8397101, 0x0c08deb3, 0xb4d89ce4, 0x566490c1,
788 		0xcb7b6184, 0x32d570b6, 0x6c48745c, 0xb8d04257,
789 	}, {
790 		0x5150a7f4, 0x7e536541, 0x1ac3a417, 0x3a965e27,
791 		0x3bcb6bab, 0x1ff1459d, 0xacab58fa, 0x4b9303e3,
792 		0x2055fa30, 0xadf66d76, 0x889176cc, 0xf5254c02,
793 		0x4ffcd7e5, 0xc5d7cb2a, 0x26804435, 0xb58fa362,
794 		0xde495ab1, 0x25671bba, 0x45980eea, 0x5de1c0fe,
795 		0xc302752f, 0x8112f04c, 0x8da39746, 0x6bc6f9d3,
796 		0x03e75f8f, 0x15959c92, 0xbfeb7a6d, 0x95da5952,
797 		0xd42d83be, 0x58d32174, 0x492969e0, 0x8e44c8c9,
798 		0x756a89c2, 0xf478798e, 0x996b3e58, 0x27dd71b9,
799 		0xbeb64fe1, 0xf017ad88, 0xc966ac20, 0x7db43ace,
800 		0x63184adf, 0xe582311a, 0x97603351, 0x62457f53,
801 		0xb1e07764, 0xbb84ae6b, 0xfe1ca081, 0xf9942b08,
802 		0x70586848, 0x8f19fd45, 0x94876cde, 0x52b7f87b,
803 		0xab23d373, 0x72e2024b, 0xe3578f1f, 0x662aab55,
804 		0xb20728eb, 0x2f03c2b5, 0x869a7bc5, 0xd3a50837,
805 		0x30f28728, 0x23b2a5bf, 0x02ba6a03, 0xed5c8216,
806 		0x8a2b1ccf, 0xa792b479, 0xf3f0f207, 0x4ea1e269,
807 		0x65cdf4da, 0x06d5be05, 0xd11f6234, 0xc48afea6,
808 		0x349d532e, 0xa2a055f3, 0x0532e18a, 0xa475ebf6,
809 		0x0b39ec83, 0x40aaef60, 0x5e069f71, 0xbd51106e,
810 		0x3ef98a21, 0x963d06dd, 0xddae053e, 0x4d46bde6,
811 		0x91b58d54, 0x71055dc4, 0x046fd406, 0x60ff1550,
812 		0x1924fb98, 0xd697e9bd, 0x89cc4340, 0x67779ed9,
813 		0xb0bd42e8, 0x07888b89, 0xe7385b19, 0x79dbeec8,
814 		0xa1470a7c, 0x7ce90f42, 0xf8c91e84, 0x00000000,
815 		0x09838680, 0x3248ed2b, 0x1eac7011, 0x6c4e725a,
816 		0xfdfbff0e, 0x0f563885, 0x3d1ed5ae, 0x3627392d,
817 		0x0a64d90f, 0x6821a65c, 0x9bd1545b, 0x243a2e36,
818 		0x0cb1670a, 0x930fe757, 0xb4d296ee, 0x1b9e919b,
819 		0x804fc5c0, 0x61a220dc, 0x5a694b77, 0x1c161a12,
820 		0xe20aba93, 0xc0e52aa0, 0x3c43e022, 0x121d171b,
821 		0x0e0b0d09, 0xf2adc78b, 0x2db9a8b6, 0x14c8a91e,
822 		0x578519f1, 0xaf4c0775, 0xeebbdd99, 0xa3fd607f,
823 		0xf79f2601, 0x5cbcf572, 0x44c53b66, 0x5b347efb,
824 		0x8b762943, 0xcbdcc623, 0xb668fced, 0xb863f1e4,
825 		0xd7cadc31, 0x42108563, 0x13402297, 0x842011c6,
826 		0x857d244a, 0xd2f83dbb, 0xae1132f9, 0xc76da129,
827 		0x1d4b2f9e, 0xdcf330b2, 0x0dec5286, 0x77d0e3c1,
828 		0x2b6c16b3, 0xa999b970, 0x11fa4894, 0x472264e9,
829 		0xa8c48cfc, 0xa01a3ff0, 0x56d82c7d, 0x22ef9033,
830 		0x87c74e49, 0xd9c1d138, 0x8cfea2ca, 0x98360bd4,
831 		0xa6cf81f5, 0xa528de7a, 0xda268eb7, 0x3fa4bfad,
832 		0x2ce49d3a, 0x500d9278, 0x6a9bcc5f, 0x5462467e,
833 		0xf6c2138d, 0x90e8b8d8, 0x2e5ef739, 0x82f5afc3,
834 		0x9fbe805d, 0x697c93d0, 0x6fa92dd5, 0xcfb31225,
835 		0xc83b99ac, 0x10a77d18, 0xe86e639c, 0xdb7bbb3b,
836 		0xcd097826, 0x6ef41859, 0xec01b79a, 0x83a89a4f,
837 		0xe6656e95, 0xaa7ee6ff, 0x2108cfbc, 0xefe6e815,
838 		0xbad99be7, 0x4ace366f, 0xead4099f, 0x29d67cb0,
839 		0x31afb2a4, 0x2a31233f, 0xc63094a5, 0x35c066a2,
840 		0x7437bc4e, 0xfca6ca82, 0xe0b0d090, 0x3315d8a7,
841 		0xf14a9804, 0x41f7daec, 0x7f0e50cd, 0x172ff691,
842 		0x768dd64d, 0x434db0ef, 0xcc544daa, 0xe4df0496,
843 		0x9ee3b5d1, 0x4c1b886a, 0xc1b81f2c, 0x467f5165,
844 		0x9d04ea5e, 0x015d358c, 0xfa737487, 0xfb2e410b,
845 		0xb35a1d67, 0x9252d2db, 0xe9335610, 0x6d1347d6,
846 		0x9a8c61d7, 0x377a0ca1, 0x598e14f8, 0xeb893c13,
847 		0xceee27a9, 0xb735c961, 0xe1ede51c, 0x7a3cb147,
848 		0x9c59dfd2, 0x553f73f2, 0x1879ce14, 0x73bf37c7,
849 		0x53eacdf7, 0x5f5baafd, 0xdf146f3d, 0x7886db44,
850 		0xca81f3af, 0xb93ec468, 0x382c3424, 0xc25f40a3,
851 		0x1672c31d, 0xbc0c25e2, 0x288b493c, 0xff41950d,
852 		0x397101a8, 0x08deb30c, 0xd89ce4b4, 0x6490c156,
853 		0x7b6184cb, 0xd570b632, 0x48745c6c, 0xd04257b8,
854 	}
855 };
856 
857 __visible const u32 crypto_il_tab[4][256] = {
858 	{
859 		0x00000052, 0x00000009, 0x0000006a, 0x000000d5,
860 		0x00000030, 0x00000036, 0x000000a5, 0x00000038,
861 		0x000000bf, 0x00000040, 0x000000a3, 0x0000009e,
862 		0x00000081, 0x000000f3, 0x000000d7, 0x000000fb,
863 		0x0000007c, 0x000000e3, 0x00000039, 0x00000082,
864 		0x0000009b, 0x0000002f, 0x000000ff, 0x00000087,
865 		0x00000034, 0x0000008e, 0x00000043, 0x00000044,
866 		0x000000c4, 0x000000de, 0x000000e9, 0x000000cb,
867 		0x00000054, 0x0000007b, 0x00000094, 0x00000032,
868 		0x000000a6, 0x000000c2, 0x00000023, 0x0000003d,
869 		0x000000ee, 0x0000004c, 0x00000095, 0x0000000b,
870 		0x00000042, 0x000000fa, 0x000000c3, 0x0000004e,
871 		0x00000008, 0x0000002e, 0x000000a1, 0x00000066,
872 		0x00000028, 0x000000d9, 0x00000024, 0x000000b2,
873 		0x00000076, 0x0000005b, 0x000000a2, 0x00000049,
874 		0x0000006d, 0x0000008b, 0x000000d1, 0x00000025,
875 		0x00000072, 0x000000f8, 0x000000f6, 0x00000064,
876 		0x00000086, 0x00000068, 0x00000098, 0x00000016,
877 		0x000000d4, 0x000000a4, 0x0000005c, 0x000000cc,
878 		0x0000005d, 0x00000065, 0x000000b6, 0x00000092,
879 		0x0000006c, 0x00000070, 0x00000048, 0x00000050,
880 		0x000000fd, 0x000000ed, 0x000000b9, 0x000000da,
881 		0x0000005e, 0x00000015, 0x00000046, 0x00000057,
882 		0x000000a7, 0x0000008d, 0x0000009d, 0x00000084,
883 		0x00000090, 0x000000d8, 0x000000ab, 0x00000000,
884 		0x0000008c, 0x000000bc, 0x000000d3, 0x0000000a,
885 		0x000000f7, 0x000000e4, 0x00000058, 0x00000005,
886 		0x000000b8, 0x000000b3, 0x00000045, 0x00000006,
887 		0x000000d0, 0x0000002c, 0x0000001e, 0x0000008f,
888 		0x000000ca, 0x0000003f, 0x0000000f, 0x00000002,
889 		0x000000c1, 0x000000af, 0x000000bd, 0x00000003,
890 		0x00000001, 0x00000013, 0x0000008a, 0x0000006b,
891 		0x0000003a, 0x00000091, 0x00000011, 0x00000041,
892 		0x0000004f, 0x00000067, 0x000000dc, 0x000000ea,
893 		0x00000097, 0x000000f2, 0x000000cf, 0x000000ce,
894 		0x000000f0, 0x000000b4, 0x000000e6, 0x00000073,
895 		0x00000096, 0x000000ac, 0x00000074, 0x00000022,
896 		0x000000e7, 0x000000ad, 0x00000035, 0x00000085,
897 		0x000000e2, 0x000000f9, 0x00000037, 0x000000e8,
898 		0x0000001c, 0x00000075, 0x000000df, 0x0000006e,
899 		0x00000047, 0x000000f1, 0x0000001a, 0x00000071,
900 		0x0000001d, 0x00000029, 0x000000c5, 0x00000089,
901 		0x0000006f, 0x000000b7, 0x00000062, 0x0000000e,
902 		0x000000aa, 0x00000018, 0x000000be, 0x0000001b,
903 		0x000000fc, 0x00000056, 0x0000003e, 0x0000004b,
904 		0x000000c6, 0x000000d2, 0x00000079, 0x00000020,
905 		0x0000009a, 0x000000db, 0x000000c0, 0x000000fe,
906 		0x00000078, 0x000000cd, 0x0000005a, 0x000000f4,
907 		0x0000001f, 0x000000dd, 0x000000a8, 0x00000033,
908 		0x00000088, 0x00000007, 0x000000c7, 0x00000031,
909 		0x000000b1, 0x00000012, 0x00000010, 0x00000059,
910 		0x00000027, 0x00000080, 0x000000ec, 0x0000005f,
911 		0x00000060, 0x00000051, 0x0000007f, 0x000000a9,
912 		0x00000019, 0x000000b5, 0x0000004a, 0x0000000d,
913 		0x0000002d, 0x000000e5, 0x0000007a, 0x0000009f,
914 		0x00000093, 0x000000c9, 0x0000009c, 0x000000ef,
915 		0x000000a0, 0x000000e0, 0x0000003b, 0x0000004d,
916 		0x000000ae, 0x0000002a, 0x000000f5, 0x000000b0,
917 		0x000000c8, 0x000000eb, 0x000000bb, 0x0000003c,
918 		0x00000083, 0x00000053, 0x00000099, 0x00000061,
919 		0x00000017, 0x0000002b, 0x00000004, 0x0000007e,
920 		0x000000ba, 0x00000077, 0x000000d6, 0x00000026,
921 		0x000000e1, 0x00000069, 0x00000014, 0x00000063,
922 		0x00000055, 0x00000021, 0x0000000c, 0x0000007d,
923 	}, {
924 		0x00005200, 0x00000900, 0x00006a00, 0x0000d500,
925 		0x00003000, 0x00003600, 0x0000a500, 0x00003800,
926 		0x0000bf00, 0x00004000, 0x0000a300, 0x00009e00,
927 		0x00008100, 0x0000f300, 0x0000d700, 0x0000fb00,
928 		0x00007c00, 0x0000e300, 0x00003900, 0x00008200,
929 		0x00009b00, 0x00002f00, 0x0000ff00, 0x00008700,
930 		0x00003400, 0x00008e00, 0x00004300, 0x00004400,
931 		0x0000c400, 0x0000de00, 0x0000e900, 0x0000cb00,
932 		0x00005400, 0x00007b00, 0x00009400, 0x00003200,
933 		0x0000a600, 0x0000c200, 0x00002300, 0x00003d00,
934 		0x0000ee00, 0x00004c00, 0x00009500, 0x00000b00,
935 		0x00004200, 0x0000fa00, 0x0000c300, 0x00004e00,
936 		0x00000800, 0x00002e00, 0x0000a100, 0x00006600,
937 		0x00002800, 0x0000d900, 0x00002400, 0x0000b200,
938 		0x00007600, 0x00005b00, 0x0000a200, 0x00004900,
939 		0x00006d00, 0x00008b00, 0x0000d100, 0x00002500,
940 		0x00007200, 0x0000f800, 0x0000f600, 0x00006400,
941 		0x00008600, 0x00006800, 0x00009800, 0x00001600,
942 		0x0000d400, 0x0000a400, 0x00005c00, 0x0000cc00,
943 		0x00005d00, 0x00006500, 0x0000b600, 0x00009200,
944 		0x00006c00, 0x00007000, 0x00004800, 0x00005000,
945 		0x0000fd00, 0x0000ed00, 0x0000b900, 0x0000da00,
946 		0x00005e00, 0x00001500, 0x00004600, 0x00005700,
947 		0x0000a700, 0x00008d00, 0x00009d00, 0x00008400,
948 		0x00009000, 0x0000d800, 0x0000ab00, 0x00000000,
949 		0x00008c00, 0x0000bc00, 0x0000d300, 0x00000a00,
950 		0x0000f700, 0x0000e400, 0x00005800, 0x00000500,
951 		0x0000b800, 0x0000b300, 0x00004500, 0x00000600,
952 		0x0000d000, 0x00002c00, 0x00001e00, 0x00008f00,
953 		0x0000ca00, 0x00003f00, 0x00000f00, 0x00000200,
954 		0x0000c100, 0x0000af00, 0x0000bd00, 0x00000300,
955 		0x00000100, 0x00001300, 0x00008a00, 0x00006b00,
956 		0x00003a00, 0x00009100, 0x00001100, 0x00004100,
957 		0x00004f00, 0x00006700, 0x0000dc00, 0x0000ea00,
958 		0x00009700, 0x0000f200, 0x0000cf00, 0x0000ce00,
959 		0x0000f000, 0x0000b400, 0x0000e600, 0x00007300,
960 		0x00009600, 0x0000ac00, 0x00007400, 0x00002200,
961 		0x0000e700, 0x0000ad00, 0x00003500, 0x00008500,
962 		0x0000e200, 0x0000f900, 0x00003700, 0x0000e800,
963 		0x00001c00, 0x00007500, 0x0000df00, 0x00006e00,
964 		0x00004700, 0x0000f100, 0x00001a00, 0x00007100,
965 		0x00001d00, 0x00002900, 0x0000c500, 0x00008900,
966 		0x00006f00, 0x0000b700, 0x00006200, 0x00000e00,
967 		0x0000aa00, 0x00001800, 0x0000be00, 0x00001b00,
968 		0x0000fc00, 0x00005600, 0x00003e00, 0x00004b00,
969 		0x0000c600, 0x0000d200, 0x00007900, 0x00002000,
970 		0x00009a00, 0x0000db00, 0x0000c000, 0x0000fe00,
971 		0x00007800, 0x0000cd00, 0x00005a00, 0x0000f400,
972 		0x00001f00, 0x0000dd00, 0x0000a800, 0x00003300,
973 		0x00008800, 0x00000700, 0x0000c700, 0x00003100,
974 		0x0000b100, 0x00001200, 0x00001000, 0x00005900,
975 		0x00002700, 0x00008000, 0x0000ec00, 0x00005f00,
976 		0x00006000, 0x00005100, 0x00007f00, 0x0000a900,
977 		0x00001900, 0x0000b500, 0x00004a00, 0x00000d00,
978 		0x00002d00, 0x0000e500, 0x00007a00, 0x00009f00,
979 		0x00009300, 0x0000c900, 0x00009c00, 0x0000ef00,
980 		0x0000a000, 0x0000e000, 0x00003b00, 0x00004d00,
981 		0x0000ae00, 0x00002a00, 0x0000f500, 0x0000b000,
982 		0x0000c800, 0x0000eb00, 0x0000bb00, 0x00003c00,
983 		0x00008300, 0x00005300, 0x00009900, 0x00006100,
984 		0x00001700, 0x00002b00, 0x00000400, 0x00007e00,
985 		0x0000ba00, 0x00007700, 0x0000d600, 0x00002600,
986 		0x0000e100, 0x00006900, 0x00001400, 0x00006300,
987 		0x00005500, 0x00002100, 0x00000c00, 0x00007d00,
988 	}, {
989 		0x00520000, 0x00090000, 0x006a0000, 0x00d50000,
990 		0x00300000, 0x00360000, 0x00a50000, 0x00380000,
991 		0x00bf0000, 0x00400000, 0x00a30000, 0x009e0000,
992 		0x00810000, 0x00f30000, 0x00d70000, 0x00fb0000,
993 		0x007c0000, 0x00e30000, 0x00390000, 0x00820000,
994 		0x009b0000, 0x002f0000, 0x00ff0000, 0x00870000,
995 		0x00340000, 0x008e0000, 0x00430000, 0x00440000,
996 		0x00c40000, 0x00de0000, 0x00e90000, 0x00cb0000,
997 		0x00540000, 0x007b0000, 0x00940000, 0x00320000,
998 		0x00a60000, 0x00c20000, 0x00230000, 0x003d0000,
999 		0x00ee0000, 0x004c0000, 0x00950000, 0x000b0000,
1000 		0x00420000, 0x00fa0000, 0x00c30000, 0x004e0000,
1001 		0x00080000, 0x002e0000, 0x00a10000, 0x00660000,
1002 		0x00280000, 0x00d90000, 0x00240000, 0x00b20000,
1003 		0x00760000, 0x005b0000, 0x00a20000, 0x00490000,
1004 		0x006d0000, 0x008b0000, 0x00d10000, 0x00250000,
1005 		0x00720000, 0x00f80000, 0x00f60000, 0x00640000,
1006 		0x00860000, 0x00680000, 0x00980000, 0x00160000,
1007 		0x00d40000, 0x00a40000, 0x005c0000, 0x00cc0000,
1008 		0x005d0000, 0x00650000, 0x00b60000, 0x00920000,
1009 		0x006c0000, 0x00700000, 0x00480000, 0x00500000,
1010 		0x00fd0000, 0x00ed0000, 0x00b90000, 0x00da0000,
1011 		0x005e0000, 0x00150000, 0x00460000, 0x00570000,
1012 		0x00a70000, 0x008d0000, 0x009d0000, 0x00840000,
1013 		0x00900000, 0x00d80000, 0x00ab0000, 0x00000000,
1014 		0x008c0000, 0x00bc0000, 0x00d30000, 0x000a0000,
1015 		0x00f70000, 0x00e40000, 0x00580000, 0x00050000,
1016 		0x00b80000, 0x00b30000, 0x00450000, 0x00060000,
1017 		0x00d00000, 0x002c0000, 0x001e0000, 0x008f0000,
1018 		0x00ca0000, 0x003f0000, 0x000f0000, 0x00020000,
1019 		0x00c10000, 0x00af0000, 0x00bd0000, 0x00030000,
1020 		0x00010000, 0x00130000, 0x008a0000, 0x006b0000,
1021 		0x003a0000, 0x00910000, 0x00110000, 0x00410000,
1022 		0x004f0000, 0x00670000, 0x00dc0000, 0x00ea0000,
1023 		0x00970000, 0x00f20000, 0x00cf0000, 0x00ce0000,
1024 		0x00f00000, 0x00b40000, 0x00e60000, 0x00730000,
1025 		0x00960000, 0x00ac0000, 0x00740000, 0x00220000,
1026 		0x00e70000, 0x00ad0000, 0x00350000, 0x00850000,
1027 		0x00e20000, 0x00f90000, 0x00370000, 0x00e80000,
1028 		0x001c0000, 0x00750000, 0x00df0000, 0x006e0000,
1029 		0x00470000, 0x00f10000, 0x001a0000, 0x00710000,
1030 		0x001d0000, 0x00290000, 0x00c50000, 0x00890000,
1031 		0x006f0000, 0x00b70000, 0x00620000, 0x000e0000,
1032 		0x00aa0000, 0x00180000, 0x00be0000, 0x001b0000,
1033 		0x00fc0000, 0x00560000, 0x003e0000, 0x004b0000,
1034 		0x00c60000, 0x00d20000, 0x00790000, 0x00200000,
1035 		0x009a0000, 0x00db0000, 0x00c00000, 0x00fe0000,
1036 		0x00780000, 0x00cd0000, 0x005a0000, 0x00f40000,
1037 		0x001f0000, 0x00dd0000, 0x00a80000, 0x00330000,
1038 		0x00880000, 0x00070000, 0x00c70000, 0x00310000,
1039 		0x00b10000, 0x00120000, 0x00100000, 0x00590000,
1040 		0x00270000, 0x00800000, 0x00ec0000, 0x005f0000,
1041 		0x00600000, 0x00510000, 0x007f0000, 0x00a90000,
1042 		0x00190000, 0x00b50000, 0x004a0000, 0x000d0000,
1043 		0x002d0000, 0x00e50000, 0x007a0000, 0x009f0000,
1044 		0x00930000, 0x00c90000, 0x009c0000, 0x00ef0000,
1045 		0x00a00000, 0x00e00000, 0x003b0000, 0x004d0000,
1046 		0x00ae0000, 0x002a0000, 0x00f50000, 0x00b00000,
1047 		0x00c80000, 0x00eb0000, 0x00bb0000, 0x003c0000,
1048 		0x00830000, 0x00530000, 0x00990000, 0x00610000,
1049 		0x00170000, 0x002b0000, 0x00040000, 0x007e0000,
1050 		0x00ba0000, 0x00770000, 0x00d60000, 0x00260000,
1051 		0x00e10000, 0x00690000, 0x00140000, 0x00630000,
1052 		0x00550000, 0x00210000, 0x000c0000, 0x007d0000,
1053 	}, {
1054 		0x52000000, 0x09000000, 0x6a000000, 0xd5000000,
1055 		0x30000000, 0x36000000, 0xa5000000, 0x38000000,
1056 		0xbf000000, 0x40000000, 0xa3000000, 0x9e000000,
1057 		0x81000000, 0xf3000000, 0xd7000000, 0xfb000000,
1058 		0x7c000000, 0xe3000000, 0x39000000, 0x82000000,
1059 		0x9b000000, 0x2f000000, 0xff000000, 0x87000000,
1060 		0x34000000, 0x8e000000, 0x43000000, 0x44000000,
1061 		0xc4000000, 0xde000000, 0xe9000000, 0xcb000000,
1062 		0x54000000, 0x7b000000, 0x94000000, 0x32000000,
1063 		0xa6000000, 0xc2000000, 0x23000000, 0x3d000000,
1064 		0xee000000, 0x4c000000, 0x95000000, 0x0b000000,
1065 		0x42000000, 0xfa000000, 0xc3000000, 0x4e000000,
1066 		0x08000000, 0x2e000000, 0xa1000000, 0x66000000,
1067 		0x28000000, 0xd9000000, 0x24000000, 0xb2000000,
1068 		0x76000000, 0x5b000000, 0xa2000000, 0x49000000,
1069 		0x6d000000, 0x8b000000, 0xd1000000, 0x25000000,
1070 		0x72000000, 0xf8000000, 0xf6000000, 0x64000000,
1071 		0x86000000, 0x68000000, 0x98000000, 0x16000000,
1072 		0xd4000000, 0xa4000000, 0x5c000000, 0xcc000000,
1073 		0x5d000000, 0x65000000, 0xb6000000, 0x92000000,
1074 		0x6c000000, 0x70000000, 0x48000000, 0x50000000,
1075 		0xfd000000, 0xed000000, 0xb9000000, 0xda000000,
1076 		0x5e000000, 0x15000000, 0x46000000, 0x57000000,
1077 		0xa7000000, 0x8d000000, 0x9d000000, 0x84000000,
1078 		0x90000000, 0xd8000000, 0xab000000, 0x00000000,
1079 		0x8c000000, 0xbc000000, 0xd3000000, 0x0a000000,
1080 		0xf7000000, 0xe4000000, 0x58000000, 0x05000000,
1081 		0xb8000000, 0xb3000000, 0x45000000, 0x06000000,
1082 		0xd0000000, 0x2c000000, 0x1e000000, 0x8f000000,
1083 		0xca000000, 0x3f000000, 0x0f000000, 0x02000000,
1084 		0xc1000000, 0xaf000000, 0xbd000000, 0x03000000,
1085 		0x01000000, 0x13000000, 0x8a000000, 0x6b000000,
1086 		0x3a000000, 0x91000000, 0x11000000, 0x41000000,
1087 		0x4f000000, 0x67000000, 0xdc000000, 0xea000000,
1088 		0x97000000, 0xf2000000, 0xcf000000, 0xce000000,
1089 		0xf0000000, 0xb4000000, 0xe6000000, 0x73000000,
1090 		0x96000000, 0xac000000, 0x74000000, 0x22000000,
1091 		0xe7000000, 0xad000000, 0x35000000, 0x85000000,
1092 		0xe2000000, 0xf9000000, 0x37000000, 0xe8000000,
1093 		0x1c000000, 0x75000000, 0xdf000000, 0x6e000000,
1094 		0x47000000, 0xf1000000, 0x1a000000, 0x71000000,
1095 		0x1d000000, 0x29000000, 0xc5000000, 0x89000000,
1096 		0x6f000000, 0xb7000000, 0x62000000, 0x0e000000,
1097 		0xaa000000, 0x18000000, 0xbe000000, 0x1b000000,
1098 		0xfc000000, 0x56000000, 0x3e000000, 0x4b000000,
1099 		0xc6000000, 0xd2000000, 0x79000000, 0x20000000,
1100 		0x9a000000, 0xdb000000, 0xc0000000, 0xfe000000,
1101 		0x78000000, 0xcd000000, 0x5a000000, 0xf4000000,
1102 		0x1f000000, 0xdd000000, 0xa8000000, 0x33000000,
1103 		0x88000000, 0x07000000, 0xc7000000, 0x31000000,
1104 		0xb1000000, 0x12000000, 0x10000000, 0x59000000,
1105 		0x27000000, 0x80000000, 0xec000000, 0x5f000000,
1106 		0x60000000, 0x51000000, 0x7f000000, 0xa9000000,
1107 		0x19000000, 0xb5000000, 0x4a000000, 0x0d000000,
1108 		0x2d000000, 0xe5000000, 0x7a000000, 0x9f000000,
1109 		0x93000000, 0xc9000000, 0x9c000000, 0xef000000,
1110 		0xa0000000, 0xe0000000, 0x3b000000, 0x4d000000,
1111 		0xae000000, 0x2a000000, 0xf5000000, 0xb0000000,
1112 		0xc8000000, 0xeb000000, 0xbb000000, 0x3c000000,
1113 		0x83000000, 0x53000000, 0x99000000, 0x61000000,
1114 		0x17000000, 0x2b000000, 0x04000000, 0x7e000000,
1115 		0xba000000, 0x77000000, 0xd6000000, 0x26000000,
1116 		0xe1000000, 0x69000000, 0x14000000, 0x63000000,
1117 		0x55000000, 0x21000000, 0x0c000000, 0x7d000000,
1118 	}
1119 };
1120 
1121 EXPORT_SYMBOL_GPL(crypto_ft_tab);
1122 EXPORT_SYMBOL_GPL(crypto_fl_tab);
1123 EXPORT_SYMBOL_GPL(crypto_it_tab);
1124 EXPORT_SYMBOL_GPL(crypto_il_tab);
1125 
1126 /* initialise the key schedule from the user supplied key */
1127 
1128 #define star_x(x) (((x) & 0x7f7f7f7f) << 1) ^ ((((x) & 0x80808080) >> 7) * 0x1b)
1129 
1130 #define imix_col(y, x)	do {		\
1131 	u	= star_x(x);		\
1132 	v	= star_x(u);		\
1133 	w	= star_x(v);		\
1134 	t	= w ^ (x);		\
1135 	(y)	= u ^ v ^ w;		\
1136 	(y)	^= ror32(u ^ t, 8) ^	\
1137 		ror32(v ^ t, 16) ^	\
1138 		ror32(t, 24);		\
1139 } while (0)
1140 
1141 #define ls_box(x)		\
1142 	crypto_fl_tab[0][byte(x, 0)] ^	\
1143 	crypto_fl_tab[1][byte(x, 1)] ^	\
1144 	crypto_fl_tab[2][byte(x, 2)] ^	\
1145 	crypto_fl_tab[3][byte(x, 3)]
1146 
1147 #define loop4(i)	do {		\
1148 	t = ror32(t, 8);		\
1149 	t = ls_box(t) ^ rco_tab[i];	\
1150 	t ^= ctx->key_enc[4 * i];		\
1151 	ctx->key_enc[4 * i + 4] = t;		\
1152 	t ^= ctx->key_enc[4 * i + 1];		\
1153 	ctx->key_enc[4 * i + 5] = t;		\
1154 	t ^= ctx->key_enc[4 * i + 2];		\
1155 	ctx->key_enc[4 * i + 6] = t;		\
1156 	t ^= ctx->key_enc[4 * i + 3];		\
1157 	ctx->key_enc[4 * i + 7] = t;		\
1158 } while (0)
1159 
1160 #define loop6(i)	do {		\
1161 	t = ror32(t, 8);		\
1162 	t = ls_box(t) ^ rco_tab[i];	\
1163 	t ^= ctx->key_enc[6 * i];		\
1164 	ctx->key_enc[6 * i + 6] = t;		\
1165 	t ^= ctx->key_enc[6 * i + 1];		\
1166 	ctx->key_enc[6 * i + 7] = t;		\
1167 	t ^= ctx->key_enc[6 * i + 2];		\
1168 	ctx->key_enc[6 * i + 8] = t;		\
1169 	t ^= ctx->key_enc[6 * i + 3];		\
1170 	ctx->key_enc[6 * i + 9] = t;		\
1171 	t ^= ctx->key_enc[6 * i + 4];		\
1172 	ctx->key_enc[6 * i + 10] = t;		\
1173 	t ^= ctx->key_enc[6 * i + 5];		\
1174 	ctx->key_enc[6 * i + 11] = t;		\
1175 } while (0)
1176 
1177 #define loop8tophalf(i)	do {			\
1178 	t = ror32(t, 8);			\
1179 	t = ls_box(t) ^ rco_tab[i];		\
1180 	t ^= ctx->key_enc[8 * i];			\
1181 	ctx->key_enc[8 * i + 8] = t;			\
1182 	t ^= ctx->key_enc[8 * i + 1];			\
1183 	ctx->key_enc[8 * i + 9] = t;			\
1184 	t ^= ctx->key_enc[8 * i + 2];			\
1185 	ctx->key_enc[8 * i + 10] = t;			\
1186 	t ^= ctx->key_enc[8 * i + 3];			\
1187 	ctx->key_enc[8 * i + 11] = t;			\
1188 } while (0)
1189 
1190 #define loop8(i)	do {				\
1191 	loop8tophalf(i);				\
1192 	t  = ctx->key_enc[8 * i + 4] ^ ls_box(t);	\
1193 	ctx->key_enc[8 * i + 12] = t;			\
1194 	t ^= ctx->key_enc[8 * i + 5];			\
1195 	ctx->key_enc[8 * i + 13] = t;			\
1196 	t ^= ctx->key_enc[8 * i + 6];			\
1197 	ctx->key_enc[8 * i + 14] = t;			\
1198 	t ^= ctx->key_enc[8 * i + 7];			\
1199 	ctx->key_enc[8 * i + 15] = t;			\
1200 } while (0)
1201 
1202 /**
1203  * crypto_aes_expand_key - Expands the AES key as described in FIPS-197
1204  * @ctx:	The location where the computed key will be stored.
1205  * @in_key:	The supplied key.
1206  * @key_len:	The length of the supplied key.
1207  *
1208  * Returns 0 on success. The function fails only if an invalid key size (or
1209  * pointer) is supplied.
1210  * The expanded key size is 240 bytes (max of 14 rounds with a unique 16 bytes
1211  * key schedule plus a 16 bytes key which is used before the first round).
1212  * The decryption key is prepared for the "Equivalent Inverse Cipher" as
1213  * described in FIPS-197. The first slot (16 bytes) of each key (enc or dec) is
1214  * for the initial combination, the second slot for the first round and so on.
1215  */
1216 int crypto_aes_expand_key(struct crypto_aes_ctx *ctx, const u8 *in_key,
1217 		unsigned int key_len)
1218 {
1219 	const __le32 *key = (const __le32 *)in_key;
1220 	u32 i, t, u, v, w, j;
1221 
1222 	if (key_len != AES_KEYSIZE_128 && key_len != AES_KEYSIZE_192 &&
1223 			key_len != AES_KEYSIZE_256)
1224 		return -EINVAL;
1225 
1226 	ctx->key_length = key_len;
1227 
1228 	ctx->key_dec[key_len + 24] = ctx->key_enc[0] = le32_to_cpu(key[0]);
1229 	ctx->key_dec[key_len + 25] = ctx->key_enc[1] = le32_to_cpu(key[1]);
1230 	ctx->key_dec[key_len + 26] = ctx->key_enc[2] = le32_to_cpu(key[2]);
1231 	ctx->key_dec[key_len + 27] = ctx->key_enc[3] = le32_to_cpu(key[3]);
1232 
1233 	switch (key_len) {
1234 	case AES_KEYSIZE_128:
1235 		t = ctx->key_enc[3];
1236 		for (i = 0; i < 10; ++i)
1237 			loop4(i);
1238 		break;
1239 
1240 	case AES_KEYSIZE_192:
1241 		ctx->key_enc[4] = le32_to_cpu(key[4]);
1242 		t = ctx->key_enc[5] = le32_to_cpu(key[5]);
1243 		for (i = 0; i < 8; ++i)
1244 			loop6(i);
1245 		break;
1246 
1247 	case AES_KEYSIZE_256:
1248 		ctx->key_enc[4] = le32_to_cpu(key[4]);
1249 		ctx->key_enc[5] = le32_to_cpu(key[5]);
1250 		ctx->key_enc[6] = le32_to_cpu(key[6]);
1251 		t = ctx->key_enc[7] = le32_to_cpu(key[7]);
1252 		for (i = 0; i < 6; ++i)
1253 			loop8(i);
1254 		loop8tophalf(i);
1255 		break;
1256 	}
1257 
1258 	ctx->key_dec[0] = ctx->key_enc[key_len + 24];
1259 	ctx->key_dec[1] = ctx->key_enc[key_len + 25];
1260 	ctx->key_dec[2] = ctx->key_enc[key_len + 26];
1261 	ctx->key_dec[3] = ctx->key_enc[key_len + 27];
1262 
1263 	for (i = 4; i < key_len + 24; ++i) {
1264 		j = key_len + 24 - (i & ~3) + (i & 3);
1265 		imix_col(ctx->key_dec[j], ctx->key_enc[i]);
1266 	}
1267 	return 0;
1268 }
1269 EXPORT_SYMBOL_GPL(crypto_aes_expand_key);
1270 
1271 /**
1272  * crypto_aes_set_key - Set the AES key.
1273  * @tfm:	The %crypto_tfm that is used in the context.
1274  * @in_key:	The input key.
1275  * @key_len:	The size of the key.
1276  *
1277  * Returns 0 on success, on failure the %CRYPTO_TFM_RES_BAD_KEY_LEN flag in tfm
1278  * is set. The function uses crypto_aes_expand_key() to expand the key.
1279  * &crypto_aes_ctx _must_ be the private data embedded in @tfm which is
1280  * retrieved with crypto_tfm_ctx().
1281  */
1282 int crypto_aes_set_key(struct crypto_tfm *tfm, const u8 *in_key,
1283 		unsigned int key_len)
1284 {
1285 	struct crypto_aes_ctx *ctx = crypto_tfm_ctx(tfm);
1286 	u32 *flags = &tfm->crt_flags;
1287 	int ret;
1288 
1289 	ret = crypto_aes_expand_key(ctx, in_key, key_len);
1290 	if (!ret)
1291 		return 0;
1292 
1293 	*flags |= CRYPTO_TFM_RES_BAD_KEY_LEN;
1294 	return -EINVAL;
1295 }
1296 EXPORT_SYMBOL_GPL(crypto_aes_set_key);
1297 
1298 /* encrypt a block of text */
1299 
1300 #define f_rn(bo, bi, n, k)	do {				\
1301 	bo[n] = crypto_ft_tab[0][byte(bi[n], 0)] ^			\
1302 		crypto_ft_tab[1][byte(bi[(n + 1) & 3], 1)] ^		\
1303 		crypto_ft_tab[2][byte(bi[(n + 2) & 3], 2)] ^		\
1304 		crypto_ft_tab[3][byte(bi[(n + 3) & 3], 3)] ^ *(k + n);	\
1305 } while (0)
1306 
1307 #define f_nround(bo, bi, k)	do {\
1308 	f_rn(bo, bi, 0, k);	\
1309 	f_rn(bo, bi, 1, k);	\
1310 	f_rn(bo, bi, 2, k);	\
1311 	f_rn(bo, bi, 3, k);	\
1312 	k += 4;			\
1313 } while (0)
1314 
1315 #define f_rl(bo, bi, n, k)	do {				\
1316 	bo[n] = crypto_fl_tab[0][byte(bi[n], 0)] ^			\
1317 		crypto_fl_tab[1][byte(bi[(n + 1) & 3], 1)] ^		\
1318 		crypto_fl_tab[2][byte(bi[(n + 2) & 3], 2)] ^		\
1319 		crypto_fl_tab[3][byte(bi[(n + 3) & 3], 3)] ^ *(k + n);	\
1320 } while (0)
1321 
1322 #define f_lround(bo, bi, k)	do {\
1323 	f_rl(bo, bi, 0, k);	\
1324 	f_rl(bo, bi, 1, k);	\
1325 	f_rl(bo, bi, 2, k);	\
1326 	f_rl(bo, bi, 3, k);	\
1327 } while (0)
1328 
1329 static void aes_encrypt(struct crypto_tfm *tfm, u8 *out, const u8 *in)
1330 {
1331 	const struct crypto_aes_ctx *ctx = crypto_tfm_ctx(tfm);
1332 	const __le32 *src = (const __le32 *)in;
1333 	__le32 *dst = (__le32 *)out;
1334 	u32 b0[4], b1[4];
1335 	const u32 *kp = ctx->key_enc + 4;
1336 	const int key_len = ctx->key_length;
1337 
1338 	b0[0] = le32_to_cpu(src[0]) ^ ctx->key_enc[0];
1339 	b0[1] = le32_to_cpu(src[1]) ^ ctx->key_enc[1];
1340 	b0[2] = le32_to_cpu(src[2]) ^ ctx->key_enc[2];
1341 	b0[3] = le32_to_cpu(src[3]) ^ ctx->key_enc[3];
1342 
1343 	if (key_len > 24) {
1344 		f_nround(b1, b0, kp);
1345 		f_nround(b0, b1, kp);
1346 	}
1347 
1348 	if (key_len > 16) {
1349 		f_nround(b1, b0, kp);
1350 		f_nround(b0, b1, kp);
1351 	}
1352 
1353 	f_nround(b1, b0, kp);
1354 	f_nround(b0, b1, kp);
1355 	f_nround(b1, b0, kp);
1356 	f_nround(b0, b1, kp);
1357 	f_nround(b1, b0, kp);
1358 	f_nround(b0, b1, kp);
1359 	f_nround(b1, b0, kp);
1360 	f_nround(b0, b1, kp);
1361 	f_nround(b1, b0, kp);
1362 	f_lround(b0, b1, kp);
1363 
1364 	dst[0] = cpu_to_le32(b0[0]);
1365 	dst[1] = cpu_to_le32(b0[1]);
1366 	dst[2] = cpu_to_le32(b0[2]);
1367 	dst[3] = cpu_to_le32(b0[3]);
1368 }
1369 
1370 /* decrypt a block of text */
1371 
1372 #define i_rn(bo, bi, n, k)	do {				\
1373 	bo[n] = crypto_it_tab[0][byte(bi[n], 0)] ^			\
1374 		crypto_it_tab[1][byte(bi[(n + 3) & 3], 1)] ^		\
1375 		crypto_it_tab[2][byte(bi[(n + 2) & 3], 2)] ^		\
1376 		crypto_it_tab[3][byte(bi[(n + 1) & 3], 3)] ^ *(k + n);	\
1377 } while (0)
1378 
1379 #define i_nround(bo, bi, k)	do {\
1380 	i_rn(bo, bi, 0, k);	\
1381 	i_rn(bo, bi, 1, k);	\
1382 	i_rn(bo, bi, 2, k);	\
1383 	i_rn(bo, bi, 3, k);	\
1384 	k += 4;			\
1385 } while (0)
1386 
1387 #define i_rl(bo, bi, n, k)	do {			\
1388 	bo[n] = crypto_il_tab[0][byte(bi[n], 0)] ^		\
1389 	crypto_il_tab[1][byte(bi[(n + 3) & 3], 1)] ^		\
1390 	crypto_il_tab[2][byte(bi[(n + 2) & 3], 2)] ^		\
1391 	crypto_il_tab[3][byte(bi[(n + 1) & 3], 3)] ^ *(k + n);	\
1392 } while (0)
1393 
1394 #define i_lround(bo, bi, k)	do {\
1395 	i_rl(bo, bi, 0, k);	\
1396 	i_rl(bo, bi, 1, k);	\
1397 	i_rl(bo, bi, 2, k);	\
1398 	i_rl(bo, bi, 3, k);	\
1399 } while (0)
1400 
1401 static void aes_decrypt(struct crypto_tfm *tfm, u8 *out, const u8 *in)
1402 {
1403 	const struct crypto_aes_ctx *ctx = crypto_tfm_ctx(tfm);
1404 	const __le32 *src = (const __le32 *)in;
1405 	__le32 *dst = (__le32 *)out;
1406 	u32 b0[4], b1[4];
1407 	const int key_len = ctx->key_length;
1408 	const u32 *kp = ctx->key_dec + 4;
1409 
1410 	b0[0] = le32_to_cpu(src[0]) ^  ctx->key_dec[0];
1411 	b0[1] = le32_to_cpu(src[1]) ^  ctx->key_dec[1];
1412 	b0[2] = le32_to_cpu(src[2]) ^  ctx->key_dec[2];
1413 	b0[3] = le32_to_cpu(src[3]) ^  ctx->key_dec[3];
1414 
1415 	if (key_len > 24) {
1416 		i_nround(b1, b0, kp);
1417 		i_nround(b0, b1, kp);
1418 	}
1419 
1420 	if (key_len > 16) {
1421 		i_nround(b1, b0, kp);
1422 		i_nround(b0, b1, kp);
1423 	}
1424 
1425 	i_nround(b1, b0, kp);
1426 	i_nround(b0, b1, kp);
1427 	i_nround(b1, b0, kp);
1428 	i_nround(b0, b1, kp);
1429 	i_nround(b1, b0, kp);
1430 	i_nround(b0, b1, kp);
1431 	i_nround(b1, b0, kp);
1432 	i_nround(b0, b1, kp);
1433 	i_nround(b1, b0, kp);
1434 	i_lround(b0, b1, kp);
1435 
1436 	dst[0] = cpu_to_le32(b0[0]);
1437 	dst[1] = cpu_to_le32(b0[1]);
1438 	dst[2] = cpu_to_le32(b0[2]);
1439 	dst[3] = cpu_to_le32(b0[3]);
1440 }
1441 
1442 static struct crypto_alg aes_alg = {
1443 	.cra_name		=	"aes",
1444 	.cra_driver_name	=	"aes-generic",
1445 	.cra_priority		=	100,
1446 	.cra_flags		=	CRYPTO_ALG_TYPE_CIPHER,
1447 	.cra_blocksize		=	AES_BLOCK_SIZE,
1448 	.cra_ctxsize		=	sizeof(struct crypto_aes_ctx),
1449 	.cra_alignmask		=	3,
1450 	.cra_module		=	THIS_MODULE,
1451 	.cra_u			=	{
1452 		.cipher = {
1453 			.cia_min_keysize	=	AES_MIN_KEY_SIZE,
1454 			.cia_max_keysize	=	AES_MAX_KEY_SIZE,
1455 			.cia_setkey		=	crypto_aes_set_key,
1456 			.cia_encrypt		=	aes_encrypt,
1457 			.cia_decrypt		=	aes_decrypt
1458 		}
1459 	}
1460 };
1461 
1462 static int __init aes_init(void)
1463 {
1464 	return crypto_register_alg(&aes_alg);
1465 }
1466 
1467 static void __exit aes_fini(void)
1468 {
1469 	crypto_unregister_alg(&aes_alg);
1470 }
1471 
1472 module_init(aes_init);
1473 module_exit(aes_fini);
1474 
1475 MODULE_DESCRIPTION("Rijndael (AES) Cipher Algorithm");
1476 MODULE_LICENSE("Dual BSD/GPL");
1477 MODULE_ALIAS_CRYPTO("aes");
1478 MODULE_ALIAS_CRYPTO("aes-generic");
1479