@leocuvee/wrkzcoin-multi-hashing 0.0.20

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 (314) hide show
  1. package/.travis.yml +5 -0
  2. package/LICENSE +674 -0
  3. package/README.md +87 -0
  4. package/appveyor.yml +12 -0
  5. package/argon2/.gitattributes +10 -0
  6. package/argon2/.travis.yml +25 -0
  7. package/argon2/Argon2.sln +160 -0
  8. package/argon2/CHANGELOG.md +32 -0
  9. package/argon2/CMakeLists.txt +87 -0
  10. package/argon2/LICENSE +314 -0
  11. package/argon2/Makefile +196 -0
  12. package/argon2/README.md +297 -0
  13. package/argon2/appveyor.yml +40 -0
  14. package/argon2/argon2-specs.pdf +0 -0
  15. package/argon2/export.sh +7 -0
  16. package/argon2/include/argon2.h +427 -0
  17. package/argon2/latex/CMakeLists.txt +34 -0
  18. package/argon2/latex/IEEEtran.cls +6347 -0
  19. package/argon2/latex/Makefile +18 -0
  20. package/argon2/latex/argon2-specs.tex +920 -0
  21. package/argon2/latex/pics/argon2-par.pdf +0 -0
  22. package/argon2/latex/pics/compression.pdf +0 -0
  23. package/argon2/latex/pics/generic.pdf +0 -0
  24. package/argon2/latex/pics/power-distribution.jpg +0 -0
  25. package/argon2/latex/tradeoff.bib +822 -0
  26. package/argon2/libargon2.pc +16 -0
  27. package/argon2/man/CMakeLists.txt +8 -0
  28. package/argon2/man/argon2.1 +57 -0
  29. package/argon2/meson.build +16 -0
  30. package/argon2/meson_options.txt +1 -0
  31. package/argon2/src/CMakeLists.txt +147 -0
  32. package/argon2/src/argon2.c +452 -0
  33. package/argon2/src/argon2.pc.in +11 -0
  34. package/argon2/src/blake2/blake2-impl.h +156 -0
  35. package/argon2/src/blake2/blake2.h +89 -0
  36. package/argon2/src/blake2/blake2b.c +390 -0
  37. package/argon2/src/blake2/blamka-round-opt.h +471 -0
  38. package/argon2/src/blake2/blamka-round-ref.h +56 -0
  39. package/argon2/src/core.c +634 -0
  40. package/argon2/src/core.h +228 -0
  41. package/argon2/src/encoding.c +467 -0
  42. package/argon2/src/encoding.h +57 -0
  43. package/argon2/src/genkat.h +51 -0
  44. package/argon2/src/meson.build +68 -0
  45. package/argon2/src/opt.c +283 -0
  46. package/argon2/src/optimization/CMakeLists.txt +10 -0
  47. package/argon2/src/ref.c +194 -0
  48. package/argon2/src/thread.c +57 -0
  49. package/argon2/src/thread.h +67 -0
  50. package/argon2/tests/CMakeLists.txt +43 -0
  51. package/argon2/tests/bench.c +111 -0
  52. package/argon2/tests/genkat.c +207 -0
  53. package/argon2/tests/kats/argon2d +12304 -0
  54. package/argon2/tests/kats/argon2d.shasum +1 -0
  55. package/argon2/tests/kats/argon2d_v16 +12304 -0
  56. package/argon2/tests/kats/argon2d_v16.shasum +1 -0
  57. package/argon2/tests/kats/argon2i +12304 -0
  58. package/argon2/tests/kats/argon2i.shasum +1 -0
  59. package/argon2/tests/kats/argon2i_v16 +12304 -0
  60. package/argon2/tests/kats/argon2i_v16.shasum +1 -0
  61. package/argon2/tests/kats/argon2id +12304 -0
  62. package/argon2/tests/kats/argon2id.shasum +1 -0
  63. package/argon2/tests/kats/argon2id_v16 +12304 -0
  64. package/argon2/tests/kats/argon2id_v16.shasum +1 -0
  65. package/argon2/tests/kats/check-sums.ps1 +48 -0
  66. package/argon2/tests/kats/check-sums.sh +16 -0
  67. package/argon2/tests/kats/test.ps1 +132 -0
  68. package/argon2/tests/kats/test.sh +117 -0
  69. package/argon2/tests/meson.build +34 -0
  70. package/argon2/tests/test.c +289 -0
  71. package/argon2/tool/CMakeLists.txt +7 -0
  72. package/argon2/tool/main.c +339 -0
  73. package/argon2/tool/meson.build +8 -0
  74. package/argon2/vs2015/Argon2Opt/Argon2Opt.vcxproj +226 -0
  75. package/argon2/vs2015/Argon2Opt/Argon2Opt.vcxproj.filters +69 -0
  76. package/argon2/vs2015/Argon2OptBench/Argon2OptBench.vcxproj +226 -0
  77. package/argon2/vs2015/Argon2OptBench/Argon2OptBench.vcxproj.filters +69 -0
  78. package/argon2/vs2015/Argon2OptDll/Argon2OptDll.vcxproj +225 -0
  79. package/argon2/vs2015/Argon2OptDll/Argon2OptDll.vcxproj.filters +66 -0
  80. package/argon2/vs2015/Argon2OptGenKAT/Argon2OptGenKAT.vcxproj +239 -0
  81. package/argon2/vs2015/Argon2OptGenKAT/Argon2OptGenKAT.vcxproj.filters +72 -0
  82. package/argon2/vs2015/Argon2OptTestCI/Argon2OptTestCI.vcxproj +227 -0
  83. package/argon2/vs2015/Argon2OptTestCI/Argon2OptTestCI.vcxproj.filters +69 -0
  84. package/argon2/vs2015/Argon2Ref/Argon2Ref.vcxproj +226 -0
  85. package/argon2/vs2015/Argon2Ref/Argon2Ref.vcxproj.filters +69 -0
  86. package/argon2/vs2015/Argon2RefBench/Argon2RefBench.vcxproj +226 -0
  87. package/argon2/vs2015/Argon2RefBench/Argon2RefBench.vcxproj.filters +69 -0
  88. package/argon2/vs2015/Argon2RefDll/Argon2RefDll.vcxproj +225 -0
  89. package/argon2/vs2015/Argon2RefDll/Argon2RefDll.vcxproj.filters +66 -0
  90. package/argon2/vs2015/Argon2RefGenKAT/Argon2RefGenKAT.vcxproj +227 -0
  91. package/argon2/vs2015/Argon2RefGenKAT/Argon2RefGenKAT.vcxproj.filters +72 -0
  92. package/argon2/vs2015/Argon2RefTestCI/Argon2RefTestCI.vcxproj +226 -0
  93. package/argon2/vs2015/Argon2RefTestCI/Argon2RefTestCI.vcxproj.filters +69 -0
  94. package/bcrypt.c +566 -0
  95. package/bcrypt.h +14 -0
  96. package/binding.gyp +93 -0
  97. package/blake.c +17 -0
  98. package/blake.h +16 -0
  99. package/boolberry.cc +11 -0
  100. package/boolberry.h +6 -0
  101. package/build/Makefile +354 -0
  102. package/build/Release/.deps/Release/multihashing.node.d +1 -0
  103. package/build/Release/.deps/Release/obj.target/multihashing/argon2/src/argon2.o.d +8 -0
  104. package/build/Release/.deps/Release/obj.target/multihashing/argon2/src/blake2/blake2b.o.d +8 -0
  105. package/build/Release/.deps/Release/obj.target/multihashing/argon2/src/core.o.d +10 -0
  106. package/build/Release/.deps/Release/obj.target/multihashing/argon2/src/encoding.o.d +8 -0
  107. package/build/Release/.deps/Release/obj.target/multihashing/argon2/src/ref.o.d +14 -0
  108. package/build/Release/.deps/Release/obj.target/multihashing/argon2/src/thread.o.d +5 -0
  109. package/build/Release/.deps/Release/obj.target/multihashing/bcrypt.o.d +4 -0
  110. package/build/Release/.deps/Release/obj.target/multihashing/blake.o.d +7 -0
  111. package/build/Release/.deps/Release/obj.target/multihashing/boolberry.o.d +12 -0
  112. package/build/Release/.deps/Release/obj.target/multihashing/c11.o.d +20 -0
  113. package/build/Release/.deps/Release/obj.target/multihashing/crypto/aesb.o.d +3 -0
  114. package/build/Release/.deps/Release/obj.target/multihashing/crypto/c_blake256.o.d +5 -0
  115. package/build/Release/.deps/Release/obj.target/multihashing/crypto/c_groestl.o.d +10 -0
  116. package/build/Release/.deps/Release/obj.target/multihashing/crypto/c_jh.o.d +9 -0
  117. package/build/Release/.deps/Release/obj.target/multihashing/crypto/c_keccak.o.d +7 -0
  118. package/build/Release/.deps/Release/obj.target/multihashing/crypto/c_skein.o.d +10 -0
  119. package/build/Release/.deps/Release/obj.target/multihashing/crypto/hash.o.d +7 -0
  120. package/build/Release/.deps/Release/obj.target/multihashing/crypto/oaes_lib.o.d +6 -0
  121. package/build/Release/.deps/Release/obj.target/multihashing/crypto/wild_keccak.o.d +8 -0
  122. package/build/Release/.deps/Release/obj.target/multihashing/cryptonight.o.d +18 -0
  123. package/build/Release/.deps/Release/obj.target/multihashing/cryptonight_dark.o.d +18 -0
  124. package/build/Release/.deps/Release/obj.target/multihashing/cryptonight_dark_lite.o.d +18 -0
  125. package/build/Release/.deps/Release/obj.target/multihashing/cryptonight_fast.o.d +18 -0
  126. package/build/Release/.deps/Release/obj.target/multihashing/cryptonight_lite.o.d +18 -0
  127. package/build/Release/.deps/Release/obj.target/multihashing/cryptonight_soft_shell.o.d +18 -0
  128. package/build/Release/.deps/Release/obj.target/multihashing/cryptonight_turtle.o.d +18 -0
  129. package/build/Release/.deps/Release/obj.target/multihashing/cryptonight_turtle_lite.o.d +18 -0
  130. package/build/Release/.deps/Release/obj.target/multihashing/fresh.o.d +10 -0
  131. package/build/Release/.deps/Release/obj.target/multihashing/fugue.o.d +7 -0
  132. package/build/Release/.deps/Release/obj.target/multihashing/groestl.o.d +8 -0
  133. package/build/Release/.deps/Release/obj.target/multihashing/hefty1.o.d +12 -0
  134. package/build/Release/.deps/Release/obj.target/multihashing/keccak.o.d +8 -0
  135. package/build/Release/.deps/Release/obj.target/multihashing/multihashing.o.d +155 -0
  136. package/build/Release/.deps/Release/obj.target/multihashing/nist5.o.d +12 -0
  137. package/build/Release/.deps/Release/obj.target/multihashing/quark.o.d +14 -0
  138. package/build/Release/.deps/Release/obj.target/multihashing/qubit.o.d +12 -0
  139. package/build/Release/.deps/Release/obj.target/multihashing/scryptjane.o.d +30 -0
  140. package/build/Release/.deps/Release/obj.target/multihashing/scryptn.o.d +6 -0
  141. package/build/Release/.deps/Release/obj.target/multihashing/sha1.o.d +24 -0
  142. package/build/Release/.deps/Release/obj.target/multihashing/sha3/aes_helper.o.d +5 -0
  143. package/build/Release/.deps/Release/obj.target/multihashing/sha3/hamsi.o.d +7 -0
  144. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_blake.o.d +6 -0
  145. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_bmw.o.d +6 -0
  146. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_cubehash.o.d +6 -0
  147. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_echo.o.d +7 -0
  148. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_fugue.o.d +6 -0
  149. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_groestl.o.d +6 -0
  150. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_hefty1.o.d +5 -0
  151. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_jh.o.d +6 -0
  152. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_keccak.o.d +6 -0
  153. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_luffa.o.d +6 -0
  154. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_shabal.o.d +6 -0
  155. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_shavite.o.d +7 -0
  156. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_simd.o.d +6 -0
  157. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_skein.o.d +6 -0
  158. package/build/Release/.deps/Release/obj.target/multihashing/sha3/sph_whirlpool.o.d +8 -0
  159. package/build/Release/.deps/Release/obj.target/multihashing/shavite3.o.d +7 -0
  160. package/build/Release/.deps/Release/obj.target/multihashing/skein.o.d +8 -0
  161. package/build/Release/.deps/Release/obj.target/multihashing/x11.o.d +20 -0
  162. package/build/Release/.deps/Release/obj.target/multihashing/x13.o.d +23 -0
  163. package/build/Release/.deps/Release/obj.target/multihashing/x15.o.d +26 -0
  164. package/build/Release/.deps/Release/obj.target/multihashing.node.d +1 -0
  165. package/build/Release/multihashing.node +0 -0
  166. package/build/binding.Makefile +6 -0
  167. package/build/multihashing.target.mk +255 -0
  168. package/c11.c +85 -0
  169. package/c11.h +17 -0
  170. package/crypto/aesb.c +177 -0
  171. package/crypto/c_blake256.c +326 -0
  172. package/crypto/c_blake256.h +43 -0
  173. package/crypto/c_groestl.c +360 -0
  174. package/crypto/c_groestl.h +56 -0
  175. package/crypto/c_jh.c +367 -0
  176. package/crypto/c_jh.h +20 -0
  177. package/crypto/c_keccak.c +112 -0
  178. package/crypto/c_keccak.h +26 -0
  179. package/crypto/c_skein.c +2036 -0
  180. package/crypto/c_skein.h +45 -0
  181. package/crypto/crypto.h +186 -0
  182. package/crypto/cryptonote_core/account.cpp +50 -0
  183. package/crypto/cryptonote_core/account.h +61 -0
  184. package/crypto/cryptonote_core/cryptonote_basic_impl.cpp +186 -0
  185. package/crypto/cryptonote_core/cryptonote_basic_impl.h +65 -0
  186. package/crypto/cryptonote_core/cryptonote_format_utils.cpp +766 -0
  187. package/crypto/cryptonote_core/cryptonote_format_utils.h +30 -0
  188. package/crypto/cryptonote_protocol/cryptonote_protocol_defs.h +152 -0
  189. package/crypto/groestl_tables.h +38 -0
  190. package/crypto/hash-ops.h +57 -0
  191. package/crypto/hash.c +24 -0
  192. package/crypto/hash.h +22 -0
  193. package/crypto/int-util.h +230 -0
  194. package/crypto/oaes_config.h +50 -0
  195. package/crypto/oaes_lib.c +1468 -0
  196. package/crypto/oaes_lib.h +215 -0
  197. package/crypto/skein_port.h +190 -0
  198. package/crypto/variant2_int_sqrt.h +168 -0
  199. package/crypto/wild_keccak.cpp +119 -0
  200. package/crypto/wild_keccak.h +168 -0
  201. package/cryptonight.c +300 -0
  202. package/cryptonight.h +17 -0
  203. package/cryptonight_dark.c +300 -0
  204. package/cryptonight_dark.h +17 -0
  205. package/cryptonight_dark_lite.c +300 -0
  206. package/cryptonight_dark_lite.h +17 -0
  207. package/cryptonight_fast.c +300 -0
  208. package/cryptonight_fast.h +17 -0
  209. package/cryptonight_lite.c +300 -0
  210. package/cryptonight_lite.h +17 -0
  211. package/cryptonight_soft_shell.c +298 -0
  212. package/cryptonight_soft_shell.h +17 -0
  213. package/cryptonight_turtle.c +300 -0
  214. package/cryptonight_turtle.h +17 -0
  215. package/cryptonight_turtle_lite.c +300 -0
  216. package/cryptonight_turtle_lite.h +17 -0
  217. package/fresh.c +42 -0
  218. package/fresh.h +16 -0
  219. package/fugue.c +12 -0
  220. package/fugue.h +16 -0
  221. package/groestl.c +40 -0
  222. package/groestl.h +17 -0
  223. package/hefty1.c +63 -0
  224. package/hefty1.h +16 -0
  225. package/index.js +1 -0
  226. package/keccak.c +14 -0
  227. package/keccak.h +16 -0
  228. package/leocuvee-wrkzcoin-multi-hashing-0.0.20.tgz +0 -0
  229. package/multihashing.cc +699 -0
  230. package/nist5.c +46 -0
  231. package/nist5.h +16 -0
  232. package/package.json +56 -0
  233. package/quark.c +210 -0
  234. package/quark.h +16 -0
  235. package/qubit.c +45 -0
  236. package/qubit.h +16 -0
  237. package/scryptjane/scrypt-jane-chacha.h +132 -0
  238. package/scryptjane/scrypt-jane-hash.h +48 -0
  239. package/scryptjane/scrypt-jane-hash_keccak.h +168 -0
  240. package/scryptjane/scrypt-jane-hash_sha256.h +135 -0
  241. package/scryptjane/scrypt-jane-mix_chacha-avx.h +340 -0
  242. package/scryptjane/scrypt-jane-mix_chacha-sse2.h +371 -0
  243. package/scryptjane/scrypt-jane-mix_chacha-ssse3.h +348 -0
  244. package/scryptjane/scrypt-jane-mix_chacha.h +69 -0
  245. package/scryptjane/scrypt-jane-mix_salsa-avx.h +381 -0
  246. package/scryptjane/scrypt-jane-mix_salsa-sse2.h +443 -0
  247. package/scryptjane/scrypt-jane-mix_salsa.h +70 -0
  248. package/scryptjane/scrypt-jane-pbkdf2.h +112 -0
  249. package/scryptjane/scrypt-jane-portable-x86.h +364 -0
  250. package/scryptjane/scrypt-jane-portable.h +281 -0
  251. package/scryptjane/scrypt-jane-romix-basic.h +67 -0
  252. package/scryptjane/scrypt-jane-romix-template.h +118 -0
  253. package/scryptjane/scrypt-jane-romix.h +27 -0
  254. package/scryptjane/scrypt-jane-salsa.h +106 -0
  255. package/scryptjane/scrypt-jane-test-vectors.h +261 -0
  256. package/scryptjane.c +223 -0
  257. package/scryptjane.h +36 -0
  258. package/scryptn.c +258 -0
  259. package/scryptn.h +16 -0
  260. package/sha1.c +65 -0
  261. package/sha1.h +16 -0
  262. package/sha256.h +440 -0
  263. package/sha3/aes_helper.c +392 -0
  264. package/sha3/hamsi.c +867 -0
  265. package/sha3/hamsi_helper.c +39648 -0
  266. package/sha3/md_helper.c +347 -0
  267. package/sha3/sph_blake.c +1114 -0
  268. package/sha3/sph_blake.h +327 -0
  269. package/sha3/sph_bmw.c +965 -0
  270. package/sha3/sph_bmw.h +328 -0
  271. package/sha3/sph_cubehash.c +723 -0
  272. package/sha3/sph_cubehash.h +292 -0
  273. package/sha3/sph_echo.c +1031 -0
  274. package/sha3/sph_echo.h +320 -0
  275. package/sha3/sph_fugue.c +1208 -0
  276. package/sha3/sph_fugue.h +81 -0
  277. package/sha3/sph_groestl.c +3119 -0
  278. package/sha3/sph_groestl.h +329 -0
  279. package/sha3/sph_hamsi.h +321 -0
  280. package/sha3/sph_hefty1.c +378 -0
  281. package/sha3/sph_hefty1.h +66 -0
  282. package/sha3/sph_jh.c +1116 -0
  283. package/sha3/sph_jh.h +298 -0
  284. package/sha3/sph_keccak.c +1824 -0
  285. package/sha3/sph_keccak.h +293 -0
  286. package/sha3/sph_luffa.c +1426 -0
  287. package/sha3/sph_luffa.h +296 -0
  288. package/sha3/sph_shabal.c +806 -0
  289. package/sha3/sph_shabal.h +344 -0
  290. package/sha3/sph_shavite.c +1764 -0
  291. package/sha3/sph_shavite.h +314 -0
  292. package/sha3/sph_simd.c +1799 -0
  293. package/sha3/sph_simd.h +309 -0
  294. package/sha3/sph_skein.c +1254 -0
  295. package/sha3/sph_skein.h +298 -0
  296. package/sha3/sph_types.h +1976 -0
  297. package/sha3/sph_whirlpool.c +3480 -0
  298. package/sha3/sph_whirlpool.h +209 -0
  299. package/shavite3.c +24 -0
  300. package/shavite3.h +16 -0
  301. package/skein.c +26 -0
  302. package/skein.h +16 -0
  303. package/stdint.h +259 -0
  304. package/tests/argon2-tests.js +16 -0
  305. package/tests/benchmark.js +36 -0
  306. package/tests/cryptonight-tests.js +189 -0
  307. package/tests/cryptonight_monero.js +53 -0
  308. package/tests/test.js +16 -0
  309. package/x11.c +85 -0
  310. package/x11.h +16 -0
  311. package/x13.c +97 -0
  312. package/x13.h +5 -0
  313. package/x15.c +106 -0
  314. package/x15.h +16 -0
