Lines Matching +full:0 +full:- +full:9 +full:a +full:- +full:fa +full:- +full:f
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
10 * crypto/aes_generic.c and are designed to be simply accessed by a combination
11 * of rlwimi/lwz instructions with a minimum of table registers (usually only
16 * For the safety-conscious it has to be noted that they might be vulnerable
19 * This is a quite good tradeoff for low power devices (e.g. routers) without
25 #define R(a, b, c, d) \ argument
26 0x##a##b##c##d, 0x##d##a##b##c, 0x##c##d##a##b, 0x##b##c##d##a
32 /* encryption table, same as crypto_ft_tab in crypto/aes-generic.c */
35 .long R(ff, f2, f2, 0d), R(d6, 6b, 6b, bd)
36 .long R(de, 6f, 6f, b1), R(91, c5, c5, 54)
40 .long R(4d, ab, ab, e6), R(ec, 76, 76, 9a)
41 .long R(8f, ca, ca, 45), R(1f, 82, 82, 9d)
42 .long R(89, c9, c9, 40), R(fa, 7d, 7d, 87)
43 .long R(ef, fa, fa, 15), R(b2, 59, 59, eb)
44 .long R(8e, 47, 47, c9), R(fb, f0, f0, 0b)
46 .long R(5f, a2, a2, fd), R(45, af, af, ea)
47 .long R(23, 9c, 9c, bf), R(53, a4, a4, f7)
48 .long R(e4, 72, 72, 96), R(9b, c0, c0, 5b)
50 .long R(3d, 93, 93, ae), R(4c, 26, 26, 6a)
51 .long R(6c, 36, 36, 5a), R(7e, 3f, 3f, 41)
52 .long R(f5, f7, f7, 02), R(83, cc, cc, 4f)
56 .long R(62, 31, 31, 53), R(2a, 15, 15, 3f)
57 .long R(08, 04, 04, 0c), R(95, c7, c7, 52)
58 .long R(46, 23, 23, 65), R(9d, c3, c3, 5e)
60 .long R(0a, 05, 05, 0f), R(2f, 9a, 9a, b5)
61 .long R(0e, 07, 07, 09), R(24, 12, 12, 36)
62 .long R(1b, 80, 80, 9b), R(df, e2, e2, 3d)
64 .long R(7f, b2, b2, cd), R(ea, 75, 75, 9f)
65 .long R(12, 09, 09, 1b), R(1d, 83, 83, 9e)
66 .long R(58, 2c, 2c, 74), R(34, 1a, 1a, 2e)
68 .long R(b4, 5a, 5a, ee), R(5b, a0, a0, fb)
72 .long R(5e, 2f, 2f, 71), R(13, 84, 84, 97)
75 .long R(40, 20, 20, 60), R(e3, fc, fc, 1f)
77 .long R(d4, 6a, 6a, be), R(8d, cb, cb, 46)
79 .long R(94, 4a, 4a, de), R(98, 4c, 4c, d4)
80 .long R(b0, 58, 58, e8), R(85, cf, cf, 4a)
81 .long R(bb, d0, d0, 6b), R(c5, ef, ef, 2a)
82 .long R(4f, aa, aa, e5), R(ed, fb, fb, 16)
83 .long R(86, 43, 43, c5), R(9a, 4d, 4d, d7)
85 .long R(8a, 45, 45, cf), R(e9, f9, f9, 10)
86 .long R(04, 02, 02, 06), R(fe, 7f, 7f, 81)
88 .long R(25, 9f, 9f, ba), R(4b, a8, a8, e3)
90 .long R(80, 40, 40, c0), R(05, 8f, 8f, 8a)
91 .long R(3f, 92, 92, ad), R(21, 9d, 9d, bc)
95 .long R(20, 10, 10, 30), R(e5, ff, ff, 1a)
96 .long R(fd, f3, f3, 0e), R(bf, d2, d2, 6d)
97 .long R(81, cd, cd, 4c), R(18, 0c, 0c, 14)
98 .long R(26, 13, 13, 35), R(c3, ec, ec, 2f)
99 .long R(be, 5f, 5f, e1), R(35, 97, 97, a2)
102 .long R(fc, 7e, 7e, 82), R(7a, 3d, 3d, 47)
106 .long R(9e, 4f, 4f, d1), R(a3, dc, dc, 7f)
107 .long R(44, 22, 22, 66), R(54, 2a, 2a, 7e)
108 .long R(3b, 90, 90, ab), R(0b, 88, 88, 83)
112 .long R(16, 0b, 0b, 1d), R(ad, db, db, 76)
114 .long R(74, 3a, 3a, 4e), R(14, 0a, 0a, 1e)
115 .long R(92, 49, 49, db), R(0c, 06, 06, 0a)
117 .long R(9f, c2, c2, 5d), R(bd, d3, d3, 6e)
124 .long R(9c, 4e, 4e, d2), R(49, a9, a9, e0)
125 .long R(d8, 6c, 6c, b4), R(ac, 56, 56, fa)
127 .long R(ca, 65, 65, af), R(f4, 7a, 7a, 8e)
129 .long R(6f, ba, ba, d5), R(f0, 78, 78, 88)
130 .long R(4a, 25, 25, 6f), R(5c, 2e, 2e, 72)
134 .long R(e8, 74, 74, 9c), R(3e, 1f, 1f, 21)
136 .long R(0d, 8b, 8b, 86), R(0f, 8a, 8a, 85)
140 .long R(f7, f6, f6, 01), R(1c, 0e, 0e, 12)
141 .long R(c2, 61, 61, a3), R(6a, 35, 35, 5f)
144 .long R(3a, 1d, 1d, 27), R(27, 9e, 9e, b9)
149 .long R(2d, 9b, 9b, b6), R(3c, 1e, 1e, 22)
152 .long R(50, 28, 28, 78), R(a5, df, df, 7a)
153 .long R(03, 8c, 8c, 8f), R(59, a1, a1, f8)
154 .long R(09, 89, 89, 80), R(1a, 0d, 0d, 17)
158 .long R(5a, 2d, 2d, 77), R(1e, 0f, 0f, 11)
160 .long R(6d, bb, bb, d6), R(2c, 16, 16, 3a)
163 /* decryption table, same as crypto_it_tab in crypto/aes-generic.c */
165 .long R(1a, 17, a4, c3), R(3a, 27, 5e, 96)
166 .long R(3b, ab, 6b, cb), R(1f, 9d, 45, f1)
167 .long R(ac, fa, 58, ab), R(4b, e3, 03, 93)
168 .long R(20, 30, fa, 55), R(ad, 76, 6d, f6)
170 .long R(4f, e5, d7, fc), R(c5, 2a, cb, d7)
171 .long R(26, 35, 44, 80), R(b5, 62, a3, 8f)
172 .long R(de, b1, 5a, 49), R(25, ba, 1b, 67)
173 .long R(45, ea, 0e, 98), R(5d, fe, c0, e1)
174 .long R(c3, 2f, 75, 02), R(81, 4c, f0, 12)
176 .long R(03, 8f, 5f, e7), R(15, 92, 9c, 95)
177 .long R(bf, 6d, 7a, eb), R(95, 52, 59, da)
180 .long R(75, c2, 89, 6a), R(f4, 8e, 79, 78)
182 .long R(be, e1, 4f, b6), R(f0, 88, ad, 17)
183 .long R(c9, 20, ac, 66), R(7d, ce, 3a, b4)
184 .long R(63, df, 4a, 18), R(e5, 1a, 31, 82)
185 .long R(97, 51, 33, 60), R(62, 53, 7f, 45)
188 .long R(70, 48, 68, 58), R(8f, 45, fd, 19)
191 .long R(e3, 1f, 8f, 57), R(66, 55, ab, 2a)
192 .long R(b2, eb, 28, 07), R(2f, b5, c2, 03)
193 .long R(86, c5, 7b, 9a), R(d3, 37, 08, a5)
195 .long R(02, 03, 6a, ba), R(ed, 16, 82, 5c)
196 .long R(8a, cf, 1c, 2b), R(a7, 79, b4, 92)
199 .long R(d1, 34, 62, 1f), R(c4, a6, fe, 8a)
200 .long R(34, 2e, 53, 9d), R(a2, f3, 55, a0)
201 .long R(05, 8a, e1, 32), R(a4, f6, eb, 75)
202 .long R(0b, 83, ec, 39), R(40, 60, ef, aa)
203 .long R(5e, 71, 9f, 06), R(bd, 6e, 10, 51)
204 .long R(3e, 21, 8a, f9), R(96, dd, 06, 3d)
207 .long R(04, 06, d4, 6f), R(60, 50, 15, ff)
209 .long R(89, 40, 43, cc), R(67, d9, 9e, 77)
212 .long R(a1, 7c, 0a, 47), R(7c, 42, 0f, e9)
215 .long R(1e, 11, 70, ac), R(6c, 5a, 72, 4e)
216 .long R(fd, 0e, ff, fb), R(0f, 85, 38, 56)
218 .long R(0a, 0f, d9, 64), R(68, 5c, a6, 21)
219 .long R(9b, 5b, 54, d1), R(24, 36, 2e, 3a)
220 .long R(0c, 0a, 67, b1), R(93, 57, e7, 0f)
221 .long R(b4, ee, 96, d2), R(1b, 9b, 91, 9e)
222 .long R(80, c0, c5, 4f), R(61, dc, 20, a2)
223 .long R(5a, 77, 4b, 69), R(1c, 12, 1a, 16)
224 .long R(e2, 93, ba, 0a), R(c0, a0, 2a, e5)
226 .long R(0e, 09, 0d, 0b), R(f2, 8b, c7, ad)
229 .long R(ee, 99, dd, bb), R(a3, 7f, 60, fd)
230 .long R(f7, 01, 26, 9f), R(5c, 72, f5, bc)
236 .long R(85, 4a, 24, 7d), R(d2, bb, 3d, f8)
238 .long R(1d, 9e, 2f, 4b), R(dc, b2, 30, f3)
239 .long R(0d, 86, 52, ec), R(77, c1, e3, d0)
241 .long R(11, 94, 48, fa), R(47, e9, 64, 22)
242 .long R(a8, fc, 8c, c4), R(a0, f0, 3f, 1a)
245 .long R(8c, ca, a2, fe), R(98, d4, 0b, 36)
246 .long R(a6, f5, 81, cf), R(a5, 7a, de, 28)
247 .long R(da, b7, 8e, 26), R(3f, ad, bf, a4)
248 .long R(2c, 3a, 9d, e4), R(50, 78, 92, 0d)
249 .long R(6a, 5f, cc, 9b), R(54, 7e, 46, 62)
252 .long R(9f, 5d, 80, be), R(69, d0, 93, 7c)
253 .long R(6f, d5, 2d, a9), R(cf, 25, 12, b3)
255 .long R(e8, 9c, 63, 6e), R(db, 3b, bb, 7b)
257 .long R(ec, 9a, b7, 01), R(83, 4f, 9a, a8)
260 .long R(ba, e7, 9b, d9), R(4a, 6f, 36, ce)
261 .long R(ea, 9f, 09, d4), R(29, b0, 7c, d6)
262 .long R(31, a4, b2, af), R(2a, 3f, 23, 31)
266 .long R(f1, 04, 98, 4a), R(41, ec, da, f7)
267 .long R(7f, cd, 50, 0e), R(17, 91, f6, 2f)
270 .long R(9e, d1, b5, e3), R(4c, 6a, 88, 1b)
271 .long R(c1, 2c, 1f, b8), R(46, 65, 51, 7f)
272 .long R(9d, 5e, ea, 04), R(01, 8c, 35, 5d)
273 .long R(fa, 87, 74, 73), R(fb, 0b, 41, 2e)
274 .long R(b3, 67, 1d, 5a), R(92, db, d2, 52)
276 .long R(9a, d7, 61, 8c), R(37, a1, 0c, 7a)
279 .long R(e1, 1c, e5, ed), R(7a, 47, b1, 3c)
280 .long R(9c, d2, df, 59), R(55, f2, 73, 3f)
282 .long R(53, f7, cd, ea), R(5f, fd, aa, 5b)
283 .long R(df, 3d, 6f, 14), R(78, 44, db, 86)
285 .long R(38, 24, 34, 2c), R(c2, a3, 40, 5f)
286 .long R(16, 1d, c3, 72), R(bc, e2, 25, 0c)
287 .long R(28, 3c, 49, 8b), R(ff, 0d, 95, 41)
288 .long R(39, a8, 01, 71), R(08, 0c, b3, de)
289 .long R(d8, b4, e4, 9c), R(64, 56, c1, 90)
294 /* decryption table, same as crypto_il_tab in crypto/aes-generic.c */
295 .byte 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38
296 .byte 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb
297 .byte 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87
298 .byte 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb
299 .byte 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d
300 .byte 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e
301 .byte 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2
302 .byte 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25
303 .byte 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16
304 .byte 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92
305 .byte 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda
306 .byte 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84
307 .byte 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a
308 .byte 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06
309 .byte 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02
310 .byte 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b
311 .byte 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea
312 .byte 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73
313 .byte 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85
314 .byte 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e
315 .byte 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89
316 .byte 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b
317 .byte 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20
318 .byte 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4
319 .byte 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31
320 .byte 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f
321 .byte 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d
322 .byte 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef
323 .byte 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0
324 .byte 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61
325 .byte 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26
326 .byte 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d