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,48 @@
1
+ /*
2
+ The eXtended Keccak Code Package (XKCP)
3
+ https://github.com/XKCP/XKCP
4
+
5
+ The Xoodoo permutation, designed by Joan Daemen, Seth Hoffert, Gilles Van Assche and Ronny Van Keer.
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
+ #ifndef _Xoodoo_times8_SnP_h_
18
+ #define _Xoodoo_times8_SnP_h_
19
+
20
+ /** For the documentation, see PlSnP-documentation.h.
21
+ */
22
+
23
+ #define Xoodootimes8_implementation "512-bit SIMD (AVX-512) implementation"
24
+ #define Xoodootimes8_statesSizeInBytes (8*3*4*4)
25
+ #define Xoodootimes8_statesAlignment 64
26
+
27
+ #define Xoodootimes8_StaticInitialize()
28
+ void Xoodootimes8_InitializeAll(void *states);
29
+ #define Xoodootimes8_AddByte(states, instanceIndex, byte, offset) \
30
+ ((unsigned char*)(states))[(instanceIndex)*4 + ((offset)/4)*8*4 + (offset)%4] ^= (byte)
31
+ void Xoodootimes8_AddBytes(void *states, unsigned int instanceIndex, const unsigned char *data, unsigned int offset, unsigned int length);
32
+ void Xoodootimes8_AddLanesAll(void *states, const unsigned char *data, unsigned int laneCount, unsigned int laneOffset);
33
+ void Xoodootimes8_OverwriteBytes(void *states, unsigned int instanceIndex, const unsigned char *data, unsigned int offset, unsigned int length);
34
+ void Xoodootimes8_OverwriteLanesAll(void *states, const unsigned char *data, unsigned int laneCount, unsigned int laneOffset);
35
+ void Xoodootimes8_OverwriteWithZeroes(void *states, unsigned int instanceIndex, unsigned int byteCount);
36
+ void Xoodootimes8_PermuteAll_6rounds(void *states);
37
+ void Xoodootimes8_PermuteAll_12rounds(void *states);
38
+ void Xoodootimes8_ExtractBytes(const void *states, unsigned int instanceIndex, unsigned char *data, unsigned int offset, unsigned int length);
39
+ void Xoodootimes8_ExtractLanesAll(const void *states, unsigned char *data, unsigned int laneCount, unsigned int laneOffset);
40
+ void Xoodootimes8_ExtractAndAddBytes(const void *states, unsigned int instanceIndex, const unsigned char *input, unsigned char *output, unsigned int offset, unsigned int length);
41
+ void Xoodootimes8_ExtractAndAddLanesAll(const void *states, const unsigned char *input, unsigned char *output, unsigned int laneCount, unsigned int laneOffset);
42
+
43
+ #define Xoodootimes8_FastXoofff_supported
44
+ void Xooffftimes8_AddIs(unsigned char *output, const unsigned char *input, size_t bitLen);
45
+ size_t Xooffftimes8_CompressFastLoop(unsigned char *k, unsigned char *x, const unsigned char *input, size_t length);
46
+ size_t Xooffftimes8_ExpandFastLoop(unsigned char *yAccu, const unsigned char *kRoll, unsigned char *output, size_t length);
47
+
48
+ #endif
@@ -0,0 +1,45 @@
1
+ /*
2
+ The eXtended Keccak Code Package (XKCP)
3
+ https://github.com/XKCP/XKCP
4
+
5
+ The Xoodoo permutation, designed by Joan Daemen, Seth Hoffert, Gilles Van Assche and Ronny Van Keer.
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
+ #ifndef _Xoodoo_times8_SnP_h_
18
+ #define _Xoodoo_times8_SnP_h_
19
+
20
+ #include "Xoodoo-SnP.h"
21
+
22
+ /** For the documentation, see PlSnP-documentation.h.
23
+ */
24
+
25
+ #define Xoodootimes8_implementation "fallback on serial implementation (" Xoodoo_implementation ")"
26
+ #define Xoodootimes8_statesSizeInBytes (((Xoodoo_stateSizeInBytes+(Xoodoo_stateAlignment-1))/Xoodoo_stateAlignment)*Xoodoo_stateAlignment*8)
27
+ #define Xoodootimes8_statesAlignment Xoodoo_stateAlignment
28
+ #define Xoodootimes8_isFallback
29
+
30
+ void Xoodootimes8_StaticInitialize(void);
31
+ void Xoodootimes8_InitializeAll(void *states);
32
+ void Xoodootimes8_AddByte(void *states, unsigned int instanceIndex, unsigned char data, unsigned int offset);
33
+ void Xoodootimes8_AddBytes(void *states, unsigned int instanceIndex, const unsigned char *data, unsigned int offset, unsigned int length);
34
+ void Xoodootimes8_AddLanesAll(void *states, const unsigned char *data, unsigned int laneCount, unsigned int laneOffset);
35
+ void Xoodootimes8_OverwriteBytes(void *states, unsigned int instanceIndex, const unsigned char *data, unsigned int offset, unsigned int length);
36
+ void Xoodootimes8_OverwriteLanesAll(void *states, const unsigned char *data, unsigned int laneCount, unsigned int laneOffset);
37
+ void Xoodootimes8_OverwriteWithZeroes(void *states, unsigned int instanceIndex, unsigned int byteCount);
38
+ void Xoodootimes8_PermuteAll_6rounds(void *states);
39
+ void Xoodootimes8_PermuteAll_12rounds(void *states);
40
+ void Xoodootimes8_ExtractBytes(const void *states, unsigned int instanceIndex, unsigned char *data, unsigned int offset, unsigned int length);
41
+ void Xoodootimes8_ExtractLanesAll(const void *states, unsigned char *data, unsigned int laneCount, unsigned int laneOffset);
42
+ void Xoodootimes8_ExtractAndAddBytes(const void *states, unsigned int instanceIndex, const unsigned char *input, unsigned char *output, unsigned int offset, unsigned int length);
43
+ void Xoodootimes8_ExtractAndAddLanesAll(const void *states, const unsigned char *input, unsigned char *output, unsigned int laneCount, unsigned int laneOffset);
44
+
45
+ #endif
@@ -0,0 +1,37 @@
1
+ /*
2
+ The eXtended Keccak Code Package (XKCP)
3
+ https://github.com/XKCP/XKCP
4
+
5
+ The Xoodoo permutation, designed by Joan Daemen, Seth Hoffert, Gilles Van Assche and Ronny Van Keer.
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 Xoodoo×8 in a PlSnP-compatible way.
19
+ Please refer to PlSnP-documentation.h for more details.
20
+
21
+ This implementation comes with Xoodoo-times8-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
+ #include "Xoodoo-SnP.h"
26
+
27
+ #define prefix Xoodootimes8
28
+ #define PlSnP_baseParallelism 1
29
+ #define PlSnP_targetParallelism 8
30
+ #define SnP_laneLengthInBytes 4
31
+ #define SnP Xoodoo
32
+ #define SnP_Permute Xoodoo_Permute_6rounds
33
+ #define SnP_Permute_12rounds Xoodoo_Permute_12rounds
34
+ #define PlSnP_PermuteAll Xoodootimes8_PermuteAll_6rounds
35
+ #define PlSnP_PermuteAll_12rounds Xoodootimes8_PermuteAll_12rounds
36
+
37
+ #include "PlSnP-Fallback.inc"
@@ -0,0 +1,290 @@
1
+ /*
2
+ The eXtended Keccak Code Package (XKCP)
3
+ https://github.com/XKCP/XKCP
4
+
5
+ Implementation by Gilles Van Assche, hereby denoted as "the implementer".
6
+
7
+ For more information, feedback or questions, please refer to the Keccak Team website:
8
+ https://keccak.team/
9
+
10
+ To the extent possible under law, the implementer has waived all copyright
11
+ and related or neighboring rights to the source code in this file.
12
+ http://creativecommons.org/publicdomain/zero/1.0/
13
+
14
+ ---
15
+
16
+ This file contains macros that help make a PlSnP-compatible implementation by
17
+ serially falling back on a SnP-compatible implementation or on a PlSnP-compatible
18
+ implementation of lower parallism degree.
19
+
20
+ Please refer to PlSnP-documentation.h for more details.
21
+ */
22
+
23
+ /* expect PlSnP_baseParallelism, PlSnP_targetParallelism */
24
+ /* expect SnP_stateSizeInBytes, SnP_stateAlignment */
25
+ /* expect prefix */
26
+ /* expect SnP_* */
27
+
28
+ #define JOIN0(a, b) a ## b
29
+ #define JOIN(a, b) JOIN0(a, b)
30
+
31
+ #define PlSnP_StaticInitialize JOIN(prefix, _StaticInitialize)
32
+ #define PlSnP_InitializeAll JOIN(prefix, _InitializeAll)
33
+ #define PlSnP_AddByte JOIN(prefix, _AddByte)
34
+ #define PlSnP_AddBytes JOIN(prefix, _AddBytes)
35
+ #define PlSnP_AddLanesAll JOIN(prefix, _AddLanesAll)
36
+ #define PlSnP_OverwriteBytes JOIN(prefix, _OverwriteBytes)
37
+ #define PlSnP_OverwriteLanesAll JOIN(prefix, _OverwriteLanesAll)
38
+ #define PlSnP_OverwriteWithZeroes JOIN(prefix, _OverwriteWithZeroes)
39
+ #define PlSnP_ExtractBytes JOIN(prefix, _ExtractBytes)
40
+ #define PlSnP_ExtractLanesAll JOIN(prefix, _ExtractLanesAll)
41
+ #define PlSnP_ExtractAndAddBytes JOIN(prefix, _ExtractAndAddBytes)
42
+ #define PlSnP_ExtractAndAddLanesAll JOIN(prefix, _ExtractAndAddLanesAll)
43
+
44
+ #if (PlSnP_baseParallelism == 1)
45
+ #define SnP_stateSizeInBytes JOIN(SnP, _stateSizeInBytes)
46
+ #define SnP_stateAlignment JOIN(SnP, _stateAlignment)
47
+ #else
48
+ #define SnP_stateSizeInBytes JOIN(SnP, _statesSizeInBytes)
49
+ #define SnP_stateAlignment JOIN(SnP, _statesAlignment)
50
+ #endif
51
+ #define PlSnP_factor ((PlSnP_targetParallelism)/(PlSnP_baseParallelism))
52
+ #define SnP_stateOffset (((SnP_stateSizeInBytes+(SnP_stateAlignment-1))/SnP_stateAlignment)*SnP_stateAlignment)
53
+ #define stateWithIndex(i) ((unsigned char *)states+((i)*SnP_stateOffset))
54
+
55
+ #define SnP_StaticInitialize JOIN(SnP, _StaticInitialize)
56
+ #define SnP_Initialize JOIN(SnP, _Initialize)
57
+ #define SnP_InitializeAll JOIN(SnP, _InitializeAll)
58
+ #define SnP_AddByte JOIN(SnP, _AddByte)
59
+ #define SnP_AddBytes JOIN(SnP, _AddBytes)
60
+ #define SnP_AddLanesAll JOIN(SnP, _AddLanesAll)
61
+ #define SnP_OverwriteBytes JOIN(SnP, _OverwriteBytes)
62
+ #define SnP_OverwriteLanesAll JOIN(SnP, _OverwriteLanesAll)
63
+ #define SnP_OverwriteWithZeroes JOIN(SnP, _OverwriteWithZeroes)
64
+ #define SnP_ExtractBytes JOIN(SnP, _ExtractBytes)
65
+ #define SnP_ExtractLanesAll JOIN(SnP, _ExtractLanesAll)
66
+ #define SnP_ExtractAndAddBytes JOIN(SnP, _ExtractAndAddBytes)
67
+ #define SnP_ExtractAndAddLanesAll JOIN(SnP, _ExtractAndAddLanesAll)
68
+
69
+ void PlSnP_StaticInitialize( void )
70
+ {
71
+ SnP_StaticInitialize();
72
+ }
73
+
74
+ void PlSnP_InitializeAll(void *states)
75
+ {
76
+ unsigned int i;
77
+
78
+ for(i=0; i<PlSnP_factor; i++)
79
+ #if (PlSnP_baseParallelism == 1)
80
+ SnP_Initialize(stateWithIndex(i));
81
+ #else
82
+ SnP_InitializeAll(stateWithIndex(i));
83
+ #endif
84
+ }
85
+
86
+ void PlSnP_AddByte(void *states, unsigned int instanceIndex, unsigned char byte, unsigned int offset)
87
+ {
88
+ #if (PlSnP_baseParallelism == 1)
89
+ SnP_AddByte(stateWithIndex(instanceIndex), byte, offset);
90
+ #else
91
+ SnP_AddByte(stateWithIndex(instanceIndex/PlSnP_baseParallelism), instanceIndex%PlSnP_baseParallelism, byte, offset);
92
+ #endif
93
+ }
94
+
95
+ void PlSnP_AddBytes(void *states, unsigned int instanceIndex, const unsigned char *data, unsigned int offset, unsigned int length)
96
+ {
97
+ #if (PlSnP_baseParallelism == 1)
98
+ SnP_AddBytes(stateWithIndex(instanceIndex), data, offset, length);
99
+ #else
100
+ SnP_AddBytes(stateWithIndex(instanceIndex/PlSnP_baseParallelism), instanceIndex%PlSnP_baseParallelism, data, offset, length);
101
+ #endif
102
+ }
103
+
104
+ void PlSnP_AddLanesAll(void *states, const unsigned char *data, unsigned int laneCount, unsigned int laneOffset)
105
+ {
106
+ unsigned int i;
107
+
108
+ for(i=0; i<PlSnP_factor; i++) {
109
+ #if (PlSnP_baseParallelism == 1)
110
+ SnP_AddBytes(stateWithIndex(i), data, 0, laneCount*SnP_laneLengthInBytes);
111
+ #else
112
+ SnP_AddLanesAll(stateWithIndex(i), data, laneCount, laneOffset);
113
+ #endif
114
+ data += PlSnP_baseParallelism*laneOffset*SnP_laneLengthInBytes;
115
+ }
116
+ }
117
+
118
+ void PlSnP_OverwriteBytes(void *states, unsigned int instanceIndex, const unsigned char *data, unsigned int offset, unsigned int length)
119
+ {
120
+ #if (PlSnP_baseParallelism == 1)
121
+ SnP_OverwriteBytes(stateWithIndex(instanceIndex), data, offset, length);
122
+ #else
123
+ SnP_OverwriteBytes(stateWithIndex(instanceIndex/PlSnP_baseParallelism), instanceIndex%PlSnP_baseParallelism, data, offset, length);
124
+ #endif
125
+ }
126
+
127
+ void PlSnP_OverwriteLanesAll(void *states, const unsigned char *data, unsigned int laneCount, unsigned int laneOffset)
128
+ {
129
+ unsigned int i;
130
+
131
+ for(i=0; i<PlSnP_factor; i++) {
132
+ #if (PlSnP_baseParallelism == 1)
133
+ SnP_OverwriteBytes(stateWithIndex(i), data, 0, laneCount*SnP_laneLengthInBytes);
134
+ #else
135
+ SnP_OverwriteLanesAll(stateWithIndex(i), data, laneCount, laneOffset);
136
+ #endif
137
+ data += PlSnP_baseParallelism*laneOffset*SnP_laneLengthInBytes;
138
+ }
139
+ }
140
+
141
+ void PlSnP_OverwriteWithZeroes(void *states, unsigned int instanceIndex, unsigned int byteCount)
142
+ {
143
+ #if (PlSnP_baseParallelism == 1)
144
+ SnP_OverwriteWithZeroes(stateWithIndex(instanceIndex), byteCount);
145
+ #else
146
+ SnP_OverwriteWithZeroes(stateWithIndex(instanceIndex/PlSnP_baseParallelism), instanceIndex%PlSnP_baseParallelism, byteCount);
147
+ #endif
148
+ }
149
+
150
+ void PlSnP_PermuteAll(void *states)
151
+ {
152
+ unsigned int i;
153
+
154
+ for(i=0; i<PlSnP_factor; i++) {
155
+ #if (PlSnP_baseParallelism == 1)
156
+ SnP_Permute(stateWithIndex(i));
157
+ #else
158
+ SnP_PermuteAll(stateWithIndex(i));
159
+ #endif
160
+ }
161
+ }
162
+
163
+ #if (defined(SnP_Permute_12rounds) || defined(SnP_PermuteAll_12rounds))
164
+ void PlSnP_PermuteAll_12rounds(void *states)
165
+ {
166
+ unsigned int i;
167
+
168
+ for(i=0; i<PlSnP_factor; i++) {
169
+ #if (PlSnP_baseParallelism == 1)
170
+ SnP_Permute_12rounds(stateWithIndex(i));
171
+ #else
172
+ SnP_PermuteAll_12rounds(stateWithIndex(i));
173
+ #endif
174
+ }
175
+ }
176
+ #endif
177
+
178
+ #if (defined(SnP_Permute_Nrounds) || defined(SnP_PermuteAll_6rounds))
179
+ void PlSnP_PermuteAll_6rounds(void *states)
180
+ {
181
+ unsigned int i;
182
+
183
+ for(i=0; i<PlSnP_factor; i++) {
184
+ #if (PlSnP_baseParallelism == 1)
185
+ SnP_Permute_Nrounds(stateWithIndex(i), 6);
186
+ #else
187
+ SnP_PermuteAll_6rounds(stateWithIndex(i));
188
+ #endif
189
+ }
190
+ }
191
+ #endif
192
+
193
+ #if (defined(SnP_Permute_Nrounds) || defined(SnP_PermuteAll_4rounds))
194
+ void PlSnP_PermuteAll_4rounds(void *states)
195
+ {
196
+ unsigned int i;
197
+
198
+ for(i=0; i<PlSnP_factor; i++) {
199
+ #if (PlSnP_baseParallelism == 1)
200
+ SnP_Permute_Nrounds(stateWithIndex(i), 4);
201
+ #else
202
+ SnP_PermuteAll_4rounds(stateWithIndex(i));
203
+ #endif
204
+ }
205
+ }
206
+ #endif
207
+
208
+ void PlSnP_ExtractBytes(void *states, unsigned int instanceIndex, unsigned char *data, unsigned int offset, unsigned int length)
209
+ {
210
+ #if (PlSnP_baseParallelism == 1)
211
+ SnP_ExtractBytes(stateWithIndex(instanceIndex), data, offset, length);
212
+ #else
213
+ SnP_ExtractBytes(stateWithIndex(instanceIndex/PlSnP_baseParallelism), instanceIndex%PlSnP_baseParallelism, data, offset, length);
214
+ #endif
215
+ }
216
+
217
+ void PlSnP_ExtractLanesAll(const void *states, unsigned char *data, unsigned int laneCount, unsigned int laneOffset)
218
+ {
219
+ unsigned int i;
220
+
221
+ for(i=0; i<PlSnP_factor; i++) {
222
+ #if (PlSnP_baseParallelism == 1)
223
+ SnP_ExtractBytes(stateWithIndex(i), data, 0, laneCount*SnP_laneLengthInBytes);
224
+ #else
225
+ SnP_ExtractLanesAll(stateWithIndex(i), data, laneCount, laneOffset);
226
+ #endif
227
+ data += laneOffset*SnP_laneLengthInBytes*PlSnP_baseParallelism;
228
+ }
229
+ }
230
+
231
+ void PlSnP_ExtractAndAddBytes(void *states, unsigned int instanceIndex, const unsigned char *input, unsigned char *output, unsigned int offset, unsigned int length)
232
+ {
233
+ #if (PlSnP_baseParallelism == 1)
234
+ SnP_ExtractAndAddBytes(stateWithIndex(instanceIndex), input, output, offset, length);
235
+ #else
236
+ SnP_ExtractAndAddBytes(stateWithIndex(instanceIndex/PlSnP_baseParallelism), instanceIndex%PlSnP_baseParallelism, input, output, offset, length);
237
+ #endif
238
+ }
239
+
240
+ void PlSnP_ExtractAndAddLanesAll(const void *states, const unsigned char *input, unsigned char *output, unsigned int laneCount, unsigned int laneOffset)
241
+ {
242
+ unsigned int i;
243
+
244
+ for(i=0; i<PlSnP_factor; i++) {
245
+ #if (PlSnP_baseParallelism == 1)
246
+ SnP_ExtractAndAddBytes(stateWithIndex(i), input, output, 0, laneCount*SnP_laneLengthInBytes);
247
+ #else
248
+ SnP_ExtractAndAddLanesAll(stateWithIndex(i), input, output, laneCount, laneOffset);
249
+ #endif
250
+ input += laneOffset*SnP_laneLengthInBytes*PlSnP_baseParallelism;
251
+ output += laneOffset*SnP_laneLengthInBytes*PlSnP_baseParallelism;
252
+ }
253
+ }
254
+
255
+ #undef PlSnP_factor
256
+ #undef SnP_stateOffset
257
+ #undef stateWithIndex
258
+ #undef JOIN0
259
+ #undef JOIN
260
+ #undef PlSnP_StaticInitialize
261
+ #undef PlSnP_InitializeAll
262
+ #undef PlSnP_AddByte
263
+ #undef PlSnP_AddBytes
264
+ #undef PlSnP_AddLanesAll
265
+ #undef PlSnP_OverwriteBytes
266
+ #undef PlSnP_OverwriteLanesAll
267
+ #undef PlSnP_OverwriteWithZeroes
268
+ #undef PlSnP_PermuteAll
269
+ #undef PlSnP_ExtractBytes
270
+ #undef PlSnP_ExtractLanesAll
271
+ #undef PlSnP_ExtractAndAddBytes
272
+ #undef PlSnP_ExtractAndAddLanesAll
273
+ #undef SnP_stateAlignment
274
+ #undef SnP_stateSizeInBytes
275
+ #undef PlSnP_factor
276
+ #undef SnP_stateOffset
277
+ #undef stateWithIndex
278
+ #undef SnP_StaticInitialize
279
+ #undef SnP_Initialize
280
+ #undef SnP_InitializeAll
281
+ #undef SnP_AddByte
282
+ #undef SnP_AddBytes
283
+ #undef SnP_AddLanesAll
284
+ #undef SnP_OverwriteBytes
285
+ #undef SnP_OverwriteWithZeroes
286
+ #undef SnP_OverwriteLanesAll
287
+ #undef SnP_ExtractBytes
288
+ #undef SnP_ExtractLanesAll
289
+ #undef SnP_ExtractAndAddBytes
290
+ #undef SnP_ExtractAndAddLanesAll
@@ -0,0 +1,141 @@
1
+ /*
2
+ The eXtended Keccak Code Package (XKCP)
3
+ https://github.com/XKCP/XKCP
4
+
5
+ Implementation by Gilles Van Assche and Ronny Van Keer, hereby denoted as "the implementer".
6
+
7
+ For more information, feedback or questions, please refer to the Keccak Team website:
8
+ https://keccak.team/
9
+
10
+ To the extent possible under law, the implementer has waived all copyright
11
+ and related or neighboring rights to the source code in this file.
12
+ http://creativecommons.org/publicdomain/zero/1.0/
13
+
14
+ ---
15
+
16
+ This file contains macros that help implement a permutation in a SnP-compatible way.
17
+ It converts an implementation that implement state input/output functions
18
+ in a lane-oriented fashion (i.e., using SnP_AddLanes() and SnP_AddBytesInLane,
19
+ and similarly for Overwite, Extract and ExtractAndAdd) to the byte-oriented SnP.
20
+ Please refer to SnP-documentation.h for more details.
21
+ */
22
+
23
+ #ifndef _SnP_Relaned_h_
24
+ #define _SnP_Relaned_h_
25
+
26
+ #define SnP_AddBytes(state, data, offset, length, SnP_AddLanes, SnP_AddBytesInLane, SnP_laneLengthInBytes) \
27
+ { \
28
+ if ((offset) == 0) { \
29
+ SnP_AddLanes(state, data, (length)/SnP_laneLengthInBytes); \
30
+ SnP_AddBytesInLane(state, \
31
+ (length)/SnP_laneLengthInBytes, \
32
+ (data)+((length)/SnP_laneLengthInBytes)*SnP_laneLengthInBytes, \
33
+ 0, \
34
+ (length)%SnP_laneLengthInBytes); \
35
+ } \
36
+ else { \
37
+ unsigned int _sizeLeft = (length); \
38
+ unsigned int _lanePosition = (offset)/SnP_laneLengthInBytes; \
39
+ unsigned int _offsetInLane = (offset)%SnP_laneLengthInBytes; \
40
+ const unsigned char *_curData = (data); \
41
+ while(_sizeLeft > 0) { \
42
+ unsigned int _bytesInLane = SnP_laneLengthInBytes - _offsetInLane; \
43
+ if (_bytesInLane > _sizeLeft) \
44
+ _bytesInLane = _sizeLeft; \
45
+ SnP_AddBytesInLane(state, _lanePosition, _curData, _offsetInLane, _bytesInLane); \
46
+ _sizeLeft -= _bytesInLane; \
47
+ _lanePosition++; \
48
+ _offsetInLane = 0; \
49
+ _curData += _bytesInLane; \
50
+ } \
51
+ } \
52
+ }
53
+
54
+ #define SnP_OverwriteBytes(state, data, offset, length, SnP_OverwriteLanes, SnP_OverwriteBytesInLane, SnP_laneLengthInBytes) \
55
+ { \
56
+ if ((offset) == 0) { \
57
+ SnP_OverwriteLanes(state, data, (length)/SnP_laneLengthInBytes); \
58
+ SnP_OverwriteBytesInLane(state, \
59
+ (length)/SnP_laneLengthInBytes, \
60
+ (data)+((length)/SnP_laneLengthInBytes)*SnP_laneLengthInBytes, \
61
+ 0, \
62
+ (length)%SnP_laneLengthInBytes); \
63
+ } \
64
+ else { \
65
+ unsigned int _sizeLeft = (length); \
66
+ unsigned int _lanePosition = (offset)/SnP_laneLengthInBytes; \
67
+ unsigned int _offsetInLane = (offset)%SnP_laneLengthInBytes; \
68
+ const unsigned char *_curData = (data); \
69
+ while(_sizeLeft > 0) { \
70
+ unsigned int _bytesInLane = SnP_laneLengthInBytes - _offsetInLane; \
71
+ if (_bytesInLane > _sizeLeft) \
72
+ _bytesInLane = _sizeLeft; \
73
+ SnP_OverwriteBytesInLane(state, _lanePosition, _curData, _offsetInLane, _bytesInLane); \
74
+ _sizeLeft -= _bytesInLane; \
75
+ _lanePosition++; \
76
+ _offsetInLane = 0; \
77
+ _curData += _bytesInLane; \
78
+ } \
79
+ } \
80
+ }
81
+
82
+ #define SnP_ExtractBytes(state, data, offset, length, SnP_ExtractLanes, SnP_ExtractBytesInLane, SnP_laneLengthInBytes) \
83
+ { \
84
+ if ((offset) == 0) { \
85
+ SnP_ExtractLanes(state, data, (length)/SnP_laneLengthInBytes); \
86
+ SnP_ExtractBytesInLane(state, \
87
+ (length)/SnP_laneLengthInBytes, \
88
+ (data)+((length)/SnP_laneLengthInBytes)*SnP_laneLengthInBytes, \
89
+ 0, \
90
+ (length)%SnP_laneLengthInBytes); \
91
+ } \
92
+ else { \
93
+ unsigned int _sizeLeft = (length); \
94
+ unsigned int _lanePosition = (offset)/SnP_laneLengthInBytes; \
95
+ unsigned int _offsetInLane = (offset)%SnP_laneLengthInBytes; \
96
+ unsigned char *_curData = (data); \
97
+ while(_sizeLeft > 0) { \
98
+ unsigned int _bytesInLane = SnP_laneLengthInBytes - _offsetInLane; \
99
+ if (_bytesInLane > _sizeLeft) \
100
+ _bytesInLane = _sizeLeft; \
101
+ SnP_ExtractBytesInLane(state, _lanePosition, _curData, _offsetInLane, _bytesInLane); \
102
+ _sizeLeft -= _bytesInLane; \
103
+ _lanePosition++; \
104
+ _offsetInLane = 0; \
105
+ _curData += _bytesInLane; \
106
+ } \
107
+ } \
108
+ }
109
+
110
+ #define SnP_ExtractAndAddBytes(state, input, output, offset, length, SnP_ExtractAndAddLanes, SnP_ExtractAndAddBytesInLane, SnP_laneLengthInBytes) \
111
+ { \
112
+ if ((offset) == 0) { \
113
+ SnP_ExtractAndAddLanes(state, input, output, (length)/SnP_laneLengthInBytes); \
114
+ SnP_ExtractAndAddBytesInLane(state, \
115
+ (length)/SnP_laneLengthInBytes, \
116
+ (input)+((length)/SnP_laneLengthInBytes)*SnP_laneLengthInBytes, \
117
+ (output)+((length)/SnP_laneLengthInBytes)*SnP_laneLengthInBytes, \
118
+ 0, \
119
+ (length)%SnP_laneLengthInBytes); \
120
+ } \
121
+ else { \
122
+ unsigned int _sizeLeft = (length); \
123
+ unsigned int _lanePosition = (offset)/SnP_laneLengthInBytes; \
124
+ unsigned int _offsetInLane = (offset)%SnP_laneLengthInBytes; \
125
+ const unsigned char *_curInput = (input); \
126
+ unsigned char *_curOutput = (output); \
127
+ while(_sizeLeft > 0) { \
128
+ unsigned int _bytesInLane = SnP_laneLengthInBytes - _offsetInLane; \
129
+ if (_bytesInLane > _sizeLeft) \
130
+ _bytesInLane = _sizeLeft; \
131
+ SnP_ExtractAndAddBytesInLane(state, _lanePosition, _curInput, _curOutput, _offsetInLane, _bytesInLane); \
132
+ _sizeLeft -= _bytesInLane; \
133
+ _lanePosition++; \
134
+ _offsetInLane = 0; \
135
+ _curInput += _bytesInLane; \
136
+ _curOutput += _bytesInLane; \
137
+ } \
138
+ } \
139
+ }
140
+
141
+ #endif
@@ -0,0 +1,79 @@
1
+ <?xml version='1.0' encoding="UTF-8"?>
2
+ <!--
3
+ The eXtended Keccak Code Package (XKCP)
4
+ https://github.com/XKCP/XKCP
5
+
6
+ Implementation by Gilles Van Assche, hereby denoted as "the implementer".
7
+
8
+ For more information, feedback or questions, please refer to the Keccak Team website:
9
+ https://keccak.team/
10
+
11
+ To the extent possible under law, the implementer has waived all copyright
12
+ and related or neighboring rights to the source code in this file.
13
+ http://creativecommons.org/publicdomain/zero/1.0/
14
+ -->
15
+ <xsl:stylesheet
16
+ xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
17
+ version='1.0'>
18
+
19
+ <xsl:template name="expand">
20
+ <xsl:param name="first"/>
21
+ <xsl:param name="second"/>
22
+ <xsl:param name="first-explored" select="''"/>
23
+ <xsl:param name="second-explored" select="''"/>
24
+ <xsl:param name="delimiter"/>
25
+ <xsl:variable name="first-cur" select="substring-before(concat($first, ' '), ' ')"/>
26
+ <xsl:variable name="first-rest" select="substring-after($first, ' ')"/>
27
+ <xsl:variable name="second-cur" select="substring-before(concat($second, ' '), ' ')"/>
28
+ <xsl:variable name="second-rest" select="substring-after($second, ' ')"/>
29
+
30
+ <xsl:if test="($first-cur!='') and ($second-cur!='')">
31
+ <target>
32
+ <xsl:attribute name="name"><xsl:value-of select="concat($first-cur, $delimiter, $second-cur)"/></xsl:attribute>
33
+ <xsl:attribute name="inherits"><xsl:value-of select="concat($first-cur, ' ', $second-cur)"/></xsl:attribute>
34
+ </target>
35
+
36
+ <xsl:choose>
37
+ <xsl:when test="normalize-space($second-rest)!=''">
38
+ <xsl:call-template name="expand">
39
+ <xsl:with-param name="first" select="$first"/>
40
+ <xsl:with-param name="first-explored" select="$first-explored"/>
41
+ <xsl:with-param name="second" select="$second-rest"/>
42
+ <xsl:with-param name="second-explored" select="normalize-space(concat($second-explored, ' ', $second-cur))"/>
43
+ <xsl:with-param name="delimiter" select="$delimiter"/>
44
+ </xsl:call-template>
45
+ </xsl:when>
46
+ <xsl:when test="normalize-space($first-rest)!=''">
47
+ <xsl:call-template name="expand">
48
+ <xsl:with-param name="first" select="$first-rest"/>
49
+ <xsl:with-param name="first-explored" select="normalize-space(concat($first-explored, ' ', $first-cur))"/>
50
+ <xsl:with-param name="second" select="normalize-space(concat($second-explored, ' ', $second-cur))"/>
51
+ <xsl:with-param name="second-explored" select="''"/>
52
+ <xsl:with-param name="delimiter" select="$delimiter"/>
53
+ </xsl:call-template>
54
+ </xsl:when>
55
+ </xsl:choose>
56
+ </xsl:if>
57
+ </xsl:template>
58
+
59
+ <xsl:template match="product">
60
+ <xsl:call-template name="expand">
61
+ <xsl:with-param name="first" select="normalize-space(factor[1]/@set)"/>
62
+ <xsl:with-param name="second" select="normalize-space(factor[2]/@set)"/>
63
+ <xsl:with-param name="delimiter">
64
+ <xsl:choose>
65
+ <xsl:when test="@delimiter!=''"><xsl:value-of select="@delimiter"/></xsl:when>
66
+ <xsl:otherwise>+</xsl:otherwise>
67
+ </xsl:choose>
68
+ </xsl:with-param>
69
+ </xsl:call-template>
70
+ </xsl:template>
71
+
72
+ <xsl:template match="*">
73
+ <xsl:copy>
74
+ <xsl:copy-of select="@*"/>
75
+ <xsl:apply-templates/>
76
+ </xsl:copy>
77
+ </xsl:template>
78
+
79
+ </xsl:stylesheet>