aes-tab-4k.S 14 KB

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