@@ -0,0 +1,298 @@
1
+ /* $Id: sph_skein.h 253 2011-06-07 18:33:10Z tp $ */
2
+ /**
3
+ * Skein interface. The Skein specification defines three main
4
+ * functions, called Skein-256, Skein-512 and Skein-1024, which can be
5
+ * further parameterized with an output length. For the SHA-3
6
+ * competition, Skein-512 is used for output sizes of 224, 256, 384 and
7
+ * 512 bits; this is what this code implements. Thus, we hereafter call
8
+ * Skein-224, Skein-256, Skein-384 and Skein-512 what the Skein
9
+ * specification defines as Skein-512-224, Skein-512-256, Skein-512-384
10
+ * and Skein-512-512, respectively.
11
+ *
12
+ * ==========================(LICENSE BEGIN)============================
13
+ *
14
+ * Copyright (c) 2007-2010 Projet RNRT SAPHIR
15
+ *
16
+ * Permission is hereby granted, free of charge, to any person obtaining
17
+ * a copy of this software and associated documentation files (the
18
+ * "Software"), to deal in the Software without restriction, including
19
+ * without limitation the rights to use, copy, modify, merge, publish,
20
+ * distribute, sublicense, and/or sell copies of the Software, and to
21
+ * permit persons to whom the Software is furnished to do so, subject to
22
+ * the following conditions:
23
+ *
24
+ * The above copyright notice and this permission notice shall be
25
+ * included in all copies or substantial portions of the Software.
26
+ *
27
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
28
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
29
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
30
+ * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
31
+ * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
32
+ * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
33
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
34
+ *
35
+ * ===========================(LICENSE END)=============================
36
+ *
37
+ * @file sph_skein.h
38
+ * @author Thomas Pornin <thomas.pornin@cryptolog.com>
39
+ */
40
+
41
+ #ifndef SPH_SKEIN_H__
42
+ #define SPH_SKEIN_H__
43
+
44
+ #ifdef __cplusplus
45
+ extern "C"{
46
+ #endif
47
+
48
+ #include <stddef.h>
49
+ #include "sph_types.h"
50
+
51
+ #if SPH_64
52
+
53
+ /**
54
+ * Output size (in bits) for Skein-224.
55
+ */
56
+ #define SPH_SIZE_skein224 224
57
+
58
+ /**
59
+ * Output size (in bits) for Skein-256.
60
+ */
61
+ #define SPH_SIZE_skein256 256
62
+
63
+ /**
64
+ * Output size (in bits) for Skein-384.
65
+ */
66
+ #define SPH_SIZE_skein384 384
67
+
68
+ /**
69
+ * Output size (in bits) for Skein-512.
70
+ */
71
+ #define SPH_SIZE_skein512 512
72
+
73
+ /**
74
+ * This structure is a context for Skein computations (with a 384- or
75
+ * 512-bit output): it contains the intermediate values and some data
76
+ * from the last entered block. Once a Skein computation has been
77
+ * performed, the context can be reused for another computation.
78
+ *
79
+ * The contents of this structure are private. A running Skein computation
80
+ * can be cloned by copying the context (e.g. with a simple
81
+ * <code>memcpy()</code>).
82
+ */
83
+ typedef struct {
84
+ #ifndef DOXYGEN_IGNORE
85
+ unsigned char buf[64]; /* first field, for alignment */
86
+ size_t ptr;
87
+ sph_u64 h0, h1, h2, h3, h4, h5, h6, h7;
88
+ sph_u64 bcount;
89
+ #endif
90
+ } sph_skein_big_context;
91
+
92
+ /**
93
+ * Type for a Skein-224 context (identical to the common "big" context).
94
+ */
95
+ typedef sph_skein_big_context sph_skein224_context;
96
+
97
+ /**
98
+ * Type for a Skein-256 context (identical to the common "big" context).
99
+ */
100
+ typedef sph_skein_big_context sph_skein256_context;
101
+
102
+ /**
103
+ * Type for a Skein-384 context (identical to the common "big" context).
104
+ */
105
+ typedef sph_skein_big_context sph_skein384_context;
106
+
107
+ /**
108
+ * Type for a Skein-512 context (identical to the common "big" context).
109
+ */
110
+ typedef sph_skein_big_context sph_skein512_context;
111
+
112
+ /**
113
+ * Initialize a Skein-224 context. This process performs no memory allocation.
114
+ *
115
+ * @param cc the Skein-224 context (pointer to a
116
+ * <code>sph_skein224_context</code>)
117
+ */
118
+ void sph_skein224_init(void *cc);
119
+
120
+ /**
121
+ * Process some data bytes. It is acceptable that <code>len</code> is zero
122
+ * (in which case this function does nothing).
123
+ *
124
+ * @param cc the Skein-224 context
125
+ * @param data the input data
126
+ * @param len the input data length (in bytes)
127
+ */
128
+ void sph_skein224(void *cc, const void *data, size_t len);
129
+
130
+ /**
131
+ * Terminate the current Skein-224 computation and output the result into
132
+ * the provided buffer. The destination buffer must be wide enough to
133
+ * accomodate the result (28 bytes). The context is automatically
134
+ * reinitialized.
135
+ *
136
+ * @param cc the Skein-224 context
137
+ * @param dst the destination buffer
138
+ */
139
+ void sph_skein224_close(void *cc, void *dst);
140
+
141
+ /**
142
+ * Add a few additional bits (0 to 7) to the current computation, then
143
+ * terminate it and output the result in the provided buffer, which must
144
+ * be wide enough to accomodate the result (28 bytes). If bit number i
145
+ * in <code>ub</code> has value 2^i, then the extra bits are those
146
+ * numbered 7 downto 8-n (this is the big-endian convention at the byte
147
+ * level). The context is automatically reinitialized.
148
+ *
149
+ * @param cc the Skein-224 context
150
+ * @param ub the extra bits
151
+ * @param n the number of extra bits (0 to 7)
152
+ * @param dst the destination buffer
153
+ */
154
+ void sph_skein224_addbits_and_close(
155
+ void *cc, unsigned ub, unsigned n, void *dst);
156
+
157
+ /**
158
+ * Initialize a Skein-256 context. This process performs no memory allocation.
159
+ *
160
+ * @param cc the Skein-256 context (pointer to a
161
+ * <code>sph_skein256_context</code>)
162
+ */
163
+ void sph_skein256_init(void *cc);
164
+
165
+ /**
166
+ * Process some data bytes. It is acceptable that <code>len</code> is zero
167
+ * (in which case this function does nothing).
168
+ *
169
+ * @param cc the Skein-256 context
170
+ * @param data the input data
171
+ * @param len the input data length (in bytes)
172
+ */
173
+ void sph_skein256(void *cc, const void *data, size_t len);
174
+
175
+ /**
176
+ * Terminate the current Skein-256 computation and output the result into
177
+ * the provided buffer. The destination buffer must be wide enough to
178
+ * accomodate the result (32 bytes). The context is automatically
179
+ * reinitialized.
180
+ *
181
+ * @param cc the Skein-256 context
182
+ * @param dst the destination buffer
183
+ */
184
+ void sph_skein256_close(void *cc, void *dst);
185
+
186
+ /**
187
+ * Add a few additional bits (0 to 7) to the current computation, then
188
+ * terminate it and output the result in the provided buffer, which must
189
+ * be wide enough to accomodate the result (32 bytes). If bit number i
190
+ * in <code>ub</code> has value 2^i, then the extra bits are those
191
+ * numbered 7 downto 8-n (this is the big-endian convention at the byte
192
+ * level). The context is automatically reinitialized.
193
+ *
194
+ * @param cc the Skein-256 context
195
+ * @param ub the extra bits
196
+ * @param n the number of extra bits (0 to 7)
197
+ * @param dst the destination buffer
198
+ */
199
+ void sph_skein256_addbits_and_close(
200
+ void *cc, unsigned ub, unsigned n, void *dst);
201
+
202
+ /**
203
+ * Initialize a Skein-384 context. This process performs no memory allocation.
204
+ *
205
+ * @param cc the Skein-384 context (pointer to a
206
+ * <code>sph_skein384_context</code>)
207
+ */
208
+ void sph_skein384_init(void *cc);
209
+
210
+ /**
211
+ * Process some data bytes. It is acceptable that <code>len</code> is zero
212
+ * (in which case this function does nothing).
213
+ *
214
+ * @param cc the Skein-384 context
215
+ * @param data the input data
216
+ * @param len the input data length (in bytes)
217
+ */
218
+ void sph_skein384(void *cc, const void *data, size_t len);
219
+
220
+ /**
221
+ * Terminate the current Skein-384 computation and output the result into
222
+ * the provided buffer. The destination buffer must be wide enough to
223
+ * accomodate the result (48 bytes). The context is automatically
224
+ * reinitialized.
225
+ *
226
+ * @param cc the Skein-384 context
227
+ * @param dst the destination buffer
228
+ */
229
+ void sph_skein384_close(void *cc, void *dst);
230
+
231
+ /**
232
+ * Add a few additional bits (0 to 7) to the current computation, then
233
+ * terminate it and output the result in the provided buffer, which must
234
+ * be wide enough to accomodate the result (48 bytes). If bit number i
235
+ * in <code>ub</code> has value 2^i, then the extra bits are those
236
+ * numbered 7 downto 8-n (this is the big-endian convention at the byte
237
+ * level). The context is automatically reinitialized.
238
+ *
239
+ * @param cc the Skein-384 context
240
+ * @param ub the extra bits
241
+ * @param n the number of extra bits (0 to 7)
242
+ * @param dst the destination buffer
243
+ */
244
+ void sph_skein384_addbits_and_close(
245
+ void *cc, unsigned ub, unsigned n, void *dst);
246
+
247
+ /**
248
+ * Initialize a Skein-512 context. This process performs no memory allocation.
249
+ *
250
+ * @param cc the Skein-512 context (pointer to a
251
+ * <code>sph_skein512_context</code>)
252
+ */
253
+ void sph_skein512_init(void *cc);
254
+
255
+ /**
256
+ * Process some data bytes. It is acceptable that <code>len</code> is zero
257
+ * (in which case this function does nothing).
258
+ *
259
+ * @param cc the Skein-512 context
260
+ * @param data the input data
261
+ * @param len the input data length (in bytes)
262
+ */
263
+ void sph_skein512(void *cc, const void *data, size_t len);
264
+
265
+ /**
266
+ * Terminate the current Skein-512 computation and output the result into
267
+ * the provided buffer. The destination buffer must be wide enough to
268
+ * accomodate the result (64 bytes). The context is automatically
269
+ * reinitialized.
270
+ *
271
+ * @param cc the Skein-512 context
272
+ * @param dst the destination buffer
273
+ */
274
+ void sph_skein512_close(void *cc, void *dst);
275
+
276
+ /**
277
+ * Add a few additional bits (0 to 7) to the current computation, then
278
+ * terminate it and output the result in the provided buffer, which must
279
+ * be wide enough to accomodate the result (64 bytes). If bit number i
280
+ * in <code>ub</code> has value 2^i, then the extra bits are those
281
+ * numbered 7 downto 8-n (this is the big-endian convention at the byte
282
+ * level). The context is automatically reinitialized.
283
+ *
284
+ * @param cc the Skein-512 context
285
+ * @param ub the extra bits
286
+ * @param n the number of extra bits (0 to 7)
287
+ * @param dst the destination buffer
288
+ */
289
+ void sph_skein512_addbits_and_close(
290
+ void *cc, unsigned ub, unsigned n, void *dst);
291
+
292
+ #endif
293
+
294
+ #ifdef __cplusplus
295
+ }
296
+ #endif
297
+
298
+ #endif