Markus Stockhausen | 0c5f9ae | 2015-02-22 09:59:43 +0100 | [diff] [blame] | 1 | /* |
| 2 | * 4K AES tables for PPC AES implementation |
| 3 | * |
| 4 | * Copyright (c) 2015 Markus Stockhausen <stockhausen@collogia.de> |
| 5 | * |
| 6 | * This program is free software; you can redistribute it and/or modify it |
| 7 | * under the terms of the GNU General Public License as published by the Free |
| 8 | * Software Foundation; either version 2 of the License, or (at your option) |
| 9 | * any later version. |
| 10 | * |
| 11 | */ |
| 12 | |
| 13 | /* |
| 14 | * These big endian AES encryption/decryption tables have been taken from |
| 15 | * crypto/aes_generic.c and are designed to be simply accessed by a combination |
| 16 | * of rlwimi/lwz instructions with a minimum of table registers (usually only |
| 17 | * one required). Thus they are aligned to 4K. The locality of rotated values |
| 18 | * is derived from the reduced offsets that are available in the SPE load |
| 19 | * instructions. E.g. evldw, evlwwsplat, ... |
| 20 | * |
| 21 | * For the safety-conscious it has to be noted that they might be vulnerable |
| 22 | * to cache timing attacks because of their size. Nevertheless in contrast to |
| 23 | * the generic tables they have been reduced from 16KB to 8KB + 256 bytes. |
| 24 | * This is a quite good tradeoff for low power devices (e.g. routers) without |
| 25 | * dedicated encryption hardware where we usually have no multiuser |
| 26 | * environment. |
| 27 | * |
| 28 | */ |
| 29 | |
| 30 | #define R(a, b, c, d) \ |
| 31 | 0x##a##b##c##d, 0x##d##a##b##c, 0x##c##d##a##b, 0x##b##c##d##a |
| 32 | |
| 33 | .data |
| 34 | .align 12 |
| 35 | .globl PPC_AES_4K_ENCTAB |
| 36 | PPC_AES_4K_ENCTAB: |
| 37 | /* encryption table, same as crypto_ft_tab in crypto/aes-generic.c */ |
| 38 | .long R(c6, 63, 63, a5), R(f8, 7c, 7c, 84) |
| 39 | .long R(ee, 77, 77, 99), R(f6, 7b, 7b, 8d) |
| 40 | .long R(ff, f2, f2, 0d), R(d6, 6b, 6b, bd) |
| 41 | .long R(de, 6f, 6f, b1), R(91, c5, c5, 54) |
| 42 | .long R(60, 30, 30, 50), R(02, 01, 01, 03) |
| 43 | .long R(ce, 67, 67, a9), R(56, 2b, 2b, 7d) |
| 44 | .long R(e7, fe, fe, 19), R(b5, d7, d7, 62) |
| 45 | .long R(4d, ab, ab, e6), R(ec, 76, 76, 9a) |
| 46 | .long R(8f, ca, ca, 45), R(1f, 82, 82, 9d) |
| 47 | .long R(89, c9, c9, 40), R(fa, 7d, 7d, 87) |
| 48 | .long R(ef, fa, fa, 15), R(b2, 59, 59, eb) |
| 49 | .long R(8e, 47, 47, c9), R(fb, f0, f0, 0b) |
| 50 | .long R(41, ad, ad, ec), R(b3, d4, d4, 67) |
| 51 | .long R(5f, a2, a2, fd), R(45, af, af, ea) |
| 52 | .long R(23, 9c, 9c, bf), R(53, a4, a4, f7) |
| 53 | .long R(e4, 72, 72, 96), R(9b, c0, c0, 5b) |
| 54 | .long R(75, b7, b7, c2), R(e1, fd, fd, 1c) |
| 55 | .long R(3d, 93, 93, ae), R(4c, 26, 26, 6a) |
| 56 | .long R(6c, 36, 36, 5a), R(7e, 3f, 3f, 41) |
| 57 | .long R(f5, f7, f7, 02), R(83, cc, cc, 4f) |
| 58 | .long R(68, 34, 34, 5c), R(51, a5, a5, f4) |
| 59 | .long R(d1, e5, e5, 34), R(f9, f1, f1, 08) |
| 60 | .long R(e2, 71, 71, 93), R(ab, d8, d8, 73) |
| 61 | .long R(62, 31, 31, 53), R(2a, 15, 15, 3f) |
| 62 | .long R(08, 04, 04, 0c), R(95, c7, c7, 52) |
| 63 | .long R(46, 23, 23, 65), R(9d, c3, c3, 5e) |
| 64 | .long R(30, 18, 18, 28), R(37, 96, 96, a1) |
| 65 | .long R(0a, 05, 05, 0f), R(2f, 9a, 9a, b5) |
| 66 | .long R(0e, 07, 07, 09), R(24, 12, 12, 36) |
| 67 | .long R(1b, 80, 80, 9b), R(df, e2, e2, 3d) |
| 68 | .long R(cd, eb, eb, 26), R(4e, 27, 27, 69) |
| 69 | .long R(7f, b2, b2, cd), R(ea, 75, 75, 9f) |
| 70 | .long R(12, 09, 09, 1b), R(1d, 83, 83, 9e) |
| 71 | .long R(58, 2c, 2c, 74), R(34, 1a, 1a, 2e) |
| 72 | .long R(36, 1b, 1b, 2d), R(dc, 6e, 6e, b2) |
| 73 | .long R(b4, 5a, 5a, ee), R(5b, a0, a0, fb) |
| 74 | .long R(a4, 52, 52, f6), R(76, 3b, 3b, 4d) |
| 75 | .long R(b7, d6, d6, 61), R(7d, b3, b3, ce) |
| 76 | .long R(52, 29, 29, 7b), R(dd, e3, e3, 3e) |
| 77 | .long R(5e, 2f, 2f, 71), R(13, 84, 84, 97) |
| 78 | .long R(a6, 53, 53, f5), R(b9, d1, d1, 68) |
| 79 | .long R(00, 00, 00, 00), R(c1, ed, ed, 2c) |
| 80 | .long R(40, 20, 20, 60), R(e3, fc, fc, 1f) |
| 81 | .long R(79, b1, b1, c8), R(b6, 5b, 5b, ed) |
| 82 | .long R(d4, 6a, 6a, be), R(8d, cb, cb, 46) |
| 83 | .long R(67, be, be, d9), R(72, 39, 39, 4b) |
| 84 | .long R(94, 4a, 4a, de), R(98, 4c, 4c, d4) |
| 85 | .long R(b0, 58, 58, e8), R(85, cf, cf, 4a) |
| 86 | .long R(bb, d0, d0, 6b), R(c5, ef, ef, 2a) |
| 87 | .long R(4f, aa, aa, e5), R(ed, fb, fb, 16) |
| 88 | .long R(86, 43, 43, c5), R(9a, 4d, 4d, d7) |
| 89 | .long R(66, 33, 33, 55), R(11, 85, 85, 94) |
| 90 | .long R(8a, 45, 45, cf), R(e9, f9, f9, 10) |
| 91 | .long R(04, 02, 02, 06), R(fe, 7f, 7f, 81) |
| 92 | .long R(a0, 50, 50, f0), R(78, 3c, 3c, 44) |
| 93 | .long R(25, 9f, 9f, ba), R(4b, a8, a8, e3) |
| 94 | .long R(a2, 51, 51, f3), R(5d, a3, a3, fe) |
| 95 | .long R(80, 40, 40, c0), R(05, 8f, 8f, 8a) |
| 96 | .long R(3f, 92, 92, ad), R(21, 9d, 9d, bc) |
| 97 | .long R(70, 38, 38, 48), R(f1, f5, f5, 04) |
| 98 | .long R(63, bc, bc, df), R(77, b6, b6, c1) |
| 99 | .long R(af, da, da, 75), R(42, 21, 21, 63) |
| 100 | .long R(20, 10, 10, 30), R(e5, ff, ff, 1a) |
| 101 | .long R(fd, f3, f3, 0e), R(bf, d2, d2, 6d) |
| 102 | .long R(81, cd, cd, 4c), R(18, 0c, 0c, 14) |
| 103 | .long R(26, 13, 13, 35), R(c3, ec, ec, 2f) |
| 104 | .long R(be, 5f, 5f, e1), R(35, 97, 97, a2) |
| 105 | .long R(88, 44, 44, cc), R(2e, 17, 17, 39) |
| 106 | .long R(93, c4, c4, 57), R(55, a7, a7, f2) |
| 107 | .long R(fc, 7e, 7e, 82), R(7a, 3d, 3d, 47) |
| 108 | .long R(c8, 64, 64, ac), R(ba, 5d, 5d, e7) |
| 109 | .long R(32, 19, 19, 2b), R(e6, 73, 73, 95) |
| 110 | .long R(c0, 60, 60, a0), R(19, 81, 81, 98) |
| 111 | .long R(9e, 4f, 4f, d1), R(a3, dc, dc, 7f) |
| 112 | .long R(44, 22, 22, 66), R(54, 2a, 2a, 7e) |
| 113 | .long R(3b, 90, 90, ab), R(0b, 88, 88, 83) |
| 114 | .long R(8c, 46, 46, ca), R(c7, ee, ee, 29) |
| 115 | .long R(6b, b8, b8, d3), R(28, 14, 14, 3c) |
| 116 | .long R(a7, de, de, 79), R(bc, 5e, 5e, e2) |
| 117 | .long R(16, 0b, 0b, 1d), R(ad, db, db, 76) |
| 118 | .long R(db, e0, e0, 3b), R(64, 32, 32, 56) |
| 119 | .long R(74, 3a, 3a, 4e), R(14, 0a, 0a, 1e) |
| 120 | .long R(92, 49, 49, db), R(0c, 06, 06, 0a) |
| 121 | .long R(48, 24, 24, 6c), R(b8, 5c, 5c, e4) |
| 122 | .long R(9f, c2, c2, 5d), R(bd, d3, d3, 6e) |
| 123 | .long R(43, ac, ac, ef), R(c4, 62, 62, a6) |
| 124 | .long R(39, 91, 91, a8), R(31, 95, 95, a4) |
| 125 | .long R(d3, e4, e4, 37), R(f2, 79, 79, 8b) |
| 126 | .long R(d5, e7, e7, 32), R(8b, c8, c8, 43) |
| 127 | .long R(6e, 37, 37, 59), R(da, 6d, 6d, b7) |
| 128 | .long R(01, 8d, 8d, 8c), R(b1, d5, d5, 64) |
| 129 | .long R(9c, 4e, 4e, d2), R(49, a9, a9, e0) |
| 130 | .long R(d8, 6c, 6c, b4), R(ac, 56, 56, fa) |
| 131 | .long R(f3, f4, f4, 07), R(cf, ea, ea, 25) |
| 132 | .long R(ca, 65, 65, af), R(f4, 7a, 7a, 8e) |
| 133 | .long R(47, ae, ae, e9), R(10, 08, 08, 18) |
| 134 | .long R(6f, ba, ba, d5), R(f0, 78, 78, 88) |
| 135 | .long R(4a, 25, 25, 6f), R(5c, 2e, 2e, 72) |
| 136 | .long R(38, 1c, 1c, 24), R(57, a6, a6, f1) |
| 137 | .long R(73, b4, b4, c7), R(97, c6, c6, 51) |
| 138 | .long R(cb, e8, e8, 23), R(a1, dd, dd, 7c) |
| 139 | .long R(e8, 74, 74, 9c), R(3e, 1f, 1f, 21) |
| 140 | .long R(96, 4b, 4b, dd), R(61, bd, bd, dc) |
| 141 | .long R(0d, 8b, 8b, 86), R(0f, 8a, 8a, 85) |
| 142 | .long R(e0, 70, 70, 90), R(7c, 3e, 3e, 42) |
| 143 | .long R(71, b5, b5, c4), R(cc, 66, 66, aa) |
| 144 | .long R(90, 48, 48, d8), R(06, 03, 03, 05) |
| 145 | .long R(f7, f6, f6, 01), R(1c, 0e, 0e, 12) |
| 146 | .long R(c2, 61, 61, a3), R(6a, 35, 35, 5f) |
| 147 | .long R(ae, 57, 57, f9), R(69, b9, b9, d0) |
| 148 | .long R(17, 86, 86, 91), R(99, c1, c1, 58) |
| 149 | .long R(3a, 1d, 1d, 27), R(27, 9e, 9e, b9) |
| 150 | .long R(d9, e1, e1, 38), R(eb, f8, f8, 13) |
| 151 | .long R(2b, 98, 98, b3), R(22, 11, 11, 33) |
| 152 | .long R(d2, 69, 69, bb), R(a9, d9, d9, 70) |
| 153 | .long R(07, 8e, 8e, 89), R(33, 94, 94, a7) |
| 154 | .long R(2d, 9b, 9b, b6), R(3c, 1e, 1e, 22) |
| 155 | .long R(15, 87, 87, 92), R(c9, e9, e9, 20) |
| 156 | .long R(87, ce, ce, 49), R(aa, 55, 55, ff) |
| 157 | .long R(50, 28, 28, 78), R(a5, df, df, 7a) |
| 158 | .long R(03, 8c, 8c, 8f), R(59, a1, a1, f8) |
| 159 | .long R(09, 89, 89, 80), R(1a, 0d, 0d, 17) |
| 160 | .long R(65, bf, bf, da), R(d7, e6, e6, 31) |
| 161 | .long R(84, 42, 42, c6), R(d0, 68, 68, b8) |
| 162 | .long R(82, 41, 41, c3), R(29, 99, 99, b0) |
| 163 | .long R(5a, 2d, 2d, 77), R(1e, 0f, 0f, 11) |
| 164 | .long R(7b, b0, b0, cb), R(a8, 54, 54, fc) |
| 165 | .long R(6d, bb, bb, d6), R(2c, 16, 16, 3a) |
| 166 | .globl PPC_AES_4K_DECTAB |
| 167 | PPC_AES_4K_DECTAB: |
| 168 | /* decryption table, same as crypto_it_tab in crypto/aes-generic.c */ |
| 169 | .long R(51, f4, a7, 50), R(7e, 41, 65, 53) |
| 170 | .long R(1a, 17, a4, c3), R(3a, 27, 5e, 96) |
| 171 | .long R(3b, ab, 6b, cb), R(1f, 9d, 45, f1) |
| 172 | .long R(ac, fa, 58, ab), R(4b, e3, 03, 93) |
| 173 | .long R(20, 30, fa, 55), R(ad, 76, 6d, f6) |
| 174 | .long R(88, cc, 76, 91), R(f5, 02, 4c, 25) |
| 175 | .long R(4f, e5, d7, fc), R(c5, 2a, cb, d7) |
| 176 | .long R(26, 35, 44, 80), R(b5, 62, a3, 8f) |
| 177 | .long R(de, b1, 5a, 49), R(25, ba, 1b, 67) |
| 178 | .long R(45, ea, 0e, 98), R(5d, fe, c0, e1) |
| 179 | .long R(c3, 2f, 75, 02), R(81, 4c, f0, 12) |
| 180 | .long R(8d, 46, 97, a3), R(6b, d3, f9, c6) |
| 181 | .long R(03, 8f, 5f, e7), R(15, 92, 9c, 95) |
| 182 | .long R(bf, 6d, 7a, eb), R(95, 52, 59, da) |
| 183 | .long R(d4, be, 83, 2d), R(58, 74, 21, d3) |
| 184 | .long R(49, e0, 69, 29), R(8e, c9, c8, 44) |
| 185 | .long R(75, c2, 89, 6a), R(f4, 8e, 79, 78) |
| 186 | .long R(99, 58, 3e, 6b), R(27, b9, 71, dd) |
| 187 | .long R(be, e1, 4f, b6), R(f0, 88, ad, 17) |
| 188 | .long R(c9, 20, ac, 66), R(7d, ce, 3a, b4) |
| 189 | .long R(63, df, 4a, 18), R(e5, 1a, 31, 82) |
| 190 | .long R(97, 51, 33, 60), R(62, 53, 7f, 45) |
| 191 | .long R(b1, 64, 77, e0), R(bb, 6b, ae, 84) |
| 192 | .long R(fe, 81, a0, 1c), R(f9, 08, 2b, 94) |
| 193 | .long R(70, 48, 68, 58), R(8f, 45, fd, 19) |
| 194 | .long R(94, de, 6c, 87), R(52, 7b, f8, b7) |
| 195 | .long R(ab, 73, d3, 23), R(72, 4b, 02, e2) |
| 196 | .long R(e3, 1f, 8f, 57), R(66, 55, ab, 2a) |
| 197 | .long R(b2, eb, 28, 07), R(2f, b5, c2, 03) |
| 198 | .long R(86, c5, 7b, 9a), R(d3, 37, 08, a5) |
| 199 | .long R(30, 28, 87, f2), R(23, bf, a5, b2) |
| 200 | .long R(02, 03, 6a, ba), R(ed, 16, 82, 5c) |
| 201 | .long R(8a, cf, 1c, 2b), R(a7, 79, b4, 92) |
| 202 | .long R(f3, 07, f2, f0), R(4e, 69, e2, a1) |
| 203 | .long R(65, da, f4, cd), R(06, 05, be, d5) |
| 204 | .long R(d1, 34, 62, 1f), R(c4, a6, fe, 8a) |
| 205 | .long R(34, 2e, 53, 9d), R(a2, f3, 55, a0) |
| 206 | .long R(05, 8a, e1, 32), R(a4, f6, eb, 75) |
| 207 | .long R(0b, 83, ec, 39), R(40, 60, ef, aa) |
| 208 | .long R(5e, 71, 9f, 06), R(bd, 6e, 10, 51) |
| 209 | .long R(3e, 21, 8a, f9), R(96, dd, 06, 3d) |
| 210 | .long R(dd, 3e, 05, ae), R(4d, e6, bd, 46) |
| 211 | .long R(91, 54, 8d, b5), R(71, c4, 5d, 05) |
| 212 | .long R(04, 06, d4, 6f), R(60, 50, 15, ff) |
| 213 | .long R(19, 98, fb, 24), R(d6, bd, e9, 97) |
| 214 | .long R(89, 40, 43, cc), R(67, d9, 9e, 77) |
| 215 | .long R(b0, e8, 42, bd), R(07, 89, 8b, 88) |
| 216 | .long R(e7, 19, 5b, 38), R(79, c8, ee, db) |
| 217 | .long R(a1, 7c, 0a, 47), R(7c, 42, 0f, e9) |
| 218 | .long R(f8, 84, 1e, c9), R(00, 00, 00, 00) |
| 219 | .long R(09, 80, 86, 83), R(32, 2b, ed, 48) |
| 220 | .long R(1e, 11, 70, ac), R(6c, 5a, 72, 4e) |
| 221 | .long R(fd, 0e, ff, fb), R(0f, 85, 38, 56) |
| 222 | .long R(3d, ae, d5, 1e), R(36, 2d, 39, 27) |
| 223 | .long R(0a, 0f, d9, 64), R(68, 5c, a6, 21) |
| 224 | .long R(9b, 5b, 54, d1), R(24, 36, 2e, 3a) |
| 225 | .long R(0c, 0a, 67, b1), R(93, 57, e7, 0f) |
| 226 | .long R(b4, ee, 96, d2), R(1b, 9b, 91, 9e) |
| 227 | .long R(80, c0, c5, 4f), R(61, dc, 20, a2) |
| 228 | .long R(5a, 77, 4b, 69), R(1c, 12, 1a, 16) |
| 229 | .long R(e2, 93, ba, 0a), R(c0, a0, 2a, e5) |
| 230 | .long R(3c, 22, e0, 43), R(12, 1b, 17, 1d) |
| 231 | .long R(0e, 09, 0d, 0b), R(f2, 8b, c7, ad) |
| 232 | .long R(2d, b6, a8, b9), R(14, 1e, a9, c8) |
| 233 | .long R(57, f1, 19, 85), R(af, 75, 07, 4c) |
| 234 | .long R(ee, 99, dd, bb), R(a3, 7f, 60, fd) |
| 235 | .long R(f7, 01, 26, 9f), R(5c, 72, f5, bc) |
| 236 | .long R(44, 66, 3b, c5), R(5b, fb, 7e, 34) |
| 237 | .long R(8b, 43, 29, 76), R(cb, 23, c6, dc) |
| 238 | .long R(b6, ed, fc, 68), R(b8, e4, f1, 63) |
| 239 | .long R(d7, 31, dc, ca), R(42, 63, 85, 10) |
| 240 | .long R(13, 97, 22, 40), R(84, c6, 11, 20) |
| 241 | .long R(85, 4a, 24, 7d), R(d2, bb, 3d, f8) |
| 242 | .long R(ae, f9, 32, 11), R(c7, 29, a1, 6d) |
| 243 | .long R(1d, 9e, 2f, 4b), R(dc, b2, 30, f3) |
| 244 | .long R(0d, 86, 52, ec), R(77, c1, e3, d0) |
| 245 | .long R(2b, b3, 16, 6c), R(a9, 70, b9, 99) |
| 246 | .long R(11, 94, 48, fa), R(47, e9, 64, 22) |
| 247 | .long R(a8, fc, 8c, c4), R(a0, f0, 3f, 1a) |
| 248 | .long R(56, 7d, 2c, d8), R(22, 33, 90, ef) |
| 249 | .long R(87, 49, 4e, c7), R(d9, 38, d1, c1) |
| 250 | .long R(8c, ca, a2, fe), R(98, d4, 0b, 36) |
| 251 | .long R(a6, f5, 81, cf), R(a5, 7a, de, 28) |
| 252 | .long R(da, b7, 8e, 26), R(3f, ad, bf, a4) |
| 253 | .long R(2c, 3a, 9d, e4), R(50, 78, 92, 0d) |
| 254 | .long R(6a, 5f, cc, 9b), R(54, 7e, 46, 62) |
| 255 | .long R(f6, 8d, 13, c2), R(90, d8, b8, e8) |
| 256 | .long R(2e, 39, f7, 5e), R(82, c3, af, f5) |
| 257 | .long R(9f, 5d, 80, be), R(69, d0, 93, 7c) |
| 258 | .long R(6f, d5, 2d, a9), R(cf, 25, 12, b3) |
| 259 | .long R(c8, ac, 99, 3b), R(10, 18, 7d, a7) |
| 260 | .long R(e8, 9c, 63, 6e), R(db, 3b, bb, 7b) |
| 261 | .long R(cd, 26, 78, 09), R(6e, 59, 18, f4) |
| 262 | .long R(ec, 9a, b7, 01), R(83, 4f, 9a, a8) |
| 263 | .long R(e6, 95, 6e, 65), R(aa, ff, e6, 7e) |
| 264 | .long R(21, bc, cf, 08), R(ef, 15, e8, e6) |
| 265 | .long R(ba, e7, 9b, d9), R(4a, 6f, 36, ce) |
| 266 | .long R(ea, 9f, 09, d4), R(29, b0, 7c, d6) |
| 267 | .long R(31, a4, b2, af), R(2a, 3f, 23, 31) |
| 268 | .long R(c6, a5, 94, 30), R(35, a2, 66, c0) |
| 269 | .long R(74, 4e, bc, 37), R(fc, 82, ca, a6) |
| 270 | .long R(e0, 90, d0, b0), R(33, a7, d8, 15) |
| 271 | .long R(f1, 04, 98, 4a), R(41, ec, da, f7) |
| 272 | .long R(7f, cd, 50, 0e), R(17, 91, f6, 2f) |
| 273 | .long R(76, 4d, d6, 8d), R(43, ef, b0, 4d) |
| 274 | .long R(cc, aa, 4d, 54), R(e4, 96, 04, df) |
| 275 | .long R(9e, d1, b5, e3), R(4c, 6a, 88, 1b) |
| 276 | .long R(c1, 2c, 1f, b8), R(46, 65, 51, 7f) |
| 277 | .long R(9d, 5e, ea, 04), R(01, 8c, 35, 5d) |
| 278 | .long R(fa, 87, 74, 73), R(fb, 0b, 41, 2e) |
| 279 | .long R(b3, 67, 1d, 5a), R(92, db, d2, 52) |
| 280 | .long R(e9, 10, 56, 33), R(6d, d6, 47, 13) |
| 281 | .long R(9a, d7, 61, 8c), R(37, a1, 0c, 7a) |
| 282 | .long R(59, f8, 14, 8e), R(eb, 13, 3c, 89) |
| 283 | .long R(ce, a9, 27, ee), R(b7, 61, c9, 35) |
| 284 | .long R(e1, 1c, e5, ed), R(7a, 47, b1, 3c) |
| 285 | .long R(9c, d2, df, 59), R(55, f2, 73, 3f) |
| 286 | .long R(18, 14, ce, 79), R(73, c7, 37, bf) |
| 287 | .long R(53, f7, cd, ea), R(5f, fd, aa, 5b) |
| 288 | .long R(df, 3d, 6f, 14), R(78, 44, db, 86) |
| 289 | .long R(ca, af, f3, 81), R(b9, 68, c4, 3e) |
| 290 | .long R(38, 24, 34, 2c), R(c2, a3, 40, 5f) |
| 291 | .long R(16, 1d, c3, 72), R(bc, e2, 25, 0c) |
| 292 | .long R(28, 3c, 49, 8b), R(ff, 0d, 95, 41) |
| 293 | .long R(39, a8, 01, 71), R(08, 0c, b3, de) |
| 294 | .long R(d8, b4, e4, 9c), R(64, 56, c1, 90) |
| 295 | .long R(7b, cb, 84, 61), R(d5, 32, b6, 70) |
| 296 | .long R(48, 6c, 5c, 74), R(d0, b8, 57, 42) |
| 297 | .globl PPC_AES_4K_DECTAB2 |
| 298 | PPC_AES_4K_DECTAB2: |
| 299 | /* decryption table, same as crypto_il_tab in crypto/aes-generic.c */ |
| 300 | .byte 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38 |
| 301 | .byte 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb |
| 302 | .byte 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87 |
| 303 | .byte 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb |
| 304 | .byte 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d |
| 305 | .byte 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e |
| 306 | .byte 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2 |
| 307 | .byte 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25 |
| 308 | .byte 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16 |
| 309 | .byte 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92 |
| 310 | .byte 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda |
| 311 | .byte 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84 |
| 312 | .byte 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a |
| 313 | .byte 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06 |
| 314 | .byte 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02 |
| 315 | .byte 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b |
| 316 | .byte 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea |
| 317 | .byte 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73 |
| 318 | .byte 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85 |
| 319 | .byte 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e |
| 320 | .byte 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89 |
| 321 | .byte 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b |
| 322 | .byte 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20 |
| 323 | .byte 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4 |
| 324 | .byte 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31 |
| 325 | .byte 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f |
| 326 | .byte 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d |
| 327 | .byte 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef |
| 328 | .byte 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0 |
| 329 | .byte 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61 |
| 330 | .byte 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26 |
| 331 | .byte 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d |