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,533 @@
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 GCC compiler.
26
+
27
+
28
+ .thumb
29
+ .syntax unified
30
+ .text
31
+
32
+ @ ----------------------------------------------------------------------------
33
+
34
+ .equ _ba , 0*4
35
+ .equ _be , 1*4
36
+ .equ _bi , 2*4
37
+ .equ _bo , 3*4
38
+ .equ _bu , 4*4
39
+ .equ _ga , 5*4
40
+ .equ _ge , 6*4
41
+ .equ _gi , 7*4
42
+ .equ _go , 8*4
43
+ .equ _gu , 9*4
44
+ .equ _ka , 10*4
45
+ .equ _ke , 11*4
46
+ .equ _ki , 12*4
47
+ .equ _ko , 13*4
48
+ .equ _ku , 14*4
49
+ .equ _ma , 15*4
50
+ .equ _me , 16*4
51
+ .equ _mi , 17*4
52
+ .equ _mo , 18*4
53
+ .equ _mu , 19*4
54
+ .equ _sa , 20*4
55
+ .equ _se , 21*4
56
+ .equ _si , 22*4
57
+ .equ _so , 23*4
58
+ .equ _su , 24*4
59
+
60
+ .macro 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
+ .endm
71
+
72
+ .macro te d, a, b
73
+ rors \b, \b, r4
74
+ eors \b, \b, \a
75
+ mov \d, \b
76
+ .endm
77
+
78
+ .macro trp rBx, sIn, oIn, rD, rot
79
+ ldr \rBx, [\sIn, #\oIn]
80
+ mov r6, \rD
81
+ eors \rBx, \rBx, r6
82
+ .if \rot != 0
83
+ movs r6, #32-\rot
84
+ rors \rBx, \rBx, r6
85
+ .endif
86
+ .endm
87
+
88
+ .macro ci sOut, oOut, ax0, ax1, ax2, iota, useax2
89
+ .if \useax2 != 0
90
+ bics \ax2, \ax2, \ax1
91
+ eors \ax2, \ax2, \ax0
92
+ .if \iota != 0
93
+ mov r6, r8
94
+ ldm r6!, { \ax1 }
95
+ mov r8, r6
96
+ eors \ax2, \ax2, \ax1
97
+ .endif
98
+ str \ax2, [\sOut, #\oOut]
99
+ .else
100
+ movs r6, \ax2
101
+ bics r6, r6, \ax1
102
+ eors r6, r6, \ax0
103
+ str r6, [\sOut, #\oOut]
104
+ .endif
105
+ .endm
106
+
107
+ .macro KeccakRound sOut, sIn
108
+
109
+ @ Prepare Theta effect
110
+ movs r4, #31
111
+ xor5 r1, \sIn, _be, _ge, _ke, _me, _se
112
+ xor5 r2, \sIn, _bu, _gu, _ku, _mu, _su
113
+ mov r6, r1
114
+ te r9, r2, r6
115
+ xor5 r3, \sIn, _bi, _gi, _ki, _mi, _si
116
+ te r12, r3, r2
117
+ xor5 r2, \sIn, _ba, _ga, _ka, _ma, _sa
118
+ te r10, r2, r3
119
+ xor5 r3, \sIn, _bo, _go, _ko, _mo, _so
120
+ te lr, r3, r2
121
+ te r11, r1, r3
122
+
123
+ @ ThetaRhoPi ChiIota
124
+ trp r1, \sIn, _bo, r12, 28
125
+ trp r2, \sIn, _gu, lr, 20
126
+ trp r3, \sIn, _ka, r9, 3
127
+ trp r4, \sIn, _me, r10, 13
128
+ trp r5, \sIn, _si, r11, 29
129
+ ci \sOut, _gu, r5, r1, r2, 0, 0
130
+ ci \sOut, _go, r4, r5, r1, 0, 0
131
+ ci \sOut, _gi, r3, r4, r5, 0, 1
132
+ ci \sOut, _ge, r2, r3, r4, 0, 1
133
+ ci \sOut, _ga, r1, r2, r3, 0, 1
134
+
135
+ trp r1, \sIn, _be, r10, 1
136
+ trp r2, \sIn, _gi, r11, 6
137
+ trp r3, \sIn, _ko, r12, 25
138
+ trp r4, \sIn, _mu, lr, 8
139
+ trp r5, \sIn, _sa, r9, 18
140
+ ci \sOut, _ku, r5, r1, r2, 0, 0
141
+ ci \sOut, _ko, r4, r5, r1, 0, 0
142
+ ci \sOut, _ki, r3, r4, r5, 0, 1
143
+ ci \sOut, _ke, r2, r3, r4, 0, 1
144
+ ci \sOut, _ka, r1, r2, r3, 0, 1
145
+
146
+ trp r1, \sIn, _bu, lr, 27
147
+ trp r2, \sIn, _ga, r9, 4
148
+ trp r3, \sIn, _ke, r10, 10
149
+ trp r4, \sIn, _mi, r11, 15
150
+ trp r5, \sIn, _so, r12, 24
151
+ ci \sOut, _mu, r5, r1, r2, 0, 0
152
+ ci \sOut, _mo, r4, r5, r1, 0, 0
153
+ ci \sOut, _mi, r3, r4, r5, 0, 1
154
+ ci \sOut, _me, r2, r3, r4, 0, 1
155
+ ci \sOut, _ma, r1, r2, r3, 0, 1
156
+
157
+ trp r1, \sIn, _bi, r11, 30
158
+ trp r2, \sIn, _go, r12, 23
159
+ trp r3, \sIn, _ku, lr, 7
160
+ trp r4, \sIn, _ma, r9, 9
161
+ trp r5, \sIn, _se, r10, 2
162
+ ci \sOut, _su, r5, r1, r2, 0, 0
163
+ ci \sOut, _so, r4, r5, r1, 0, 0
164
+ ci \sOut, _si, r3, r4, r5, 0, 1
165
+ ci \sOut, _se, r2, r3, r4, 0, 1
166
+ ci \sOut, _sa, r1, r2, r3, 0, 1
167
+
168
+ trp r1, \sIn, _ba, r9, 0
169
+ trp r2, \sIn, _ge, r10, 12
170
+ trp r3, \sIn, _ki, r11, 11
171
+ trp r4, \sIn, _mo, r12, 21
172
+ trp r5, \sIn, _su, lr, 14
173
+ ci \sOut, _bu, r5, r1, r2, 0, 0
174
+ ci \sOut, _bo, r4, r5, r1, 0, 0
175
+ ci \sOut, _bi, r3, r4, r5, 0, 1
176
+ ci \sOut, _be, r2, r3, r4, 0, 1
177
+ ci \sOut, _ba, r1, r2, r3, 1, 1
178
+ .endm
179
+
180
+ @ ----------------------------------------------------------------------------
181
+ @
182
+ @ void KeccakP800_StaticInitialize( void )
183
+ @
184
+ .align 8
185
+ .global KeccakP800_StaticInitialize
186
+ .type KeccakP800_StaticInitialize, %function;
187
+ KeccakP800_StaticInitialize:
188
+ bx lr
189
+
190
+
191
+ @ ----------------------------------------------------------------------------
192
+ @
193
+ @ void KeccakP800_Initialize(void *state)
194
+ @
195
+ .align 8
196
+ .global KeccakP800_Initialize
197
+ .type KeccakP800_Initialize, %function;
198
+ KeccakP800_Initialize:
199
+ push {r4 - r5}
200
+ movs r1, #0
201
+ movs r2, #0
202
+ movs r3, #0
203
+ movs r4, #0
204
+ movs r5, #0
205
+ stmia r0!, { r1 - r5 }
206
+ stmia r0!, { r1 - r5 }
207
+ stmia r0!, { r1 - r5 }
208
+ stmia r0!, { r1 - r5 }
209
+ stmia r0!, { r1 - r5 }
210
+ pop {r4 - r5}
211
+ bx lr
212
+
213
+
214
+ @ ----------------------------------------------------------------------------
215
+ @
216
+ @ void KeccakP800_AddByte(void *state, unsigned char byte, unsigned int offset)
217
+ @
218
+ .align 8
219
+ .global KeccakP800_AddByte
220
+ .type KeccakP800_AddByte, %function;
221
+ KeccakP800_AddByte:
222
+ adds r0, r0, r2 @ state += offset
223
+ ldrb r2, [r0]
224
+ eors r2, r2, r1
225
+ strb r2, [r0]
226
+ bx lr
227
+
228
+
229
+ @ ----------------------------------------------------------------------------
230
+ @
231
+ @ void KeccakP800_AddBytes(void *state, const unsigned char *data, unsigned int offset, unsigned int length)
232
+ @
233
+ .align 8
234
+ .global KeccakP800_AddBytes
235
+ .type KeccakP800_AddBytes, %function;
236
+ KeccakP800_AddBytes:
237
+ push {r4,lr}
238
+ adds r0, r0, r2 @ state += offset
239
+ subs r3, r3, #4 @ .if length >= 4
240
+ bcc KeccakP800_AddBytes_Bytes
241
+ movs r2, r0 @ and data pointer and offset both 32-bit aligned
242
+ orrs r2, r2, r1
243
+ lsls r2, #30
244
+ bne KeccakP800_AddBytes_Bytes
245
+ KeccakP800_AddBytes_LanesLoop: @ then, perform on words
246
+ ldr r2, [r0]
247
+ ldmia r1!, {r4}
248
+ eors r2, r2, r4
249
+ stmia r0!, {r2}
250
+ subs r3, r3, #4
251
+ bcs KeccakP800_AddBytes_LanesLoop
252
+ KeccakP800_AddBytes_Bytes:
253
+ adds r3, r3, #4
254
+ beq KeccakP800_AddBytes_Exit
255
+ subs r3, r3, #1
256
+ KeccakP800_AddBytes_BytesLoop:
257
+ ldrb r2, [r0, r3]
258
+ ldrb r4, [r1, r3]
259
+ eors r2, r2, r4
260
+ strb r2, [r0, r3]
261
+ subs r3, r3, #1
262
+ bcs KeccakP800_AddBytes_BytesLoop
263
+ KeccakP800_AddBytes_Exit:
264
+ pop {r4,pc}
265
+
266
+
267
+ @ ----------------------------------------------------------------------------
268
+ @
269
+ @ void KeccakP800_OverwriteBytes(void *state, const unsigned char *data, unsigned int offset, unsigned int length)
270
+ @
271
+ .align 8
272
+ .global KeccakP800_OverwriteBytes
273
+ .type KeccakP800_OverwriteBytes, %function;
274
+ KeccakP800_OverwriteBytes:
275
+ adds r0, r0, r2 @ state += offset
276
+ subs r3, r3, #4 @ .if length >= 4
277
+ bcc KeccakP800_OverwriteBytes_Bytes
278
+ movs r2, r0 @ and data pointer and offset both 32-bit aligned
279
+ orrs r2, r2, r1
280
+ lsls r2, #30
281
+ bne KeccakP800_OverwriteBytes_Bytes
282
+ KeccakP800_OverwriteBytes_LanesLoop: @ then, perform on words
283
+ ldmia r1!, {r2}
284
+ stmia r0!, {r2}
285
+ subs r3, r3, #4
286
+ bcs KeccakP800_OverwriteBytes_LanesLoop
287
+ KeccakP800_OverwriteBytes_Bytes:
288
+ adds r3, r3, #4
289
+ beq KeccakP800_OverwriteBytes_Exit
290
+ subs r3, r3, #1
291
+ KeccakP800_OverwriteBytes_BytesLoop:
292
+ ldrb r2, [r1, r3]
293
+ strb r2, [r0, r3]
294
+ subs r3, r3, #1
295
+ bcs KeccakP800_OverwriteBytes_BytesLoop
296
+ KeccakP800_OverwriteBytes_Exit:
297
+ bx lr
298
+
299
+
300
+ @ ----------------------------------------------------------------------------
301
+ @
302
+ @ void KeccakP800_OverwriteWithZeroes(void *state, unsigned int byteCount)
303
+ @
304
+ .align 8
305
+ .global KeccakP800_OverwriteWithZeroes
306
+ .type KeccakP800_OverwriteWithZeroes, %function;
307
+ KeccakP800_OverwriteWithZeroes:
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
+
326
+
327
+ @ ----------------------------------------------------------------------------
328
+ @
329
+ @ void KeccakP800_ExtractBytes(void *state, const unsigned char *data, unsigned int offset, unsigned int length)
330
+ @
331
+ .align 8
332
+ .global KeccakP800_ExtractBytes
333
+ .type KeccakP800_ExtractBytes, %function;
334
+ KeccakP800_ExtractBytes:
335
+ adds r0, r0, r2 @ state += offset
336
+ subs r3, r3, #4 @ .if length >= 4
337
+ bcc KeccakP800_ExtractBytes_Bytes
338
+ movs r2, r0 @ and data pointer and offset both 32-bit aligned
339
+ orrs r2, r2, r1
340
+ lsls r2, #30
341
+ bne KeccakP800_ExtractBytes_Bytes
342
+ KeccakP800_ExtractBytes_LanesLoop: @ then, perform on words
343
+ ldmia r0!, {r2}
344
+ stmia r1!, {r2}
345
+ subs r3, r3, #4
346
+ bcs KeccakP800_ExtractBytes_LanesLoop
347
+ KeccakP800_ExtractBytes_Bytes:
348
+ adds r3, r3, #4
349
+ beq KeccakP800_ExtractBytes_Exit
350
+ subs r3, r3, #1
351
+ KeccakP800_ExtractBytes_BytesLoop:
352
+ ldrb r2, [r0, r3]
353
+ strb r2, [r1, r3]
354
+ subs r3, r3, #1
355
+ bcs KeccakP800_ExtractBytes_BytesLoop
356
+ KeccakP800_ExtractBytes_Exit:
357
+ bx lr
358
+
359
+
360
+ @ ----------------------------------------------------------------------------
361
+ @
362
+ @ void KeccakP800_ExtractAndAddBytes(void *state, const unsigned char *input, unsigned char *output, unsigned int offset, unsigned int length)
363
+ @
364
+ .align 8
365
+ .global KeccakP800_ExtractAndAddBytes
366
+ .type KeccakP800_ExtractAndAddBytes, %function;
367
+ KeccakP800_ExtractAndAddBytes:
368
+ push {r4,r5}
369
+ adds r0, r0, r3 @ state += offset (offset register no longer needed, reuse for length)
370
+ ldr r3, [sp, #8] @ get length argument from stack
371
+ subs r3, r3, #4 @ .if length >= 4
372
+ bcc KeccakP800_ExtractAndAddBytes_Bytes
373
+ movs r5, r0 @ and input/output/state pointer all 32-bit aligned
374
+ orrs r5, r5, r1
375
+ orrs r5, r5, r2
376
+ lsls r5, #30
377
+ bne KeccakP800_ExtractAndAddBytes_Bytes
378
+ KeccakP800_ExtractAndAddBytes_LanesLoop: @ then, perform on words
379
+ ldmia r0!, {r5}
380
+ ldmia r1!, {r4}
381
+ eors r5, r5, r4
382
+ stmia r2!, {r5}
383
+ subs r3, r3, #4
384
+ bcs KeccakP800_ExtractAndAddBytes_LanesLoop
385
+ KeccakP800_ExtractAndAddBytes_Bytes:
386
+ adds r3, r3, #4
387
+ beq KeccakP800_ExtractAndAddBytes_Exit
388
+ subs r3, r3, #1
389
+ KeccakP800_ExtractAndAddBytes_BytesLoop:
390
+ ldrb r5, [r0, r3]
391
+ ldrb r4, [r1, r3]
392
+ eors r5, r5, r4
393
+ strb r5, [r2, r3]
394
+ subs r3, r3, #1
395
+ bcs KeccakP800_ExtractAndAddBytes_BytesLoop
396
+ KeccakP800_ExtractAndAddBytes_Exit:
397
+ pop {r4,r5}
398
+ bx lr
399
+
400
+
401
+ @ ----------------------------------------------------------------------------
402
+ @
403
+ @ void KeccakP800_Permute_Nrounds(void *state, unsigned int nrounds)
404
+ @
405
+ .align 8
406
+ .global KeccakP800_Permute_Nrounds
407
+ .type KeccakP800_Permute_Nrounds, %function;
408
+ KeccakP800_Permute_Nrounds:
409
+ lsls r2, r1, #2
410
+ lsls r1, r1, #31
411
+ bne KeccakP800_Permute_NroundsOdd
412
+ adr r1, KeccakP800_Permute_RoundConstants0
413
+ subs r1, r1, r2
414
+ b KeccakP800_Permute
415
+ KeccakP800_Permute_NroundsOdd:
416
+ adr r1, KeccakP800_Permute_RoundConstants0
417
+ subs r1, r1, r2
418
+ push { r4 - r6, lr }
419
+ mov r2, r8
420
+ mov r3, r9
421
+ mov r4, r10
422
+ mov r5, r11
423
+ mov r6, r12
424
+ push { r2 - r7 }
425
+ sub sp, sp, #25*4+4
426
+ mov r8, r1
427
+ @ copy state to stack and use stack state as input
428
+ mov r7, r0
429
+ mov r0, sp
430
+ ldmia r7!, {r1-r5}
431
+ stmia r0!, {r1-r5}
432
+ ldmia r7!, {r1-r5}
433
+ stmia r0!, {r1-r5}
434
+ ldmia r7!, {r1-r5}
435
+ stmia r0!, {r1-r5}
436
+ ldmia r7!, {r1-r5}
437
+ stmia r0!, {r1-r5}
438
+ ldmia r7!, {r1-r5}
439
+ stmia r0!, {r1-r5}
440
+ subs r0, r0, #100
441
+ subs r7, r7, #100
442
+ b KeccakP800_Permute_RoundLoop
443
+
444
+
445
+ @ ----------------------------------------------------------------------------
446
+ @
447
+ @ void KeccakP800_Permute_12rounds( void *state )
448
+ @
449
+ .align 8
450
+ .global KeccakP800_Permute_12rounds
451
+ .type KeccakP800_Permute_12rounds, %function;
452
+ KeccakP800_Permute_12rounds:
453
+ adr r1, KeccakP800_Permute_RoundConstants12
454
+ b KeccakP800_Permute
455
+
456
+
457
+ @ ----------------------------------------------------------------------------
458
+ @
459
+ @ void KeccakP800_Permute_22rounds( void *state )
460
+ @
461
+ .align 8
462
+ .global KeccakP800_Permute_22rounds
463
+ .type KeccakP800_Permute_22rounds, %function;
464
+ KeccakP800_Permute_22rounds:
465
+ adr r1, KeccakP800_Permute_RoundConstants22
466
+ b KeccakP800_Permute
467
+
468
+
469
+ .align 8
470
+ KeccakP800_Permute_RoundConstants22:
471
+ .long 0x00000001
472
+ .long 0x00008082
473
+ .long 0x0000808a
474
+ .long 0x80008000
475
+ .long 0x0000808b
476
+ .long 0x80000001
477
+ .long 0x80008081
478
+ .long 0x00008009
479
+ .long 0x0000008a
480
+ .long 0x00000088
481
+ KeccakP800_Permute_RoundConstants12:
482
+ .long 0x80008009
483
+ .long 0x8000000a
484
+ .long 0x8000808b
485
+ .long 0x0000008b
486
+ .long 0x00008089
487
+ .long 0x00008003
488
+ .long 0x00008002
489
+ .long 0x00000080
490
+ .long 0x0000800a
491
+ .long 0x8000000a
492
+ .long 0x80008081
493
+ .long 0x00008080
494
+ KeccakP800_Permute_RoundConstants0:
495
+ .long 0xFF @ terminator
496
+
497
+ @ ----------------------------------------------------------------------------
498
+ @
499
+ @ void KeccakP800_Permute( void *state, void *rc )
500
+ @
501
+ .align 8
502
+ KeccakP800_Permute:
503
+ push { r4 - r6, lr }
504
+ mov r2, r8
505
+ mov r3, r9
506
+ mov r4, r10
507
+ mov r5, r11
508
+ mov r6, r12
509
+ push { r2 - r7 }
510
+ sub sp, sp, #25*4+4
511
+ mov r8, r1
512
+ mov r7, sp
513
+ KeccakP800_Permute_RoundLoop:
514
+ KeccakRound r7, r0
515
+ ldr r6, [r6]
516
+ cmp r6, #0xFF
517
+ beq KeccakP800_Permute_Done
518
+ mov r6, r7
519
+ mov r7, r0
520
+ mov r0, r6
521
+ b KeccakP800_Permute_RoundLoop
522
+ KeccakP800_Permute_Done:
523
+ mov r0, r7
524
+ add sp,sp,#25*4+4
525
+ pop { r2 - r7 }
526
+ mov r8, r2
527
+ mov r9, r3
528
+ mov r10, r4
529
+ mov r11, r5
530
+ mov r12, r6
531
+ pop { r4 - r6, pc }
532
+
533
+