sleeping_kangaroo12 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (284) hide show
  1. checksums.yaml +7 -0
  2. data/README.md +127 -0
  3. data/ext/Rakefile +73 -0
  4. data/ext/binding/sleeping_kangaroo12.c +39 -0
  5. data/ext/config/xkcp.build +17 -0
  6. data/ext/xkcp/LICENSE +1 -0
  7. data/ext/xkcp/Makefile +15 -0
  8. data/ext/xkcp/Makefile.build +200 -0
  9. data/ext/xkcp/README.markdown +296 -0
  10. data/ext/xkcp/lib/HighLevel.build +143 -0
  11. data/ext/xkcp/lib/LowLevel.build +757 -0
  12. data/ext/xkcp/lib/common/align.h +33 -0
  13. data/ext/xkcp/lib/common/brg_endian.h +143 -0
  14. data/ext/xkcp/lib/high/KangarooTwelve/KangarooTwelve.c +301 -0
  15. data/ext/xkcp/lib/high/KangarooTwelve/KangarooTwelve.h +97 -0
  16. data/ext/xkcp/lib/high/Keccak/FIPS202/KeccakHash.c +81 -0
  17. data/ext/xkcp/lib/high/Keccak/FIPS202/KeccakHash.h +125 -0
  18. data/ext/xkcp/lib/high/Keccak/FIPS202/SimpleFIPS202.c +48 -0
  19. data/ext/xkcp/lib/high/Keccak/FIPS202/SimpleFIPS202.h +79 -0
  20. data/ext/xkcp/lib/high/Keccak/KeccakDuplex.c +81 -0
  21. data/ext/xkcp/lib/high/Keccak/KeccakDuplex.h +73 -0
  22. data/ext/xkcp/lib/high/Keccak/KeccakDuplex.inc +195 -0
  23. data/ext/xkcp/lib/high/Keccak/KeccakSponge.c +111 -0
  24. data/ext/xkcp/lib/high/Keccak/KeccakSponge.h +76 -0
  25. data/ext/xkcp/lib/high/Keccak/KeccakSponge.inc +314 -0
  26. data/ext/xkcp/lib/high/Keccak/PRG/KeccakPRG.c +61 -0
  27. data/ext/xkcp/lib/high/Keccak/PRG/KeccakPRG.h +67 -0
  28. data/ext/xkcp/lib/high/Keccak/PRG/KeccakPRG.inc +128 -0
  29. data/ext/xkcp/lib/high/Keccak/SP800-185/SP800-185.c +93 -0
  30. data/ext/xkcp/lib/high/Keccak/SP800-185/SP800-185.h +599 -0
  31. data/ext/xkcp/lib/high/Keccak/SP800-185/SP800-185.inc +573 -0
  32. data/ext/xkcp/lib/high/Ketje/Ketjev2.c +87 -0
  33. data/ext/xkcp/lib/high/Ketje/Ketjev2.h +88 -0
  34. data/ext/xkcp/lib/high/Ketje/Ketjev2.inc +274 -0
  35. data/ext/xkcp/lib/high/Keyak/Keyakv2.c +132 -0
  36. data/ext/xkcp/lib/high/Keyak/Keyakv2.h +217 -0
  37. data/ext/xkcp/lib/high/Keyak/Keyakv2.inc +81 -0
  38. data/ext/xkcp/lib/high/Keyak/Motorist.inc +953 -0
  39. data/ext/xkcp/lib/high/Kravatte/Kravatte.c +533 -0
  40. data/ext/xkcp/lib/high/Kravatte/Kravatte.h +115 -0
  41. data/ext/xkcp/lib/high/Kravatte/KravatteModes.c +557 -0
  42. data/ext/xkcp/lib/high/Kravatte/KravatteModes.h +247 -0
  43. data/ext/xkcp/lib/high/Xoodyak/Cyclist.h +66 -0
  44. data/ext/xkcp/lib/high/Xoodyak/Cyclist.inc +336 -0
  45. data/ext/xkcp/lib/high/Xoodyak/Xoodyak-parameters.h +26 -0
  46. data/ext/xkcp/lib/high/Xoodyak/Xoodyak.c +55 -0
  47. data/ext/xkcp/lib/high/Xoodyak/Xoodyak.h +35 -0
  48. data/ext/xkcp/lib/high/Xoofff/Xoofff.c +634 -0
  49. data/ext/xkcp/lib/high/Xoofff/Xoofff.h +147 -0
  50. data/ext/xkcp/lib/high/Xoofff/XoofffModes.c +483 -0
  51. data/ext/xkcp/lib/high/Xoofff/XoofffModes.h +241 -0
  52. data/ext/xkcp/lib/high/common/Phases.h +25 -0
  53. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-SnP.h +41 -0
  54. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv6m-le-armcc.s +1666 -0
  55. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv6m-le-gcc.s +1655 -0
  56. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv7a-le-armcc.s +1268 -0
  57. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv7a-le-gcc.s +1264 -0
  58. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv7m-le-armcc.s +1178 -0
  59. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv7m-le-gcc.s +1175 -0
  60. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-u1-32bi-armv6m-le-armcc.s +1338 -0
  61. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-u1-32bi-armv6m-le-gcc.s +1336 -0
  62. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-u2-32bi-armv6m-le-armcc.s +1343 -0
  63. data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-u2-32bi-armv6m-le-gcc.s +1339 -0
  64. data/ext/xkcp/lib/low/KeccakP-1600/ARMv7A-NEON/KeccakP-1600-SnP.h +42 -0
  65. data/ext/xkcp/lib/low/KeccakP-1600/ARMv7A-NEON/KeccakP-1600-armv7a-le-neon-armcc.s +823 -0
  66. data/ext/xkcp/lib/low/KeccakP-1600/ARMv7A-NEON/KeccakP-1600-armv7a-le-neon-gcc.s +831 -0
  67. data/ext/xkcp/lib/low/KeccakP-1600/ARMv8A/KeccakP-1600-SnP.h +31 -0
  68. data/ext/xkcp/lib/low/KeccakP-1600/ARMv8A/KeccakP-1600-armv8a-neon.s +540 -0
  69. data/ext/xkcp/lib/low/KeccakP-1600/AVR8/KeccakP-1600-SnP.h +42 -0
  70. data/ext/xkcp/lib/low/KeccakP-1600/AVR8/KeccakP-1600-avr8-compact.s +733 -0
  71. data/ext/xkcp/lib/low/KeccakP-1600/AVR8/KeccakP-1600-avr8-fast.s +1121 -0
  72. data/ext/xkcp/lib/low/KeccakP-1600/AVX2/KeccakP-1600-AVX2.s +1100 -0
  73. data/ext/xkcp/lib/low/KeccakP-1600/AVX2/KeccakP-1600-SnP.h +52 -0
  74. data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/KeccakP-1600-AVX512.c +623 -0
  75. data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/KeccakP-1600-SnP.h +47 -0
  76. data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/u12/KeccakP-1600-AVX512-config.h +6 -0
  77. data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/u6/KeccakP-1600-AVX512-config.h +6 -0
  78. data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/ua/KeccakP-1600-AVX512-config.h +6 -0
  79. data/ext/xkcp/lib/low/KeccakP-1600/AVX512/KeccakP-1600-AVX512.s +1031 -0
  80. data/ext/xkcp/lib/low/KeccakP-1600/AVX512/KeccakP-1600-SnP.h +53 -0
  81. data/ext/xkcp/lib/low/KeccakP-1600/XOP/KeccakP-1600-SnP.h +44 -0
  82. data/ext/xkcp/lib/low/KeccakP-1600/XOP/KeccakP-1600-XOP.c +476 -0
  83. data/ext/xkcp/lib/low/KeccakP-1600/XOP/u6/KeccakP-1600-XOP-config.h +6 -0
  84. data/ext/xkcp/lib/low/KeccakP-1600/XOP/ua/KeccakP-1600-XOP-config.h +6 -0
  85. data/ext/xkcp/lib/low/KeccakP-1600/common/KeccakP-1600-64.macros +748 -0
  86. data/ext/xkcp/lib/low/KeccakP-1600/common/KeccakP-1600-unrolling.macros +305 -0
  87. data/ext/xkcp/lib/low/KeccakP-1600/compact/KeccakP-1600-SnP.h +40 -0
  88. data/ext/xkcp/lib/low/KeccakP-1600/compact/KeccakP-1600-compact64.c +420 -0
  89. data/ext/xkcp/lib/low/KeccakP-1600/plain-32bits-inplace/KeccakP-1600-SnP.h +43 -0
  90. data/ext/xkcp/lib/low/KeccakP-1600/plain-32bits-inplace/KeccakP-1600-inplace32BI.c +1163 -0
  91. data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/KeccakP-1600-SnP.h +54 -0
  92. data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/KeccakP-1600-opt64.c +565 -0
  93. data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/lcu6/KeccakP-1600-opt64-config.h +7 -0
  94. data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/lcua/KeccakP-1600-opt64-config.h +7 -0
  95. data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/lcua-shld/KeccakP-1600-opt64-config.h +8 -0
  96. data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/u6/KeccakP-1600-opt64-config.h +6 -0
  97. data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/ua/KeccakP-1600-opt64-config.h +6 -0
  98. data/ext/xkcp/lib/low/KeccakP-1600/ref-32bits/KeccakP-1600-SnP.h +44 -0
  99. data/ext/xkcp/lib/low/KeccakP-1600/ref-32bits/KeccakP-1600-reference.h +23 -0
  100. data/ext/xkcp/lib/low/KeccakP-1600/ref-32bits/KeccakP-1600-reference32BI.c +625 -0
  101. data/ext/xkcp/lib/low/KeccakP-1600/ref-64bits/KeccakP-1600-SnP.h +44 -0
  102. data/ext/xkcp/lib/low/KeccakP-1600/ref-64bits/KeccakP-1600-reference.c +440 -0
  103. data/ext/xkcp/lib/low/KeccakP-1600/ref-64bits/KeccakP-1600-reference.h +23 -0
  104. data/ext/xkcp/lib/low/KeccakP-1600/x86-64/KeccakP-1600-SnP.h +42 -0
  105. data/ext/xkcp/lib/low/KeccakP-1600/x86-64/KeccakP-1600-x86-64-gas.s +1196 -0
  106. data/ext/xkcp/lib/low/KeccakP-1600/x86-64/KeccakP-1600-x86-64-gas_Apple.s +1124 -0
  107. data/ext/xkcp/lib/low/KeccakP-1600/x86-64/KeccakP-1600-x86-64-shld-gas.s +1196 -0
  108. data/ext/xkcp/lib/low/KeccakP-1600-times2/ARMv7A-NEON/KeccakP-1600-inplace-pl2-armv7a-neon-le-armcc.s +1392 -0
  109. data/ext/xkcp/lib/low/KeccakP-1600-times2/ARMv7A-NEON/KeccakP-1600-inplace-pl2-armv7a-neon-le-gcc.s +1394 -0
  110. data/ext/xkcp/lib/low/KeccakP-1600-times2/ARMv7A-NEON/KeccakP-1600-times2-SnP.h +42 -0
  111. data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/AVX512u12/SIMD512-2-config.h +7 -0
  112. data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/AVX512u4/SIMD512-2-config.h +7 -0
  113. data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/AVX512ufull/SIMD512-2-config.h +7 -0
  114. data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/KeccakP-1600-times2-SIMD512.c +850 -0
  115. data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/KeccakP-1600-times2-SnP.h +51 -0
  116. data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/KeccakP-1600-times2-SIMD128.c +957 -0
  117. data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/KeccakP-1600-times2-SnP.h +49 -0
  118. data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/SSSE3-u2/SIMD128-config.h +8 -0
  119. data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/SSSE3-ua/SIMD128-config.h +8 -0
  120. data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/XOP-u2/SIMD128-config.h +9 -0
  121. data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/XOP-ua/SIMD128-config.h +9 -0
  122. data/ext/xkcp/lib/low/KeccakP-1600-times2/fallback-on1/KeccakP-1600-times2-SnP.h +45 -0
  123. data/ext/xkcp/lib/low/KeccakP-1600-times2/fallback-on1/KeccakP-1600-times2-on1.c +37 -0
  124. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/KeccakP-1600-times4-SIMD256.c +1321 -0
  125. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/KeccakP-1600-times4-SnP.h +55 -0
  126. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/u12/SIMD256-config.h +7 -0
  127. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/u6/SIMD256-config.h +7 -0
  128. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/ua/SIMD256-config.h +7 -0
  129. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/AVX512u12/SIMD512-4-config.h +7 -0
  130. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/AVX512u4/SIMD512-4-config.h +7 -0
  131. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/AVX512ufull/SIMD512-4-config.h +7 -0
  132. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/KeccakP-1600-times4-SIMD512.c +881 -0
  133. data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/KeccakP-1600-times4-SnP.h +51 -0
  134. data/ext/xkcp/lib/low/KeccakP-1600-times4/fallback-on1/KeccakP-1600-times4-SnP.h +45 -0
  135. data/ext/xkcp/lib/low/KeccakP-1600-times4/fallback-on1/KeccakP-1600-times4-on1.c +37 -0
  136. data/ext/xkcp/lib/low/KeccakP-1600-times4/fallback-on2/KeccakP-1600-times4-SnP.h +45 -0
  137. data/ext/xkcp/lib/low/KeccakP-1600-times4/fallback-on2/KeccakP-1600-times4-on2.c +38 -0
  138. data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/KeccakP-1600-times8-SIMD512.c +1615 -0
  139. data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/KeccakP-1600-times8-SnP.h +57 -0
  140. data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/u12/SIMD512-config.h +7 -0
  141. data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/u4/SIMD512-config.h +7 -0
  142. data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/ua/SIMD512-config.h +7 -0
  143. data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on1/KeccakP-1600-times8-SnP.h +45 -0
  144. data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on1/KeccakP-1600-times8-on1.c +37 -0
  145. data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on2/KeccakP-1600-times8-SnP.h +45 -0
  146. data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on2/KeccakP-1600-times8-on2.c +38 -0
  147. data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on4/KeccakP-1600-times8-SnP.h +45 -0
  148. data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on4/KeccakP-1600-times8-on4.c +38 -0
  149. data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-SnP.h +41 -0
  150. data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-armv6m-le-armcc.s +442 -0
  151. data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-armv6m-le-gcc.s +446 -0
  152. data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-armv7m-le-armcc.s +419 -0
  153. data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-armv7m-le-gcc.s +427 -0
  154. data/ext/xkcp/lib/low/KeccakP-200/AVR8/KeccakP-200-SnP.h +41 -0
  155. data/ext/xkcp/lib/low/KeccakP-200/AVR8/KeccakP-200-avr8-fast.s +647 -0
  156. data/ext/xkcp/lib/low/KeccakP-200/compact/KeccakP-200-SnP.h +39 -0
  157. data/ext/xkcp/lib/low/KeccakP-200/compact/KeccakP-200-compact.c +190 -0
  158. data/ext/xkcp/lib/low/KeccakP-200/ref/KeccakP-200-SnP.h +43 -0
  159. data/ext/xkcp/lib/low/KeccakP-200/ref/KeccakP-200-reference.c +412 -0
  160. data/ext/xkcp/lib/low/KeccakP-200/ref/KeccakP-200-reference.h +23 -0
  161. data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-SnP.h +41 -0
  162. data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-armv6m-le-armcc.s +454 -0
  163. data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-armv6m-le-gcc.s +458 -0
  164. data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-armv7m-le-armcc.s +455 -0
  165. data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-armv7m-le-gcc.s +458 -0
  166. data/ext/xkcp/lib/low/KeccakP-400/AVR8/KeccakP-400-SnP.h +41 -0
  167. data/ext/xkcp/lib/low/KeccakP-400/AVR8/KeccakP-400-avr8-fast.s +728 -0
  168. data/ext/xkcp/lib/low/KeccakP-400/ref/KeccakP-400-SnP.h +43 -0
  169. data/ext/xkcp/lib/low/KeccakP-400/ref/KeccakP-400-reference.c +414 -0
  170. data/ext/xkcp/lib/low/KeccakP-400/ref/KeccakP-400-reference.h +23 -0
  171. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-SnP.h +42 -0
  172. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u1-armv6m-le-armcc.s +527 -0
  173. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u1-armv6m-le-gcc.s +533 -0
  174. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv6m-le-armcc.s +528 -0
  175. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv6m-le-gcc.s +534 -0
  176. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv7a-le-armcc.s +521 -0
  177. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv7a-le-gcc.s +527 -0
  178. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv7m-le-armcc.s +517 -0
  179. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv7m-le-gcc.s +523 -0
  180. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-uf-armv7m-le-armcc.s +550 -0
  181. data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-uf-armv7m-le-gcc.s +556 -0
  182. data/ext/xkcp/lib/low/KeccakP-800/ARMv8A/KeccakP-800-SnP.h +32 -0
  183. data/ext/xkcp/lib/low/KeccakP-800/ARMv8A/KeccakP-800-armv8a-neon.s +432 -0
  184. data/ext/xkcp/lib/low/KeccakP-800/AVR8/KeccakP-800-SnP.h +42 -0
  185. data/ext/xkcp/lib/low/KeccakP-800/AVR8/KeccakP-800-avr8-fast.s +929 -0
  186. data/ext/xkcp/lib/low/KeccakP-800/compact/KeccakP-800-SnP.h +40 -0
  187. data/ext/xkcp/lib/low/KeccakP-800/compact/KeccakP-800-compact.c +244 -0
  188. data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-SnP.h +46 -0
  189. data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-opt32-bis.macros +184 -0
  190. data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-opt32.c +454 -0
  191. data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-opt32.macros +459 -0
  192. data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-unrolling-bis.macros +83 -0
  193. data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-unrolling.macros +88 -0
  194. data/ext/xkcp/lib/low/KeccakP-800/plain/lcu2/KeccakP-800-opt32-config.h +7 -0
  195. data/ext/xkcp/lib/low/KeccakP-800/plain/lcua/KeccakP-800-opt32-config.h +7 -0
  196. data/ext/xkcp/lib/low/KeccakP-800/plain/u2/KeccakP-800-opt32-config.h +7 -0
  197. data/ext/xkcp/lib/low/KeccakP-800/plain/ua/KeccakP-800-opt32-config.h +7 -0
  198. data/ext/xkcp/lib/low/KeccakP-800/ref/KeccakP-800-SnP.h +44 -0
  199. data/ext/xkcp/lib/low/KeccakP-800/ref/KeccakP-800-reference.c +437 -0
  200. data/ext/xkcp/lib/low/KeccakP-800/ref/KeccakP-800-reference.h +23 -0
  201. data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/Ket.h +57 -0
  202. data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/KetjeJr-armv7m-le-armcc.s +475 -0
  203. data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/KetjeJr-armv7m-le-gcc.s +480 -0
  204. data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/KetjeSr-armv7m-le-armcc.s +590 -0
  205. data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/KetjeSr-armv7m-le-gcc.s +590 -0
  206. data/ext/xkcp/lib/low/Ketje/OptimizedLE/Ket.c +126 -0
  207. data/ext/xkcp/lib/low/Ketje/OptimizedLE/Ket.h +68 -0
  208. data/ext/xkcp/lib/low/Ketje/OptimizedLE/Ket.inc +174 -0
  209. data/ext/xkcp/lib/low/Ketje/SnP-compliant/Ket.c +80 -0
  210. data/ext/xkcp/lib/low/Ketje/SnP-compliant/Ket.h +68 -0
  211. data/ext/xkcp/lib/low/Ketje/SnP-compliant/Ket.inc +142 -0
  212. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-SnP.h +55 -0
  213. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-u1-armv6m-le-armcc.s +1086 -0
  214. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-u1-armv6m-le-gcc.s +1092 -0
  215. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-uf-armv6-le-armcc.s +721 -0
  216. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-uf-armv6-le-gcc.s +726 -0
  217. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-uf-armv7m-le-armcc.s +723 -0
  218. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-uf-armv7m-le-gcc.s +729 -0
  219. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-u1-armv6m-le-armcc.s +1164 -0
  220. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-u1-armv6m-le-gcc.s +1165 -0
  221. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-uf-armv6-le-armcc.s +562 -0
  222. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-uf-armv6-le-gcc.s +563 -0
  223. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-uf-armv7m-le-armcc.s +563 -0
  224. data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-uf-armv7m-le-gcc.s +565 -0
  225. data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodoo-SnP.h +55 -0
  226. data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodoo-uf-armv7a-neon-le-armcc.s +476 -0
  227. data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodoo-uf-armv7a-neon-le-gcc.s +485 -0
  228. data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodyak-uf-armv7a-neon-le-armcc.s +362 -0
  229. data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodyak-uf-armv7a-neon-le-gcc.s +367 -0
  230. data/ext/xkcp/lib/low/Xoodoo/AVR8/Xoodoo-SnP.h +43 -0
  231. data/ext/xkcp/lib/low/Xoodoo/AVR8/Xoodoo-avr8-u1.s +1341 -0
  232. data/ext/xkcp/lib/low/Xoodoo/AVX512/Xoodoo-SIMD512.c +581 -0
  233. data/ext/xkcp/lib/low/Xoodoo/AVX512/Xoodoo-SnP.h +58 -0
  234. data/ext/xkcp/lib/low/Xoodoo/AVX512/Xoodyak-full-block-SIMD512.c +332 -0
  235. data/ext/xkcp/lib/low/Xoodoo/SSE2/Xoodoo-SIMD128.c +329 -0
  236. data/ext/xkcp/lib/low/Xoodoo/SSE2/Xoodoo-SnP.h +53 -0
  237. data/ext/xkcp/lib/low/Xoodoo/SSE2/Xoodyak-full-block-SIMD128.c +355 -0
  238. data/ext/xkcp/lib/low/Xoodoo/Xoodoo.h +79 -0
  239. data/ext/xkcp/lib/low/Xoodoo/plain/Xoodoo-SnP.h +56 -0
  240. data/ext/xkcp/lib/low/Xoodoo/plain/Xoodoo-optimized.c +399 -0
  241. data/ext/xkcp/lib/low/Xoodoo/plain/Xoodyak-full-blocks.c +127 -0
  242. data/ext/xkcp/lib/low/Xoodoo/ref/Xoodoo-SnP.h +43 -0
  243. data/ext/xkcp/lib/low/Xoodoo/ref/Xoodoo-reference.c +253 -0
  244. data/ext/xkcp/lib/low/Xoodoo-times16/AVX512/Xoodoo-times16-SIMD512.c +1044 -0
  245. data/ext/xkcp/lib/low/Xoodoo-times16/AVX512/Xoodoo-times16-SnP.h +49 -0
  246. data/ext/xkcp/lib/low/Xoodoo-times16/fallback-on1/Xoodoo-times16-SnP.h +45 -0
  247. data/ext/xkcp/lib/low/Xoodoo-times16/fallback-on1/Xoodoo-times16-on1.c +37 -0
  248. data/ext/xkcp/lib/low/Xoodoo-times4/ARMv7A-NEON/Xoodoo-times4-ARMv7A.s +1587 -0
  249. data/ext/xkcp/lib/low/Xoodoo-times4/ARMv7A-NEON/Xoodoo-times4-SnP.h +48 -0
  250. data/ext/xkcp/lib/low/Xoodoo-times4/AVX512/Xoodoo-times4-SIMD512.c +1202 -0
  251. data/ext/xkcp/lib/low/Xoodoo-times4/AVX512/Xoodoo-times4-SnP.h +48 -0
  252. data/ext/xkcp/lib/low/Xoodoo-times4/SSSE3/Xoodoo-times4-SIMD128.c +484 -0
  253. data/ext/xkcp/lib/low/Xoodoo-times4/SSSE3/Xoodoo-times4-SnP.h +44 -0
  254. data/ext/xkcp/lib/low/Xoodoo-times4/fallback-on1/Xoodoo-times4-SnP.h +45 -0
  255. data/ext/xkcp/lib/low/Xoodoo-times4/fallback-on1/Xoodoo-times4-on1.c +37 -0
  256. data/ext/xkcp/lib/low/Xoodoo-times8/AVX2/Xoodoo-times8-SIMD256.c +939 -0
  257. data/ext/xkcp/lib/low/Xoodoo-times8/AVX2/Xoodoo-times8-SnP.h +49 -0
  258. data/ext/xkcp/lib/low/Xoodoo-times8/AVX512/Xoodoo-times8-SIMD512.c +1216 -0
  259. data/ext/xkcp/lib/low/Xoodoo-times8/AVX512/Xoodoo-times8-SnP.h +48 -0
  260. data/ext/xkcp/lib/low/Xoodoo-times8/fallback-on1/Xoodoo-times8-SnP.h +45 -0
  261. data/ext/xkcp/lib/low/Xoodoo-times8/fallback-on1/Xoodoo-times8-on1.c +37 -0
  262. data/ext/xkcp/lib/low/common/PlSnP-Fallback.inc +290 -0
  263. data/ext/xkcp/lib/low/common/SnP-Relaned.h +141 -0
  264. data/ext/xkcp/support/Build/ExpandProducts.xsl +79 -0
  265. data/ext/xkcp/support/Build/ToGlobalMakefile.xsl +206 -0
  266. data/ext/xkcp/support/Build/ToOneTarget.xsl +89 -0
  267. data/ext/xkcp/support/Build/ToTargetConfigFile.xsl +37 -0
  268. data/ext/xkcp/support/Build/ToTargetMakefile.xsl +298 -0
  269. data/ext/xkcp/support/Build/ToVCXProj.xsl +198 -0
  270. data/ext/xkcp/support/Kernel-PMU/Kernel-pmu.md +133 -0
  271. data/ext/xkcp/support/Kernel-PMU/Makefile +8 -0
  272. data/ext/xkcp/support/Kernel-PMU/enable_arm_pmu.c +129 -0
  273. data/ext/xkcp/support/Kernel-PMU/load-module +1 -0
  274. data/ext/xkcp/util/KeccakSum/KeccakSum.c +394 -0
  275. data/ext/xkcp/util/KeccakSum/base64.c +86 -0
  276. data/ext/xkcp/util/KeccakSum/base64.h +12 -0
  277. data/lib/sleeping_kangaroo12/binding.rb +15 -0
  278. data/lib/sleeping_kangaroo12/build/loader.rb +40 -0
  279. data/lib/sleeping_kangaroo12/build/platform.rb +37 -0
  280. data/lib/sleeping_kangaroo12/build.rb +4 -0
  281. data/lib/sleeping_kangaroo12/digest.rb +103 -0
  282. data/lib/sleeping_kangaroo12/version.rb +5 -0
  283. data/lib/sleeping_kangaroo12.rb +7 -0
  284. metadata +372 -0
