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.
- checksums.yaml +7 -0
- data/README.md +127 -0
- data/ext/Rakefile +73 -0
- data/ext/binding/sleeping_kangaroo12.c +39 -0
- data/ext/config/xkcp.build +17 -0
- data/ext/xkcp/LICENSE +1 -0
- data/ext/xkcp/Makefile +15 -0
- data/ext/xkcp/Makefile.build +200 -0
- data/ext/xkcp/README.markdown +296 -0
- data/ext/xkcp/lib/HighLevel.build +143 -0
- data/ext/xkcp/lib/LowLevel.build +757 -0
- data/ext/xkcp/lib/common/align.h +33 -0
- data/ext/xkcp/lib/common/brg_endian.h +143 -0
- data/ext/xkcp/lib/high/KangarooTwelve/KangarooTwelve.c +301 -0
- data/ext/xkcp/lib/high/KangarooTwelve/KangarooTwelve.h +97 -0
- data/ext/xkcp/lib/high/Keccak/FIPS202/KeccakHash.c +81 -0
- data/ext/xkcp/lib/high/Keccak/FIPS202/KeccakHash.h +125 -0
- data/ext/xkcp/lib/high/Keccak/FIPS202/SimpleFIPS202.c +48 -0
- data/ext/xkcp/lib/high/Keccak/FIPS202/SimpleFIPS202.h +79 -0
- data/ext/xkcp/lib/high/Keccak/KeccakDuplex.c +81 -0
- data/ext/xkcp/lib/high/Keccak/KeccakDuplex.h +73 -0
- data/ext/xkcp/lib/high/Keccak/KeccakDuplex.inc +195 -0
- data/ext/xkcp/lib/high/Keccak/KeccakSponge.c +111 -0
- data/ext/xkcp/lib/high/Keccak/KeccakSponge.h +76 -0
- data/ext/xkcp/lib/high/Keccak/KeccakSponge.inc +314 -0
- data/ext/xkcp/lib/high/Keccak/PRG/KeccakPRG.c +61 -0
- data/ext/xkcp/lib/high/Keccak/PRG/KeccakPRG.h +67 -0
- data/ext/xkcp/lib/high/Keccak/PRG/KeccakPRG.inc +128 -0
- data/ext/xkcp/lib/high/Keccak/SP800-185/SP800-185.c +93 -0
- data/ext/xkcp/lib/high/Keccak/SP800-185/SP800-185.h +599 -0
- data/ext/xkcp/lib/high/Keccak/SP800-185/SP800-185.inc +573 -0
- data/ext/xkcp/lib/high/Ketje/Ketjev2.c +87 -0
- data/ext/xkcp/lib/high/Ketje/Ketjev2.h +88 -0
- data/ext/xkcp/lib/high/Ketje/Ketjev2.inc +274 -0
- data/ext/xkcp/lib/high/Keyak/Keyakv2.c +132 -0
- data/ext/xkcp/lib/high/Keyak/Keyakv2.h +217 -0
- data/ext/xkcp/lib/high/Keyak/Keyakv2.inc +81 -0
- data/ext/xkcp/lib/high/Keyak/Motorist.inc +953 -0
- data/ext/xkcp/lib/high/Kravatte/Kravatte.c +533 -0
- data/ext/xkcp/lib/high/Kravatte/Kravatte.h +115 -0
- data/ext/xkcp/lib/high/Kravatte/KravatteModes.c +557 -0
- data/ext/xkcp/lib/high/Kravatte/KravatteModes.h +247 -0
- data/ext/xkcp/lib/high/Xoodyak/Cyclist.h +66 -0
- data/ext/xkcp/lib/high/Xoodyak/Cyclist.inc +336 -0
- data/ext/xkcp/lib/high/Xoodyak/Xoodyak-parameters.h +26 -0
- data/ext/xkcp/lib/high/Xoodyak/Xoodyak.c +55 -0
- data/ext/xkcp/lib/high/Xoodyak/Xoodyak.h +35 -0
- data/ext/xkcp/lib/high/Xoofff/Xoofff.c +634 -0
- data/ext/xkcp/lib/high/Xoofff/Xoofff.h +147 -0
- data/ext/xkcp/lib/high/Xoofff/XoofffModes.c +483 -0
- data/ext/xkcp/lib/high/Xoofff/XoofffModes.h +241 -0
- data/ext/xkcp/lib/high/common/Phases.h +25 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-SnP.h +41 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv6m-le-armcc.s +1666 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv6m-le-gcc.s +1655 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv7a-le-armcc.s +1268 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv7a-le-gcc.s +1264 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv7m-le-armcc.s +1178 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-inplace-32bi-armv7m-le-gcc.s +1175 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-u1-32bi-armv6m-le-armcc.s +1338 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-u1-32bi-armv6m-le-gcc.s +1336 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-u2-32bi-armv6m-le-armcc.s +1343 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARM/KeccakP-1600-u2-32bi-armv6m-le-gcc.s +1339 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARMv7A-NEON/KeccakP-1600-SnP.h +42 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARMv7A-NEON/KeccakP-1600-armv7a-le-neon-armcc.s +823 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARMv7A-NEON/KeccakP-1600-armv7a-le-neon-gcc.s +831 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARMv8A/KeccakP-1600-SnP.h +31 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ARMv8A/KeccakP-1600-armv8a-neon.s +540 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVR8/KeccakP-1600-SnP.h +42 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVR8/KeccakP-1600-avr8-compact.s +733 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVR8/KeccakP-1600-avr8-fast.s +1121 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVX2/KeccakP-1600-AVX2.s +1100 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVX2/KeccakP-1600-SnP.h +52 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/KeccakP-1600-AVX512.c +623 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/KeccakP-1600-SnP.h +47 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/u12/KeccakP-1600-AVX512-config.h +6 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/u6/KeccakP-1600-AVX512-config.h +6 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVX512/C/ua/KeccakP-1600-AVX512-config.h +6 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVX512/KeccakP-1600-AVX512.s +1031 -0
- data/ext/xkcp/lib/low/KeccakP-1600/AVX512/KeccakP-1600-SnP.h +53 -0
- data/ext/xkcp/lib/low/KeccakP-1600/XOP/KeccakP-1600-SnP.h +44 -0
- data/ext/xkcp/lib/low/KeccakP-1600/XOP/KeccakP-1600-XOP.c +476 -0
- data/ext/xkcp/lib/low/KeccakP-1600/XOP/u6/KeccakP-1600-XOP-config.h +6 -0
- data/ext/xkcp/lib/low/KeccakP-1600/XOP/ua/KeccakP-1600-XOP-config.h +6 -0
- data/ext/xkcp/lib/low/KeccakP-1600/common/KeccakP-1600-64.macros +748 -0
- data/ext/xkcp/lib/low/KeccakP-1600/common/KeccakP-1600-unrolling.macros +305 -0
- data/ext/xkcp/lib/low/KeccakP-1600/compact/KeccakP-1600-SnP.h +40 -0
- data/ext/xkcp/lib/low/KeccakP-1600/compact/KeccakP-1600-compact64.c +420 -0
- data/ext/xkcp/lib/low/KeccakP-1600/plain-32bits-inplace/KeccakP-1600-SnP.h +43 -0
- data/ext/xkcp/lib/low/KeccakP-1600/plain-32bits-inplace/KeccakP-1600-inplace32BI.c +1163 -0
- data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/KeccakP-1600-SnP.h +54 -0
- data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/KeccakP-1600-opt64.c +565 -0
- data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/lcu6/KeccakP-1600-opt64-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/lcua/KeccakP-1600-opt64-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/lcua-shld/KeccakP-1600-opt64-config.h +8 -0
- data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/u6/KeccakP-1600-opt64-config.h +6 -0
- data/ext/xkcp/lib/low/KeccakP-1600/plain-64bits/ua/KeccakP-1600-opt64-config.h +6 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ref-32bits/KeccakP-1600-SnP.h +44 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ref-32bits/KeccakP-1600-reference.h +23 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ref-32bits/KeccakP-1600-reference32BI.c +625 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ref-64bits/KeccakP-1600-SnP.h +44 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ref-64bits/KeccakP-1600-reference.c +440 -0
- data/ext/xkcp/lib/low/KeccakP-1600/ref-64bits/KeccakP-1600-reference.h +23 -0
- data/ext/xkcp/lib/low/KeccakP-1600/x86-64/KeccakP-1600-SnP.h +42 -0
- data/ext/xkcp/lib/low/KeccakP-1600/x86-64/KeccakP-1600-x86-64-gas.s +1196 -0
- data/ext/xkcp/lib/low/KeccakP-1600/x86-64/KeccakP-1600-x86-64-gas_Apple.s +1124 -0
- data/ext/xkcp/lib/low/KeccakP-1600/x86-64/KeccakP-1600-x86-64-shld-gas.s +1196 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/ARMv7A-NEON/KeccakP-1600-inplace-pl2-armv7a-neon-le-armcc.s +1392 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/ARMv7A-NEON/KeccakP-1600-inplace-pl2-armv7a-neon-le-gcc.s +1394 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/ARMv7A-NEON/KeccakP-1600-times2-SnP.h +42 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/AVX512u12/SIMD512-2-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/AVX512u4/SIMD512-2-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/AVX512ufull/SIMD512-2-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/KeccakP-1600-times2-SIMD512.c +850 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/AVX512/KeccakP-1600-times2-SnP.h +51 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/KeccakP-1600-times2-SIMD128.c +957 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/KeccakP-1600-times2-SnP.h +49 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/SSSE3-u2/SIMD128-config.h +8 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/SSSE3-ua/SIMD128-config.h +8 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/XOP-u2/SIMD128-config.h +9 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/SIMD128/XOP-ua/SIMD128-config.h +9 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/fallback-on1/KeccakP-1600-times2-SnP.h +45 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times2/fallback-on1/KeccakP-1600-times2-on1.c +37 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/KeccakP-1600-times4-SIMD256.c +1321 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/KeccakP-1600-times4-SnP.h +55 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/u12/SIMD256-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/u6/SIMD256-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX2/ua/SIMD256-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/AVX512u12/SIMD512-4-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/AVX512u4/SIMD512-4-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/AVX512ufull/SIMD512-4-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/KeccakP-1600-times4-SIMD512.c +881 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/AVX512/KeccakP-1600-times4-SnP.h +51 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/fallback-on1/KeccakP-1600-times4-SnP.h +45 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/fallback-on1/KeccakP-1600-times4-on1.c +37 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/fallback-on2/KeccakP-1600-times4-SnP.h +45 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times4/fallback-on2/KeccakP-1600-times4-on2.c +38 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/KeccakP-1600-times8-SIMD512.c +1615 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/KeccakP-1600-times8-SnP.h +57 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/u12/SIMD512-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/u4/SIMD512-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/AVX512/ua/SIMD512-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on1/KeccakP-1600-times8-SnP.h +45 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on1/KeccakP-1600-times8-on1.c +37 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on2/KeccakP-1600-times8-SnP.h +45 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on2/KeccakP-1600-times8-on2.c +38 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on4/KeccakP-1600-times8-SnP.h +45 -0
- data/ext/xkcp/lib/low/KeccakP-1600-times8/fallback-on4/KeccakP-1600-times8-on4.c +38 -0
- data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-SnP.h +41 -0
- data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-armv6m-le-armcc.s +442 -0
- data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-armv6m-le-gcc.s +446 -0
- data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-armv7m-le-armcc.s +419 -0
- data/ext/xkcp/lib/low/KeccakP-200/ARM/KeccakP-200-armv7m-le-gcc.s +427 -0
- data/ext/xkcp/lib/low/KeccakP-200/AVR8/KeccakP-200-SnP.h +41 -0
- data/ext/xkcp/lib/low/KeccakP-200/AVR8/KeccakP-200-avr8-fast.s +647 -0
- data/ext/xkcp/lib/low/KeccakP-200/compact/KeccakP-200-SnP.h +39 -0
- data/ext/xkcp/lib/low/KeccakP-200/compact/KeccakP-200-compact.c +190 -0
- data/ext/xkcp/lib/low/KeccakP-200/ref/KeccakP-200-SnP.h +43 -0
- data/ext/xkcp/lib/low/KeccakP-200/ref/KeccakP-200-reference.c +412 -0
- data/ext/xkcp/lib/low/KeccakP-200/ref/KeccakP-200-reference.h +23 -0
- data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-SnP.h +41 -0
- data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-armv6m-le-armcc.s +454 -0
- data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-armv6m-le-gcc.s +458 -0
- data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-armv7m-le-armcc.s +455 -0
- data/ext/xkcp/lib/low/KeccakP-400/ARM/KeccakP-400-armv7m-le-gcc.s +458 -0
- data/ext/xkcp/lib/low/KeccakP-400/AVR8/KeccakP-400-SnP.h +41 -0
- data/ext/xkcp/lib/low/KeccakP-400/AVR8/KeccakP-400-avr8-fast.s +728 -0
- data/ext/xkcp/lib/low/KeccakP-400/ref/KeccakP-400-SnP.h +43 -0
- data/ext/xkcp/lib/low/KeccakP-400/ref/KeccakP-400-reference.c +414 -0
- data/ext/xkcp/lib/low/KeccakP-400/ref/KeccakP-400-reference.h +23 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-SnP.h +42 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u1-armv6m-le-armcc.s +527 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u1-armv6m-le-gcc.s +533 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv6m-le-armcc.s +528 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv6m-le-gcc.s +534 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv7a-le-armcc.s +521 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv7a-le-gcc.s +527 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv7m-le-armcc.s +517 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-u2-armv7m-le-gcc.s +523 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-uf-armv7m-le-armcc.s +550 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARM/KeccakP-800-uf-armv7m-le-gcc.s +556 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARMv8A/KeccakP-800-SnP.h +32 -0
- data/ext/xkcp/lib/low/KeccakP-800/ARMv8A/KeccakP-800-armv8a-neon.s +432 -0
- data/ext/xkcp/lib/low/KeccakP-800/AVR8/KeccakP-800-SnP.h +42 -0
- data/ext/xkcp/lib/low/KeccakP-800/AVR8/KeccakP-800-avr8-fast.s +929 -0
- data/ext/xkcp/lib/low/KeccakP-800/compact/KeccakP-800-SnP.h +40 -0
- data/ext/xkcp/lib/low/KeccakP-800/compact/KeccakP-800-compact.c +244 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-SnP.h +46 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-opt32-bis.macros +184 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-opt32.c +454 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-opt32.macros +459 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-unrolling-bis.macros +83 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/KeccakP-800-unrolling.macros +88 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/lcu2/KeccakP-800-opt32-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/lcua/KeccakP-800-opt32-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/u2/KeccakP-800-opt32-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-800/plain/ua/KeccakP-800-opt32-config.h +7 -0
- data/ext/xkcp/lib/low/KeccakP-800/ref/KeccakP-800-SnP.h +44 -0
- data/ext/xkcp/lib/low/KeccakP-800/ref/KeccakP-800-reference.c +437 -0
- data/ext/xkcp/lib/low/KeccakP-800/ref/KeccakP-800-reference.h +23 -0
- data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/Ket.h +57 -0
- data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/KetjeJr-armv7m-le-armcc.s +475 -0
- data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/KetjeJr-armv7m-le-gcc.s +480 -0
- data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/KetjeSr-armv7m-le-armcc.s +590 -0
- data/ext/xkcp/lib/low/Ketje/OptimizedAsmARM/KetjeSr-armv7m-le-gcc.s +590 -0
- data/ext/xkcp/lib/low/Ketje/OptimizedLE/Ket.c +126 -0
- data/ext/xkcp/lib/low/Ketje/OptimizedLE/Ket.h +68 -0
- data/ext/xkcp/lib/low/Ketje/OptimizedLE/Ket.inc +174 -0
- data/ext/xkcp/lib/low/Ketje/SnP-compliant/Ket.c +80 -0
- data/ext/xkcp/lib/low/Ketje/SnP-compliant/Ket.h +68 -0
- data/ext/xkcp/lib/low/Ketje/SnP-compliant/Ket.inc +142 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-SnP.h +55 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-u1-armv6m-le-armcc.s +1086 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-u1-armv6m-le-gcc.s +1092 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-uf-armv6-le-armcc.s +721 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-uf-armv6-le-gcc.s +726 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-uf-armv7m-le-armcc.s +723 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodoo-uf-armv7m-le-gcc.s +729 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-u1-armv6m-le-armcc.s +1164 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-u1-armv6m-le-gcc.s +1165 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-uf-armv6-le-armcc.s +562 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-uf-armv6-le-gcc.s +563 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-uf-armv7m-le-armcc.s +563 -0
- data/ext/xkcp/lib/low/Xoodoo/ARM/Xoodyak-uf-armv7m-le-gcc.s +565 -0
- data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodoo-SnP.h +55 -0
- data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodoo-uf-armv7a-neon-le-armcc.s +476 -0
- data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodoo-uf-armv7a-neon-le-gcc.s +485 -0
- data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodyak-uf-armv7a-neon-le-armcc.s +362 -0
- data/ext/xkcp/lib/low/Xoodoo/ARMv7A-NEON/Xoodyak-uf-armv7a-neon-le-gcc.s +367 -0
- data/ext/xkcp/lib/low/Xoodoo/AVR8/Xoodoo-SnP.h +43 -0
- data/ext/xkcp/lib/low/Xoodoo/AVR8/Xoodoo-avr8-u1.s +1341 -0
- data/ext/xkcp/lib/low/Xoodoo/AVX512/Xoodoo-SIMD512.c +581 -0
- data/ext/xkcp/lib/low/Xoodoo/AVX512/Xoodoo-SnP.h +58 -0
- data/ext/xkcp/lib/low/Xoodoo/AVX512/Xoodyak-full-block-SIMD512.c +332 -0
- data/ext/xkcp/lib/low/Xoodoo/SSE2/Xoodoo-SIMD128.c +329 -0
- data/ext/xkcp/lib/low/Xoodoo/SSE2/Xoodoo-SnP.h +53 -0
- data/ext/xkcp/lib/low/Xoodoo/SSE2/Xoodyak-full-block-SIMD128.c +355 -0
- data/ext/xkcp/lib/low/Xoodoo/Xoodoo.h +79 -0
- data/ext/xkcp/lib/low/Xoodoo/plain/Xoodoo-SnP.h +56 -0
- data/ext/xkcp/lib/low/Xoodoo/plain/Xoodoo-optimized.c +399 -0
- data/ext/xkcp/lib/low/Xoodoo/plain/Xoodyak-full-blocks.c +127 -0
- data/ext/xkcp/lib/low/Xoodoo/ref/Xoodoo-SnP.h +43 -0
- data/ext/xkcp/lib/low/Xoodoo/ref/Xoodoo-reference.c +253 -0
- data/ext/xkcp/lib/low/Xoodoo-times16/AVX512/Xoodoo-times16-SIMD512.c +1044 -0
- data/ext/xkcp/lib/low/Xoodoo-times16/AVX512/Xoodoo-times16-SnP.h +49 -0
- data/ext/xkcp/lib/low/Xoodoo-times16/fallback-on1/Xoodoo-times16-SnP.h +45 -0
- data/ext/xkcp/lib/low/Xoodoo-times16/fallback-on1/Xoodoo-times16-on1.c +37 -0
- data/ext/xkcp/lib/low/Xoodoo-times4/ARMv7A-NEON/Xoodoo-times4-ARMv7A.s +1587 -0
- data/ext/xkcp/lib/low/Xoodoo-times4/ARMv7A-NEON/Xoodoo-times4-SnP.h +48 -0
- data/ext/xkcp/lib/low/Xoodoo-times4/AVX512/Xoodoo-times4-SIMD512.c +1202 -0
- data/ext/xkcp/lib/low/Xoodoo-times4/AVX512/Xoodoo-times4-SnP.h +48 -0
- data/ext/xkcp/lib/low/Xoodoo-times4/SSSE3/Xoodoo-times4-SIMD128.c +484 -0
- data/ext/xkcp/lib/low/Xoodoo-times4/SSSE3/Xoodoo-times4-SnP.h +44 -0
- data/ext/xkcp/lib/low/Xoodoo-times4/fallback-on1/Xoodoo-times4-SnP.h +45 -0
- data/ext/xkcp/lib/low/Xoodoo-times4/fallback-on1/Xoodoo-times4-on1.c +37 -0
- data/ext/xkcp/lib/low/Xoodoo-times8/AVX2/Xoodoo-times8-SIMD256.c +939 -0
- data/ext/xkcp/lib/low/Xoodoo-times8/AVX2/Xoodoo-times8-SnP.h +49 -0
- data/ext/xkcp/lib/low/Xoodoo-times8/AVX512/Xoodoo-times8-SIMD512.c +1216 -0
- data/ext/xkcp/lib/low/Xoodoo-times8/AVX512/Xoodoo-times8-SnP.h +48 -0
- data/ext/xkcp/lib/low/Xoodoo-times8/fallback-on1/Xoodoo-times8-SnP.h +45 -0
- data/ext/xkcp/lib/low/Xoodoo-times8/fallback-on1/Xoodoo-times8-on1.c +37 -0
- data/ext/xkcp/lib/low/common/PlSnP-Fallback.inc +290 -0
- data/ext/xkcp/lib/low/common/SnP-Relaned.h +141 -0
- data/ext/xkcp/support/Build/ExpandProducts.xsl +79 -0
- data/ext/xkcp/support/Build/ToGlobalMakefile.xsl +206 -0
- data/ext/xkcp/support/Build/ToOneTarget.xsl +89 -0
- data/ext/xkcp/support/Build/ToTargetConfigFile.xsl +37 -0
- data/ext/xkcp/support/Build/ToTargetMakefile.xsl +298 -0
- data/ext/xkcp/support/Build/ToVCXProj.xsl +198 -0
- data/ext/xkcp/support/Kernel-PMU/Kernel-pmu.md +133 -0
- data/ext/xkcp/support/Kernel-PMU/Makefile +8 -0
- data/ext/xkcp/support/Kernel-PMU/enable_arm_pmu.c +129 -0
- data/ext/xkcp/support/Kernel-PMU/load-module +1 -0
- data/ext/xkcp/util/KeccakSum/KeccakSum.c +394 -0
- data/ext/xkcp/util/KeccakSum/base64.c +86 -0
- data/ext/xkcp/util/KeccakSum/base64.h +12 -0
- data/lib/sleeping_kangaroo12/binding.rb +15 -0
- data/lib/sleeping_kangaroo12/build/loader.rb +40 -0
- data/lib/sleeping_kangaroo12/build/platform.rb +37 -0
- data/lib/sleeping_kangaroo12/build.rb +4 -0
- data/lib/sleeping_kangaroo12/digest.rb +103 -0
- data/lib/sleeping_kangaroo12/version.rb +5 -0
- data/lib/sleeping_kangaroo12.rb +7 -0
- metadata +372 -0
|
@@ -0,0 +1,355 @@
|
|
|
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
|
+
#define VERBOSE 0
|
|
18
|
+
|
|
19
|
+
#include <stdio.h>
|
|
20
|
+
#include <stdlib.h>
|
|
21
|
+
#include <string.h>
|
|
22
|
+
#include <emmintrin.h>
|
|
23
|
+
#include <pmmintrin.h>
|
|
24
|
+
#include <smmintrin.h>
|
|
25
|
+
#include <tmmintrin.h>
|
|
26
|
+
#include "align.h"
|
|
27
|
+
#include "Xoodoo.h"
|
|
28
|
+
#include "Xoodyak-parameters.h"
|
|
29
|
+
|
|
30
|
+
#include "brg_endian.h"
|
|
31
|
+
#if (PLATFORM_BYTE_ORDER != IS_LITTLE_ENDIAN)
|
|
32
|
+
#error Expecting a little-endian platform
|
|
33
|
+
#endif
|
|
34
|
+
|
|
35
|
+
#if (VERBOSE > 0)
|
|
36
|
+
#define Dump(__t) Vars2State; \
|
|
37
|
+
printf(__t "\n"); \
|
|
38
|
+
printf("a00 %08x, a01 %08x, a02 %08x, a03 %08x\n", state[0+0], state[0+1], state[0+2], state[0+3] ); \
|
|
39
|
+
printf("a10 %08x, a11 %08x, a12 %08x, a13 %08x\n", state[4+0], state[4+1], state[4+2], state[4+3] ); \
|
|
40
|
+
printf("a20 %08x, a21 %08x, a22 %08x, a23 %08x\n\n", state[8+0], state[8+1], state[8+2], state[8+3] );
|
|
41
|
+
#else
|
|
42
|
+
#define Dump(__t)
|
|
43
|
+
#endif
|
|
44
|
+
|
|
45
|
+
#if (VERBOSE >= 1)
|
|
46
|
+
#define Dump1(__t) Dump(__t)
|
|
47
|
+
#else
|
|
48
|
+
#define Dump1(__t)
|
|
49
|
+
#endif
|
|
50
|
+
|
|
51
|
+
#if (VERBOSE >= 2)
|
|
52
|
+
#define Dump2(__t) Dump(__t)
|
|
53
|
+
#else
|
|
54
|
+
#define Dump2(__t)
|
|
55
|
+
#endif
|
|
56
|
+
|
|
57
|
+
#if (VERBOSE >= 3)
|
|
58
|
+
#define Dump3(__t) Dump(__t)
|
|
59
|
+
#else
|
|
60
|
+
#define Dump3(__t)
|
|
61
|
+
#endif
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
typedef __m128i V128;
|
|
65
|
+
|
|
66
|
+
ALIGN(16) static const uint8_t maskRhoEast2[16] = {
|
|
67
|
+
11, 8, 9, 10,
|
|
68
|
+
15, 12, 13, 14,
|
|
69
|
+
3, 0, 1, 2,
|
|
70
|
+
7, 4, 5, 6,
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
#define ANDnu128(a, b) _mm_andnot_si128(a, b)
|
|
74
|
+
#define CONST128(a) _mm_load_si128((const V128 *)&(a))
|
|
75
|
+
#define LOAD128(a) _mm_load_si128((const V128 *)&(a))
|
|
76
|
+
#define LOAD128u(a) _mm_loadu_si128((const V128 *)&(a))
|
|
77
|
+
#if defined(Waffel_useXOP)
|
|
78
|
+
#define ROL32in128(a, o) _mm_roti_epi32(a, o)
|
|
79
|
+
#else
|
|
80
|
+
#define ROL32in128(a, o) _mm_or_si128(_mm_slli_epi32(a, o), _mm_srli_epi32(a, 32-(o)))
|
|
81
|
+
#endif
|
|
82
|
+
#define STORE128(a, b) _mm_store_si128((V128 *)&(a), b)
|
|
83
|
+
#define STORE128u(a, b) _mm_storeu_si128((V128 *)&(a), b)
|
|
84
|
+
#define STORE64L(a, b) _mm_storel_epi64((V128 *)&(a), b)
|
|
85
|
+
#define XOR128(a, b) _mm_xor_si128(a, b)
|
|
86
|
+
|
|
87
|
+
#define DeclareVars V128 a0, a1, a2, p, e; \
|
|
88
|
+
V128 rhoEast2 = CONST128(maskRhoEast2)
|
|
89
|
+
|
|
90
|
+
#define State2Vars(state) a0 = LOAD128(((uint32_t*)state)[0]), a1 = LOAD128(((uint32_t*)state)[4]), a2 = LOAD128(((uint32_t*)state)[8]);
|
|
91
|
+
|
|
92
|
+
#define Vars2State(state) STORE128(((uint32_t*)state)[0], a0), STORE128(((uint32_t*)state)[4], a1), STORE128(((uint32_t*)state)[8], a2);
|
|
93
|
+
|
|
94
|
+
/*
|
|
95
|
+
** Theta: Column Parity Mixer
|
|
96
|
+
*/
|
|
97
|
+
#define Theta() p = XOR128( a0, a1 ); \
|
|
98
|
+
p = XOR128( p, a2 ); \
|
|
99
|
+
p = _mm_shuffle_epi32( p, 0x93); \
|
|
100
|
+
e = ROL32in128( p, 5 ); \
|
|
101
|
+
p = ROL32in128( p, 14 ); \
|
|
102
|
+
e = XOR128( e, p ); \
|
|
103
|
+
a0 = XOR128( a0, e ); \
|
|
104
|
+
a1 = XOR128( a1, e ); \
|
|
105
|
+
a2 = XOR128( a2, e );
|
|
106
|
+
|
|
107
|
+
/*
|
|
108
|
+
** Rho-west: Plane shift
|
|
109
|
+
*/
|
|
110
|
+
#define Rho_west() a1 = _mm_shuffle_epi32( a1, 0x93); \
|
|
111
|
+
a2 = ROL32in128(a2, 11);
|
|
112
|
+
|
|
113
|
+
/*
|
|
114
|
+
** Iota: round constants
|
|
115
|
+
*/
|
|
116
|
+
#define Iota(__rc) a0 = XOR128(a0, _mm_set_epi32(0, 0, 0, (__rc)));
|
|
117
|
+
|
|
118
|
+
/*
|
|
119
|
+
** Chi: non linear step, on colums
|
|
120
|
+
*/
|
|
121
|
+
#define Chi() a0 = XOR128(a0, ANDnu128(a1, a2)); \
|
|
122
|
+
a1 = XOR128(a1, ANDnu128(a2, a0)); \
|
|
123
|
+
a2 = XOR128(a2, ANDnu128(a0, a1));
|
|
124
|
+
|
|
125
|
+
/*
|
|
126
|
+
** Rho-east: Plane shift#include "Xoodoo.h"
|
|
127
|
+
|
|
128
|
+
*/
|
|
129
|
+
#define Rho_east() a1 = ROL32in128(a1, 1); \
|
|
130
|
+
a2 = _mm_shuffle_epi8( a2, rhoEast2);
|
|
131
|
+
|
|
132
|
+
|
|
133
|
+
#define Round(__rc) \
|
|
134
|
+
Theta(); \
|
|
135
|
+
Dump3("Theta"); \
|
|
136
|
+
Rho_west(); \
|
|
137
|
+
Dump3("Rho-west"); \
|
|
138
|
+
Iota(__rc); \
|
|
139
|
+
Dump3("Iota"); \
|
|
140
|
+
Chi(); \
|
|
141
|
+
Dump3("Chi"); \
|
|
142
|
+
Rho_east(); \
|
|
143
|
+
Dump3("Rho-east")
|
|
144
|
+
|
|
145
|
+
static const uint32_t RC[MAXROUNDS] = {
|
|
146
|
+
_rc12,
|
|
147
|
+
_rc11,
|
|
148
|
+
_rc10,
|
|
149
|
+
_rc9,
|
|
150
|
+
_rc8,
|
|
151
|
+
_rc7,
|
|
152
|
+
_rc6,
|
|
153
|
+
_rc5,
|
|
154
|
+
_rc4,
|
|
155
|
+
_rc3,
|
|
156
|
+
_rc2,
|
|
157
|
+
_rc1
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
size_t Xoodyak_AbsorbKeyedFullBlocks(void *state, const uint8_t *X, size_t XLen)
|
|
161
|
+
{
|
|
162
|
+
size_t initialLength = XLen;
|
|
163
|
+
DeclareVars;
|
|
164
|
+
|
|
165
|
+
State2Vars(state);
|
|
166
|
+
do {
|
|
167
|
+
Round(_rc12); /* Xoodyak_Up(instance, NULL, 0, 0); */
|
|
168
|
+
Round(_rc11);
|
|
169
|
+
Round(_rc10);
|
|
170
|
+
Round(_rc9);
|
|
171
|
+
Round(_rc8);
|
|
172
|
+
Round(_rc7);
|
|
173
|
+
Round(_rc6);
|
|
174
|
+
Round(_rc5);
|
|
175
|
+
Round(_rc4);
|
|
176
|
+
Round(_rc3);
|
|
177
|
+
Round(_rc2);
|
|
178
|
+
Round(_rc1);
|
|
179
|
+
a0 = XOR128(a0, LOAD128u(X[0])); /* Xoodyak_Down(instance, X, Xoodyak_Rkin, 0); */
|
|
180
|
+
a1 = XOR128(a1, LOAD128u(X[16]));
|
|
181
|
+
a2 = XOR128(a2, _mm_set_epi32(1, *(uint32_t*)(&X[40]), *(uint32_t*)(&X[36]), *(uint32_t*)(&X[32])));
|
|
182
|
+
X += Xoodyak_Rkin;
|
|
183
|
+
XLen -= Xoodyak_Rkin;
|
|
184
|
+
} while (XLen >= Xoodyak_Rkin);
|
|
185
|
+
Vars2State(state);
|
|
186
|
+
|
|
187
|
+
return initialLength - XLen;
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
size_t Xoodyak_AbsorbHashFullBlocks(void *state, const uint8_t *X, size_t XLen)
|
|
191
|
+
{
|
|
192
|
+
size_t initialLength = XLen;
|
|
193
|
+
V128 one = _mm_set_epi32(0, 0, 0, 1);
|
|
194
|
+
DeclareVars;
|
|
195
|
+
|
|
196
|
+
State2Vars(state);
|
|
197
|
+
do {
|
|
198
|
+
Round(_rc12); /* Xoodyak_Up(instance, NULL, 0, 0); */
|
|
199
|
+
Round(_rc11);
|
|
200
|
+
Round(_rc10);
|
|
201
|
+
Round(_rc9);
|
|
202
|
+
Round(_rc8);
|
|
203
|
+
Round(_rc7);
|
|
204
|
+
Round(_rc6);
|
|
205
|
+
Round(_rc5);
|
|
206
|
+
Round(_rc4);
|
|
207
|
+
Round(_rc3);
|
|
208
|
+
Round(_rc2);
|
|
209
|
+
Round(_rc1);
|
|
210
|
+
a0 = XOR128(a0, LOAD128u(X[0])); /* Xoodyak_Down(instance, X, Xoodyak_Rhash, 0); */
|
|
211
|
+
a1 = XOR128(a1, one);
|
|
212
|
+
X += Xoodyak_Rhash;
|
|
213
|
+
XLen -= Xoodyak_Rhash;
|
|
214
|
+
} while (XLen >= Xoodyak_Rhash);
|
|
215
|
+
Vars2State(state);
|
|
216
|
+
|
|
217
|
+
return initialLength - XLen;
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
|
|
221
|
+
size_t Xoodyak_SqueezeKeyedFullBlocks(void *state, uint8_t *Y, size_t YLen)
|
|
222
|
+
{
|
|
223
|
+
size_t initialLength = YLen;
|
|
224
|
+
V128 one = _mm_set_epi32(0, 0, 0, 1);
|
|
225
|
+
DeclareVars;
|
|
226
|
+
|
|
227
|
+
State2Vars(state);
|
|
228
|
+
do {
|
|
229
|
+
a0 = XOR128(a0, one); /* Xoodyak_Down(instance, NULL, 0, 0); */
|
|
230
|
+
Round(_rc12); /* Xoodyak_Up(instance, Y, Xoodyak_Rkout, 0); */
|
|
231
|
+
Round(_rc11);
|
|
232
|
+
Round(_rc10);
|
|
233
|
+
Round(_rc9);
|
|
234
|
+
Round(_rc8);
|
|
235
|
+
Round(_rc7);
|
|
236
|
+
Round(_rc6);
|
|
237
|
+
Round(_rc5);
|
|
238
|
+
Round(_rc4);
|
|
239
|
+
Round(_rc3);
|
|
240
|
+
Round(_rc2);
|
|
241
|
+
Round(_rc1);
|
|
242
|
+
STORE128u(Y[0], a0);
|
|
243
|
+
STORE64L(Y[16], a1);
|
|
244
|
+
Y += Xoodyak_Rkout;
|
|
245
|
+
YLen -= Xoodyak_Rkout;
|
|
246
|
+
} while (YLen >= Xoodyak_Rkout);
|
|
247
|
+
Vars2State(state);
|
|
248
|
+
|
|
249
|
+
return initialLength - YLen;
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
size_t Xoodyak_SqueezeHashFullBlocks(void *state, uint8_t *Y, size_t YLen)
|
|
253
|
+
{
|
|
254
|
+
size_t initialLength = YLen;
|
|
255
|
+
V128 one = _mm_set_epi32(0, 0, 0, 1);
|
|
256
|
+
DeclareVars;
|
|
257
|
+
|
|
258
|
+
State2Vars(state);
|
|
259
|
+
do {
|
|
260
|
+
a0 = XOR128(a0, one); /* Xoodyak_Down(instance, NULL, 0, 0); */
|
|
261
|
+
Round(_rc12); /* Xoodyak_Up(instance, Y, Xoodyak_Rhash, 0); */
|
|
262
|
+
Round(_rc11);
|
|
263
|
+
Round(_rc10);
|
|
264
|
+
Round(_rc9);
|
|
265
|
+
Round(_rc8);
|
|
266
|
+
Round(_rc7);
|
|
267
|
+
Round(_rc6);
|
|
268
|
+
Round(_rc5);
|
|
269
|
+
Round(_rc4);
|
|
270
|
+
Round(_rc3);
|
|
271
|
+
Round(_rc2);
|
|
272
|
+
Round(_rc1);
|
|
273
|
+
STORE128u(Y[0], a0);
|
|
274
|
+
Y += Xoodyak_Rhash;
|
|
275
|
+
YLen -= Xoodyak_Rhash;
|
|
276
|
+
} while (YLen >= Xoodyak_Rhash);
|
|
277
|
+
Vars2State(state);
|
|
278
|
+
|
|
279
|
+
return initialLength - YLen;
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
size_t Xoodyak_EncryptFullBlocks(void *state, const uint8_t *I, uint8_t *O, size_t IOLen)
|
|
283
|
+
{
|
|
284
|
+
size_t initialLength = IOLen;
|
|
285
|
+
DeclareVars;
|
|
286
|
+
|
|
287
|
+
State2Vars(state);
|
|
288
|
+
do {
|
|
289
|
+
Round(_rc12);
|
|
290
|
+
Round(_rc11);
|
|
291
|
+
Round(_rc10);
|
|
292
|
+
Round(_rc9);
|
|
293
|
+
Round(_rc8);
|
|
294
|
+
Round(_rc7);
|
|
295
|
+
Round(_rc6);
|
|
296
|
+
Round(_rc5);
|
|
297
|
+
Round(_rc4);
|
|
298
|
+
Round(_rc3);
|
|
299
|
+
Round(_rc2);
|
|
300
|
+
Round(_rc1);
|
|
301
|
+
a0 = XOR128(a0, LOAD128u(I[0]));
|
|
302
|
+
a1 = XOR128(a1, _mm_set_epi32(0, 1, *(uint32_t*)(&I[20]), *(uint32_t*)(&I[16])));
|
|
303
|
+
STORE128u(O[0], a0);
|
|
304
|
+
STORE64L(O[16], a1);
|
|
305
|
+
I += Xoodyak_Rkout;
|
|
306
|
+
O += Xoodyak_Rkout;
|
|
307
|
+
IOLen -= Xoodyak_Rkout;
|
|
308
|
+
} while (IOLen >= Xoodyak_Rkout);
|
|
309
|
+
Vars2State(state);
|
|
310
|
+
|
|
311
|
+
return initialLength - IOLen;
|
|
312
|
+
}
|
|
313
|
+
|
|
314
|
+
size_t Xoodyak_DecryptFullBlocks(void *state, const uint8_t *I, uint8_t *O, size_t IOLen)
|
|
315
|
+
{
|
|
316
|
+
size_t initialLength = IOLen;
|
|
317
|
+
V128 o0;
|
|
318
|
+
V128 one = _mm_set_epi32(0, 1, 0, 0);
|
|
319
|
+
DeclareVars;
|
|
320
|
+
|
|
321
|
+
State2Vars(state);
|
|
322
|
+
do {
|
|
323
|
+
Round(_rc12);
|
|
324
|
+
Round(_rc11);
|
|
325
|
+
Round(_rc10);
|
|
326
|
+
Round(_rc9);
|
|
327
|
+
Round(_rc8);
|
|
328
|
+
Round(_rc7);
|
|
329
|
+
Round(_rc6);
|
|
330
|
+
Round(_rc5);
|
|
331
|
+
Round(_rc4);
|
|
332
|
+
Round(_rc3);
|
|
333
|
+
Round(_rc2);
|
|
334
|
+
Round(_rc1);
|
|
335
|
+
o0 = XOR128(a0, LOAD128u(I[0]));
|
|
336
|
+
#if defined(__i386__) || defined(_M_IX86)
|
|
337
|
+
*((uint32_t*)(O+16)) = *((uint32_t*)(I+16)) ^ _mm_extract_epi32(a1, 0);
|
|
338
|
+
*((uint32_t*)(O+20)) = *((uint32_t*)(I+20)) ^ _mm_extract_epi32(a1, 1);
|
|
339
|
+
a1 = _mm_insert_epi32(a1, *((uint32_t*)(I+16)), 0);
|
|
340
|
+
a1 = _mm_insert_epi32(a1, *((uint32_t*)(I+20)), 1);
|
|
341
|
+
#else
|
|
342
|
+
*((uint64_t*)(O+16)) = *((uint64_t*)(I+16)) ^ _mm_extract_epi64(a1, 0);
|
|
343
|
+
a1 = _mm_insert_epi64(a1, *((uint64_t*)(I+16)), 0);
|
|
344
|
+
#endif
|
|
345
|
+
STORE128u(O[0], o0);
|
|
346
|
+
a0 = XOR128(a0, o0);
|
|
347
|
+
a1 = XOR128(a1, one);
|
|
348
|
+
I += Xoodyak_Rkout;
|
|
349
|
+
O += Xoodyak_Rkout;
|
|
350
|
+
IOLen -= Xoodyak_Rkout;
|
|
351
|
+
} while (IOLen >= Xoodyak_Rkout);
|
|
352
|
+
Vars2State(state);
|
|
353
|
+
|
|
354
|
+
return initialLength - IOLen;
|
|
355
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
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_h_
|
|
18
|
+
#define _Xoodoo_h_
|
|
19
|
+
|
|
20
|
+
#include <stdint.h>
|
|
21
|
+
#include <stdlib.h>
|
|
22
|
+
|
|
23
|
+
#define MAXROUNDS 12
|
|
24
|
+
#define NROWS 3
|
|
25
|
+
#define NCOLUMS 4
|
|
26
|
+
#define NLANES (NCOLUMS*NROWS)
|
|
27
|
+
|
|
28
|
+
/* Round constants */
|
|
29
|
+
#define _rc12 0x00000058
|
|
30
|
+
#define _rc11 0x00000038
|
|
31
|
+
#define _rc10 0x000003C0
|
|
32
|
+
#define _rc9 0x000000D0
|
|
33
|
+
#define _rc8 0x00000120
|
|
34
|
+
#define _rc7 0x00000014
|
|
35
|
+
#define _rc6 0x00000060
|
|
36
|
+
#define _rc5 0x0000002C
|
|
37
|
+
#define _rc4 0x00000380
|
|
38
|
+
#define _rc3 0x000000F0
|
|
39
|
+
#define _rc2 0x000001A0
|
|
40
|
+
#define _rc1 0x00000012
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
#if !defined(ROTL32)
|
|
44
|
+
#if defined (__arm__) && !defined(__GNUC__)
|
|
45
|
+
#define ROTL32(a, offset) __ror(a, (32-(offset))%32)
|
|
46
|
+
#elif defined(_MSC_VER)
|
|
47
|
+
#define ROTL32(a, offset) _rotl(a, (offset)%32)
|
|
48
|
+
#else
|
|
49
|
+
#define ROTL32(a, offset) ((((uint32_t)a) << ((offset)%32)) ^ (((uint32_t)a) >> ((32-(offset))%32)))
|
|
50
|
+
#endif
|
|
51
|
+
#endif
|
|
52
|
+
|
|
53
|
+
#if !defined(READ32_UNALIGNED)
|
|
54
|
+
#if defined (__arm__) && !defined(__GNUC__)
|
|
55
|
+
#define READ32_UNALIGNED(argAddress) (*((const __packed uint32_t*)(argAddress)))
|
|
56
|
+
#elif defined(_MSC_VER)
|
|
57
|
+
#define READ32_UNALIGNED(argAddress) (*((const uint32_t*)(argAddress)))
|
|
58
|
+
#else
|
|
59
|
+
#define READ32_UNALIGNED(argAddress) (*((const uint32_t*)(argAddress)))
|
|
60
|
+
#endif
|
|
61
|
+
#endif
|
|
62
|
+
|
|
63
|
+
#if !defined(WRITE32_UNALIGNED)
|
|
64
|
+
#if defined (__arm__) && !defined(__GNUC__)
|
|
65
|
+
#define WRITE32_UNALIGNED(argAddress, argData) (*((__packed uint32_t*)(argAddress)) = (argData))
|
|
66
|
+
#elif defined(_MSC_VER)
|
|
67
|
+
#define WRITE32_UNALIGNED(argAddress, argData) (*((uint32_t*)(argAddress)) = (argData))
|
|
68
|
+
#else
|
|
69
|
+
#define WRITE32_UNALIGNED(argAddress, argData) (*((uint32_t*)(argAddress)) = (argData))
|
|
70
|
+
#endif
|
|
71
|
+
#endif
|
|
72
|
+
|
|
73
|
+
#if !defined(index)
|
|
74
|
+
#define index(__x,__y) ((((__y) % NROWS) * NCOLUMS) + ((__x) % NCOLUMS))
|
|
75
|
+
#endif
|
|
76
|
+
|
|
77
|
+
typedef uint32_t tXoodooLane;
|
|
78
|
+
|
|
79
|
+
#endif
|
|
@@ -0,0 +1,56 @@
|
|
|
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_SnP_h_
|
|
18
|
+
#define _Xoodoo_SnP_h_
|
|
19
|
+
|
|
20
|
+
#include <stddef.h>
|
|
21
|
+
#include <stdint.h>
|
|
22
|
+
|
|
23
|
+
/** For the documentation, see SnP-documentation.h.
|
|
24
|
+
*/
|
|
25
|
+
|
|
26
|
+
#define Xoodoo_implementation "32-bit optimized implementation"
|
|
27
|
+
#define Xoodoo_stateSizeInBytes (3*4*4)
|
|
28
|
+
#define Xoodoo_stateAlignment 4
|
|
29
|
+
#define Xoodoo_HasNround
|
|
30
|
+
|
|
31
|
+
#define Xoodoo_StaticInitialize()
|
|
32
|
+
void Xoodoo_Initialize(void *state);
|
|
33
|
+
#define Xoodoo_AddByte(argS, argData, argOffset) ((uint8_t*)argS)[argOffset] ^= (argData)
|
|
34
|
+
void Xoodoo_AddBytes(void *state, const uint8_t *data, unsigned int offset, unsigned int length);
|
|
35
|
+
void Xoodoo_OverwriteBytes(void *state, const uint8_t *data, unsigned int offset, unsigned int length);
|
|
36
|
+
void Xoodoo_OverwriteWithZeroes(void *state, unsigned int byteCount);
|
|
37
|
+
void Xoodoo_Permute_Nrounds(void *state, unsigned int nrounds);
|
|
38
|
+
void Xoodoo_Permute_6rounds(void *state);
|
|
39
|
+
void Xoodoo_Permute_12rounds(void *state);
|
|
40
|
+
void Xoodoo_ExtractBytes(const void *state, uint8_t *data, unsigned int offset, unsigned int length);
|
|
41
|
+
void Xoodoo_ExtractAndAddBytes(const void *state, const uint8_t *input, uint8_t *output, unsigned int offset, unsigned int length);
|
|
42
|
+
|
|
43
|
+
//#define Xoodoo_FastXoofff_supported
|
|
44
|
+
//void Xoofff_AddIs( uint8_t *output, const uint8_t *input, size_t bitLen);
|
|
45
|
+
//size_t Xoofff_CompressFastLoop(uint8_t *k, uint8_t *xAccu, const uint8_t *input, size_t length);
|
|
46
|
+
//size_t Xoofff_ExpandFastLoop(uint8_t *yAccu, const uint8_t *kRoll, uint8_t *output, size_t length);
|
|
47
|
+
|
|
48
|
+
#define CyclistFullBlocks_supported
|
|
49
|
+
size_t Xoodyak_AbsorbKeyedFullBlocks(void *state, const uint8_t *X, size_t XLen);
|
|
50
|
+
size_t Xoodyak_AbsorbHashFullBlocks(void *state, const uint8_t *X, size_t XLen);
|
|
51
|
+
size_t Xoodyak_SqueezeHashFullBlocks(void *state, uint8_t *Y, size_t YLen);
|
|
52
|
+
size_t Xoodyak_SqueezeKeyedFullBlocks(void *state, uint8_t *Y, size_t YLen);
|
|
53
|
+
size_t Xoodyak_EncryptFullBlocks(void *state, const uint8_t *I, uint8_t *O, size_t IOLen);
|
|
54
|
+
size_t Xoodyak_DecryptFullBlocks(void *state, const uint8_t *I, uint8_t *O, size_t IOLen);
|
|
55
|
+
|
|
56
|
+
#endif
|