@@ -0,0 +1,528 @@
1
+ ;
2
+ ; The eXtended Keccak Code Package (XKCP)
3
+ ; https://github.com/XKCP/XKCP
4
+ ;
5
+ ; The Keccak-p permutations, designed by Guido Bertoni, Joan Daemen, Michaël Peeters and Gilles Van Assche.
6
+ ;
7
+ ; Implementation by Ronny Van Keer, hereby denoted as "the implementer".
8
+ ;
9
+ ; For more information, feedback or questions, please refer to the Keccak Team website:
10
+ ; https://keccak.team/
11
+ ;
12
+ ; To the extent possible under law, the implementer has waived all copyright
13
+ ; and related or neighboring rights to the source code in this file.
14
+ ; http://creativecommons.org/publicdomain/zero/1.0/
15
+ ;
16
+ ; ---
17
+ ;
18
+ ; This file implements Keccak-p[800] in a SnP-compatible way.
19
+ ; Please refer to SnP-documentation.h for more details.
20
+ ;
21
+ ; This implementation comes with KeccakP-800-SnP.h in the same folder.
22
+ ; Please refer to LowLevel.build for the exact list of other files it must be combined with.
23
+ ;
24
+
25
+ ; WARNING: This implementation assumes a little endian CPU with ARMv6M architecture (e.g., Cortex-M0) and the ARMCC compiler.
26
+
27
+ PRESERVE8
28
+ THUMB
29
+ AREA |.text|, CODE, READONLY
30
+
31
+ ; ----------------------------------------------------------------------------
32
+
33
+ _ba equ 0*4
34
+ _be equ 1*4
35
+ _bi equ 2*4
36
+ _bo equ 3*4
37
+ _bu equ 4*4
38
+ _ga equ 5*4
39
+ _ge equ 6*4
40
+ _gi equ 7*4
41
+ _go equ 8*4
42
+ _gu equ 9*4
43
+ _ka equ 10*4
44
+ _ke equ 11*4
45
+ _ki equ 12*4
46
+ _ko equ 13*4
47
+ _ku equ 14*4
48
+ _ma equ 15*4
49
+ _me equ 16*4
50
+ _mi equ 17*4
51
+ _mo equ 18*4
52
+ _mu equ 19*4
53
+ _sa equ 20*4
54
+ _se equ 21*4
55
+ _si equ 22*4
56
+ _so equ 23*4
57
+ _su equ 24*4
58
+
59
+ MACRO
60
+ xor5 $result,$ptr,$b,$g,$k,$m,$s
61
+ ldr $result, [$ptr, #$b]
62
+ ldr r6, [$ptr, #$g]
63
+ eors $result, $result, r6
64
+ ldr r6, [$ptr, #$k]
65
+ eors $result, $result, r6
66
+ ldr r6, [$ptr, #$m]
67
+ eors $result, $result, r6
68
+ ldr r6, [$ptr, #$s]
69
+ eors $result, $result, r6
70
+ MEND
71
+
72
+ MACRO ; Theta effect
73
+ te $d, $a, $b
74
+ rors $b, $b, r4
75
+ eors $b, $b, $a
76
+ mov $d, $b
77
+ MEND
78
+
79
+ MACRO ; Theta Rho Pi
80
+ trp $rBx, $sIn, $oIn, $rD, $rot
81
+ ldr $rBx, [$sIn, #$oIn]
82
+ mov r6, $rD
83
+ eors $rBx, $rBx, r6
84
+ if $rot != 0
85
+ movs r6, #32-$rot
86
+ rors $rBx, $rBx, r6
87
+ endif
88
+ MEND
89
+
90
+ MACRO ; Chi Iota
91
+ ci $sOut, $oOut, $ax0, $ax1, $ax2, $iota, $useax2, $temp, $earlyT
92
+ if $useax2 != 0
93
+ bics $ax2, $ax2, $ax1
94
+ eors $ax2, $ax2, $ax0
95
+ if $iota != 0
96
+ mov $temp, r8
97
+ ldm $temp!, { $ax1 }
98
+ mov r8, $temp
99
+ eors $ax2, $ax2, $ax1
100
+ endif
101
+ str $ax2, [$sOut, #$oOut]
102
+ else
103
+ movs $temp, $ax2
104
+ bics $temp, $temp, $ax1
105
+ eors $temp, $temp, $ax0
106
+ str $temp, [$sOut, #$oOut]
107
+ if $earlyT != 0
108
+ eors r7, $temp
109
+ endif
110
+ endif
111
+ MEND
112
+
113
+ MACRO
114
+ KeccakRound $sOut, $sIn
115
+
116
+ ; Prepare Theta effect (U column already done by earlyTheta
117
+ movs r4, #31
118
+ xor5 r1, $sIn, _be, _ge, _ke, _me, _se
119
+ mov r6, r1
120
+ te r9, r7, r6
121
+ xor5 r2, $sIn, _bi, _gi, _ki, _mi, _si
122
+ te r12, r2, r7
123
+ xor5 r3, $sIn, _ba, _ga, _ka, _ma, _sa
124
+ te r10, r3, r2
125
+ xor5 r2, $sIn, _bo, _go, _ko, _mo, _so
126
+ te lr, r2, r3
127
+ te r11, r1, r2
128
+
129
+ ; ThetaRhoPi ChiIota
130
+ trp r1, $sIn, _bo, r12, 28
131
+ trp r2, $sIn, _gu, lr, 20
132
+ trp r3, $sIn, _ka, r9, 3
133
+ trp r4, $sIn, _me, r10, 13
134
+ trp r5, $sIn, _si, r11, 29
135
+ ci $sOut, _gu, r5, r1, r2, 0, 0, r7, 0
136
+ ci $sOut, _go, r4, r5, r1, 0, 0, r6, 0
137
+ ci $sOut, _gi, r3, r4, r5, 0, 1, r6, 0
138
+ ci $sOut, _ge, r2, r3, r4, 0, 1, r6, 0
139
+ ci $sOut, _ga, r1, r2, r3, 0, 1, r6, 0
140
+
141
+ trp r1, $sIn, _be, r10, 1
142
+ trp r2, $sIn, _gi, r11, 6
143
+ trp r3, $sIn, _ko, r12, 25
144
+ trp r4, $sIn, _mu, lr, 8
145
+ trp r5, $sIn, _sa, r9, 18
146
+ ci $sOut, _ku, r5, r1, r2, 0, 0, r6, 1
147
+ ci $sOut, _ko, r4, r5, r1, 0, 0, r6, 0
148
+ ci $sOut, _ki, r3, r4, r5, 0, 1, r6, 0
149
+ ci $sOut, _ke, r2, r3, r4, 0, 1, r6, 0
150
+ ci $sOut, _ka, r1, r2, r3, 0, 1, r6, 0
151
+
152
+ trp r1, $sIn, _bu, lr, 27
153
+ trp r2, $sIn, _ga, r9, 4
154
+ trp r3, $sIn, _ke, r10, 10
155
+ trp r4, $sIn, _mi, r11, 15
156
+ trp r5, $sIn, _so, r12, 24
157
+ ci $sOut, _mu, r5, r1, r2, 0, 0, r6, 1
158
+ ci $sOut, _mo, r4, r5, r1, 0, 0, r6, 0
159
+ ci $sOut, _mi, r3, r4, r5, 0, 1, r6, 0
160
+ ci $sOut, _me, r2, r3, r4, 0, 1, r6, 0
161
+ ci $sOut, _ma, r1, r2, r3, 0, 1, r6, 0
162
+
163
+ trp r1, $sIn, _bi, r11, 30
164
+ trp r2, $sIn, _go, r12, 23
165
+ trp r3, $sIn, _ku, lr, 7
166
+ trp r4, $sIn, _ma, r9, 9
167
+ trp r5, $sIn, _se, r10, 2
168
+ ci $sOut, _su, r5, r1, r2, 0, 0, r6, 1
169
+ ci $sOut, _so, r4, r5, r1, 0, 0, r6, 0
170
+ ci $sOut, _si, r3, r4, r5, 0, 1, r6, 0
171
+ ci $sOut, _se, r2, r3, r4, 0, 1, r6, 0
172
+ ci $sOut, _sa, r1, r2, r3, 0, 1, r6, 0
173
+
174
+ trp r1, $sIn, _ba, r9, 0
175
+ trp r2, $sIn, _ge, r10, 12
176
+ trp r3, $sIn, _ki, r11, 11
177
+ trp r4, $sIn, _mo, r12, 21
178
+ trp r5, $sIn, _su, lr, 14
179
+ ci $sOut, _bu, r5, r1, r2, 0, 0, r6, 1
180
+ ci $sOut, _bo, r4, r5, r1, 0, 0, r6, 0
181
+ ci $sOut, _bi, r3, r4, r5, 0, 1, r6, 0
182
+ ci $sOut, _be, r2, r3, r4, 0, 1, r6, 0
183
+ ci $sOut, _ba, r1, r2, r3, 1, 1, r6, 0
184
+ MEND
185
+
186
+ ; ----------------------------------------------------------------------------
187
+ ;
188
+ ; void KeccakP800_StaticInitialize( void )
189
+ ;
190
+ ALIGN
191
+ EXPORT KeccakP800_StaticInitialize
192
+ KeccakP800_StaticInitialize PROC
193
+ bx lr
194
+ ENDP
195
+
196
+ ; ----------------------------------------------------------------------------
197
+ ;
198
+ ; void KeccakP800_Initialize(void *state)
199
+ ;
200
+ ALIGN
201
+ EXPORT KeccakP800_Initialize
202
+ KeccakP800_Initialize PROC
203
+ push {r4 - r5}
204
+ movs r1, #0
205
+ movs r2, #0
206
+ movs r3, #0
207
+ movs r4, #0
208
+ movs r5, #0
209
+ stmia r0!, { r1 - r5 }
210
+ stmia r0!, { r1 - r5 }
211
+ stmia r0!, { r1 - r5 }
212
+ stmia r0!, { r1 - r5 }
213
+ stmia r0!, { r1 - r5 }
214
+ pop {r4 - r5}
215
+ bx lr
216
+ ENDP
217
+
218
+ ; ----------------------------------------------------------------------------
219
+ ;
220
+ ; void KeccakP800_AddByte(void *state, unsigned char byte, unsigned int offset)
221
+ ;
222
+ ALIGN
223
+ EXPORT KeccakP800_AddByte
224
+ KeccakP800_AddByte PROC
225
+ adds r0, r0, r2 ; state += offset
226
+ ldrb r2, [r0]
227
+ eors r2, r2, r1
228
+ strb r2, [r0]
229
+ bx lr
230
+ ENDP
231
+
232
+ ; ----------------------------------------------------------------------------
233
+ ;
234
+ ; void KeccakP800_AddBytes(void *state, const unsigned char *data, unsigned int offset, unsigned int length)
235
+ ;
236
+ ALIGN
237
+ EXPORT KeccakP800_AddBytes
238
+ KeccakP800_AddBytes PROC
239
+ push {r4,lr}
240
+ adds r0, r0, r2 ; state += offset
241
+ subs r3, r3, #4 ; if length >= 4
242
+ bcc KeccakP800_AddBytes_Bytes
243
+ movs r2, r0 ; and data pointer and offset both 32-bit aligned
244
+ orrs r2, r2, r1
245
+ lsls r2, #30
246
+ bne KeccakP800_AddBytes_Bytes
247
+ KeccakP800_AddBytes_LanesLoop ; then, perform on words
248
+ ldr r2, [r0]
249
+ ldmia r1!, {r4}
250
+ eors r2, r2, r4
251
+ stmia r0!, {r2}
252
+ subs r3, r3, #4
253
+ bcs KeccakP800_AddBytes_LanesLoop
254
+ KeccakP800_AddBytes_Bytes
255
+ adds r3, r3, #4
256
+ beq KeccakP800_AddBytes_Exit
257
+ subs r3, r3, #1
258
+ KeccakP800_AddBytes_BytesLoop
259
+ ldrb r2, [r0, r3]
260
+ ldrb r4, [r1, r3]
261
+ eors r2, r2, r4
262
+ strb r2, [r0, r3]
263
+ subs r3, r3, #1
264
+ bcs KeccakP800_AddBytes_BytesLoop
265
+ KeccakP800_AddBytes_Exit
266
+ pop {r4,pc}
267
+ ENDP
268
+
269
+ ; ----------------------------------------------------------------------------
270
+ ;
271
+ ; void KeccakP800_OverwriteBytes(void *state, const unsigned char *data, unsigned int offset, unsigned int length)
272
+ ;
273
+ ALIGN
274
+ EXPORT KeccakP800_OverwriteBytes
275
+ KeccakP800_OverwriteBytes PROC
276
+ adds r0, r0, r2 ; state += offset
277
+ subs r3, r3, #4 ; if length >= 4
278
+ bcc KeccakP800_OverwriteBytes_Bytes
279
+ movs r2, r0 ; and data pointer and offset both 32-bit aligned
280
+ orrs r2, r2, r1
281
+ lsls r2, #30
282
+ bne KeccakP800_OverwriteBytes_Bytes
283
+ KeccakP800_OverwriteBytes_LanesLoop ; then, perform on words
284
+ ldmia r1!, {r2}
285
+ stmia r0!, {r2}
286
+ subs r3, r3, #4
287
+ bcs KeccakP800_OverwriteBytes_LanesLoop
288
+ KeccakP800_OverwriteBytes_Bytes
289
+ adds r3, r3, #4
290
+ beq KeccakP800_OverwriteBytes_Exit
291
+ subs r3, r3, #1
292
+ KeccakP800_OverwriteBytes_BytesLoop
293
+ ldrb r2, [r1, r3]
294
+ strb r2, [r0, r3]
295
+ subs r3, r3, #1
296
+ bcs KeccakP800_OverwriteBytes_BytesLoop
297
+ KeccakP800_OverwriteBytes_Exit
298
+ bx lr
299
+ ENDP
300
+
301
+ ; ----------------------------------------------------------------------------
302
+ ;
303
+ ; void KeccakP800_OverwriteWithZeroes(void *state, unsigned int byteCount)
304
+ ;
305
+ ALIGN
306
+ EXPORT KeccakP800_OverwriteWithZeroes
307
+ KeccakP800_OverwriteWithZeroes PROC
308
+ movs r3, #0
309
+ lsrs r2, r1, #2
310
+ beq KeccakP800_OverwriteWithZeroes_Bytes
311
+ KeccakP800_OverwriteWithZeroes_LoopLanes
312
+ stm r0!, { r3 }
313
+ subs r2, r2, #1
314
+ bne KeccakP800_OverwriteWithZeroes_LoopLanes
315
+ KeccakP800_OverwriteWithZeroes_Bytes
316
+ lsls r1, r1, #32-2
317
+ beq KeccakP800_OverwriteWithZeroes_Exit
318
+ lsrs r1, r1, #32-2
319
+ KeccakP800_OverwriteWithZeroes_LoopBytes
320
+ subs r1, r1, #1
321
+ strb r3, [r0, r1]
322
+ bne KeccakP800_OverwriteWithZeroes_LoopBytes
323
+ KeccakP800_OverwriteWithZeroes_Exit
324
+ bx lr
325
+ ENDP
326
+
327
+ ; ----------------------------------------------------------------------------
328
+ ;
329
+ ; void KeccakP800_ExtractBytes(void *state, const unsigned char *data, unsigned int offset, unsigned int length)
330
+ ;
331
+ ALIGN
332
+ EXPORT KeccakP800_ExtractBytes
333
+ KeccakP800_ExtractBytes PROC
334
+ adds r0, r0, r2 ; state += offset
335
+ subs r3, r3, #4 ; if length >= 4
336
+ bcc KeccakP800_ExtractBytes_Bytes
337
+ movs r2, r0 ; and data pointer and offset both 32-bit aligned
338
+ orrs r2, r2, r1
339
+ lsls r2, #30
340
+ bne KeccakP800_ExtractBytes_Bytes
341
+ KeccakP800_ExtractBytes_LanesLoop ; then, perform on words
342
+ ldmia r0!, {r2}
343
+ stmia r1!, {r2}
344
+ subs r3, r3, #4
345
+ bcs KeccakP800_ExtractBytes_LanesLoop
346
+ KeccakP800_ExtractBytes_Bytes
347
+ adds r3, r3, #4
348
+ beq KeccakP800_ExtractBytes_Exit
349
+ subs r3, r3, #1
350
+ KeccakP800_ExtractBytes_BytesLoop
351
+ ldrb r2, [r0, r3]
352
+ strb r2, [r1, r3]
353
+ subs r3, r3, #1
354
+ bcs KeccakP800_ExtractBytes_BytesLoop
355
+ KeccakP800_ExtractBytes_Exit
356
+ bx lr
357
+ ENDP
358
+
359
+ ; ----------------------------------------------------------------------------
360
+ ;
361
+ ; void KeccakP800_ExtractAndAddBytes(void *state, const unsigned char *input, unsigned char *output, unsigned int offset, unsigned int length)
362
+ ;
363
+ ALIGN
364
+ EXPORT KeccakP800_ExtractAndAddBytes
365
+ KeccakP800_ExtractAndAddBytes PROC
366
+ push {r4,r5}
367
+ adds r0, r0, r3 ; state += offset (offset register no longer needed, reuse for length)
368
+ ldr r3, [sp, #8] ; get length argument from stack
369
+ subs r3, r3, #4 ; if length >= 4
370
+ bcc KeccakP800_ExtractAndAddBytes_Bytes
371
+ movs r5, r0 ; and input/output/state pointer all 32-bit aligned
372
+ orrs r5, r5, r1
373
+ orrs r5, r5, r2
374
+ lsls r5, #30
375
+ bne KeccakP800_ExtractAndAddBytes_Bytes
376
+ KeccakP800_ExtractAndAddBytes_LanesLoop ; then, perform on words
377
+ ldmia r0!, {r5}
378
+ ldmia r1!, {r4}
379
+ eors r5, r5, r4
380
+ stmia r2!, {r5}
381
+ subs r3, r3, #4
382
+ bcs KeccakP800_ExtractAndAddBytes_LanesLoop
383
+ KeccakP800_ExtractAndAddBytes_Bytes
384
+ adds r3, r3, #4
385
+ beq KeccakP800_ExtractAndAddBytes_Exit
386
+ subs r3, r3, #1
387
+ KeccakP800_ExtractAndAddBytes_BytesLoop
388
+ ldrb r5, [r0, r3]
389
+ ldrb r4, [r1, r3]
390
+ eors r5, r5, r4
391
+ strb r5, [r2, r3]
392
+ subs r3, r3, #1
393
+ bcs KeccakP800_ExtractAndAddBytes_BytesLoop
394
+ KeccakP800_ExtractAndAddBytes_Exit
395
+ pop {r4,r5}
396
+ bx lr
397
+ ENDP
398
+
399
+ ; ----------------------------------------------------------------------------
400
+ ;
401
+ ; void KeccakP800_Permute_Nrounds(void *state, unsigned int nrounds)
402
+ ;
403
+ ALIGN
404
+ EXPORT KeccakP800_Permute_Nrounds
405
+ KeccakP800_Permute_Nrounds PROC
406
+ lsls r2, r1, #2
407
+ lsls r1, r1, #31
408
+ bne KeccakP800_Permute_NroundsOdd
409
+ adr r1, KeccakP800_Permute_RoundConstants0
410
+ subs r1, r1, r2
411
+ b KeccakP800_Permute
412
+ KeccakP800_Permute_NroundsOdd
413
+ adr r1, KeccakP800_Permute_RoundConstants0
414
+ subs r1, r1, r2
415
+ push { r4 - r6, lr }
416
+ mov r2, r8
417
+ mov r3, r9
418
+ mov r4, r10
419
+ mov r5, r11
420
+ mov r6, r12
421
+ push { r2 - r7 }
422
+ sub sp, sp, #25*4+4
423
+ mov r8, r1
424
+ mov r6, sp ; copy state to stack and use stack state as input
425
+ ldmia r0!, {r1-r4,r7}
426
+ stmia r6!, {r1-r4,r7}
427
+ ldmia r0!, {r1-r5}
428
+ stmia r6!, {r1-r5}
429
+ eors r7, r7, r5
430
+ ldmia r0!, {r1-r5}
431
+ stmia r6!, {r1-r5}
432
+ eors r7, r7, r5
433
+ ldmia r0!, {r1-r5}
434
+ stmia r6!, {r1-r5}
435
+ eors r7, r7, r5
436
+ ldmia r0!, {r1-r5}
437
+ stmia r6!, {r1-r5}
438
+ eors r7, r7, r5
439
+ subs r0, r0, #100
440
+ b KeccakP800_Permute_RoundOdd
441
+ ENDP
442
+
443
+ ; ----------------------------------------------------------------------------
444
+ ;
445
+ ; void KeccakP800_Permute_12rounds( void *state )
446
+ ;
447
+ ALIGN
448
+ EXPORT KeccakP800_Permute_12rounds
449
+ KeccakP800_Permute_12rounds PROC
450
+ adr r1, KeccakP800_Permute_RoundConstants12
451
+ b KeccakP800_Permute
452
+ ENDP
453
+
454
+ ; ----------------------------------------------------------------------------
455
+ ;
456
+ ; void KeccakP800_Permute_22rounds( void *state )
457
+ ;
458
+ ALIGN
459
+ EXPORT KeccakP800_Permute_22rounds
460
+ KeccakP800_Permute_22rounds PROC
461
+ adr r1, KeccakP800_Permute_RoundConstants22
462
+ b KeccakP800_Permute
463
+ ENDP
464
+
465
+ ALIGN
466
+ KeccakP800_Permute_RoundConstants22
467
+ dcd 0x00000001
468
+ dcd 0x00008082
469
+ dcd 0x0000808a
470
+ dcd 0x80008000
471
+ dcd 0x0000808b
472
+ dcd 0x80000001
473
+ dcd 0x80008081
474
+ dcd 0x00008009
475
+ dcd 0x0000008a
476
+ dcd 0x00000088
477
+ KeccakP800_Permute_RoundConstants12
478
+ dcd 0x80008009
479
+ dcd 0x8000000a
480
+ dcd 0x8000808b
481
+ dcd 0x0000008b
482
+ dcd 0x00008089
483
+ dcd 0x00008003
484
+ dcd 0x00008002
485
+ dcd 0x00000080
486
+ dcd 0x0000800a
487
+ dcd 0x8000000a
488
+ dcd 0x80008081
489
+ dcd 0x00008080
490
+ KeccakP800_Permute_RoundConstants0
491
+ dcd 0xFF ; terminator
492
+
493
+ ; ----------------------------------------------------------------------------
494
+ ;
495
+ ; void KeccakP800_Permute( void *state, void *rc )
496
+ ;
497
+ ALIGN
498
+ KeccakP800_Permute PROC
499
+ push { r4 - r6, lr }
500
+ mov r2, r8
501
+ mov r3, r9
502
+ mov r4, r10
503
+ mov r5, r11
504
+ mov r6, r12
505
+ push { r2 - r7 }
506
+ sub sp, sp, #25*4+4
507
+ mov r8, r1
508
+ xor5 r7, r0, _bu, _gu, _ku, _mu, _su
509
+ KeccakP800_Permute_RoundLoop
510
+ KeccakRound sp, r0
511
+ KeccakP800_Permute_RoundOdd
512
+ KeccakRound r0, sp
513
+ ldr r6, [r6]
514
+ cmp r6, #0xFF
515
+ beq KeccakP800_Permute_Done
516
+ b KeccakP800_Permute_RoundLoop
517
+ KeccakP800_Permute_Done
518
+ add sp,sp,#25*4+4
519
+ pop { r2 - r7 }
520
+ mov r8, r2
521
+ mov r9, r3
522
+ mov r10, r4
523
+ mov r11, r5
524
+ mov r12, r6
525
+ pop { r4 - r6, pc }
526
+ ENDP
527
+
528
+ END