ruby_nacl 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/Changelog +0 -0
- data/README.md +49 -0
- data/ext/ruby_nacl/NaCl/MACROS +56 -0
- data/ext/ruby_nacl/NaCl/OPERATIONS +11 -0
- data/ext/ruby_nacl/NaCl/PROTOTYPES.c +26 -0
- data/ext/ruby_nacl/NaCl/PROTOTYPES.cpp +17 -0
- data/ext/ruby_nacl/NaCl/README +1 -0
- data/ext/ruby_nacl/NaCl/commandline/nacl-sha256.c +64 -0
- data/ext/ruby_nacl/NaCl/commandline/nacl-sha512.c +64 -0
- data/ext/ruby_nacl/NaCl/cpucycles/alpha.c +80 -0
- data/ext/ruby_nacl/NaCl/cpucycles/alpha.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/amd64cpuinfo.c +16 -0
- data/ext/ruby_nacl/NaCl/cpucycles/amd64cpuinfo.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/amd64cpuspeed.c +25 -0
- data/ext/ruby_nacl/NaCl/cpucycles/amd64cpuspeed.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/amd64tscfreq.c +18 -0
- data/ext/ruby_nacl/NaCl/cpucycles/amd64tscfreq.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/celllinux.c +83 -0
- data/ext/ruby_nacl/NaCl/cpucycles/celllinux.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/cortex.c +73 -0
- data/ext/ruby_nacl/NaCl/cpucycles/cortex.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/dev4ns.c +62 -0
- data/ext/ruby_nacl/NaCl/cpucycles/dev4ns.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/do +105 -0
- data/ext/ruby_nacl/NaCl/cpucycles/gettimeofday.c +32 -0
- data/ext/ruby_nacl/NaCl/cpucycles/gettimeofday.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/hppapstat.c +26 -0
- data/ext/ruby_nacl/NaCl/cpucycles/hppapstat.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/ia64cpuinfo.c +15 -0
- data/ext/ruby_nacl/NaCl/cpucycles/ia64cpuinfo.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/mips.c +65 -0
- data/ext/ruby_nacl/NaCl/cpucycles/mips.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/monotonic.c +34 -0
- data/ext/ruby_nacl/NaCl/cpucycles/monotonic.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/monotoniccpuinfo.c +33 -0
- data/ext/ruby_nacl/NaCl/cpucycles/monotoniccpuinfo.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/osfreq.c +65 -0
- data/ext/ruby_nacl/NaCl/cpucycles/powerpccpuinfo.c +95 -0
- data/ext/ruby_nacl/NaCl/cpucycles/powerpccpuinfo.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/powerpcmacos.c +42 -0
- data/ext/ruby_nacl/NaCl/cpucycles/powerpcmacos.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/sgi.c +38 -0
- data/ext/ruby_nacl/NaCl/cpucycles/sgi.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/sparc32cpuinfo.c +16 -0
- data/ext/ruby_nacl/NaCl/cpucycles/sparc32cpuinfo.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/sparccpuinfo.c +15 -0
- data/ext/ruby_nacl/NaCl/cpucycles/sparccpuinfo.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/test.c +77 -0
- data/ext/ruby_nacl/NaCl/cpucycles/x86cpuinfo.c +15 -0
- data/ext/ruby_nacl/NaCl/cpucycles/x86cpuinfo.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/x86cpuspeed.c +24 -0
- data/ext/ruby_nacl/NaCl/cpucycles/x86cpuspeed.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/x86estimate.c +59 -0
- data/ext/ruby_nacl/NaCl/cpucycles/x86estimate.h +27 -0
- data/ext/ruby_nacl/NaCl/cpucycles/x86tscfreq.c +17 -0
- data/ext/ruby_nacl/NaCl/cpucycles/x86tscfreq.h +27 -0
- data/ext/ruby_nacl/NaCl/cpuid/cbytes.c +16 -0
- data/ext/ruby_nacl/NaCl/cpuid/cpuid.c +41 -0
- data/ext/ruby_nacl/NaCl/cpuid/do +37 -0
- data/ext/ruby_nacl/NaCl/cpuid/unknown.c +7 -0
- data/ext/ruby_nacl/NaCl/cpuid/x86.c +41 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha256/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha256/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha256/ref/hmac.c +83 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha256/ref/verify.c +9 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha256/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha512256/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha512256/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha512256/ref/hmac.c +86 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha512256/ref/verify.c +9 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha512256/selected +0 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/hmacsha512256/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/measure.c +69 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/try.c +119 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/wrapper-auth.cpp +11 -0
- data/ext/ruby_nacl/NaCl/crypto_auth/wrapper-verify.cpp +14 -0
- data/ext/ruby_nacl/NaCl/crypto_box/curve25519xsalsa20poly1305/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_box/curve25519xsalsa20poly1305/ref/after.c +22 -0
- data/ext/ruby_nacl/NaCl/crypto_box/curve25519xsalsa20poly1305/ref/api.h +6 -0
- data/ext/ruby_nacl/NaCl/crypto_box/curve25519xsalsa20poly1305/ref/before.c +17 -0
- data/ext/ruby_nacl/NaCl/crypto_box/curve25519xsalsa20poly1305/ref/box.c +27 -0
- data/ext/ruby_nacl/NaCl/crypto_box/curve25519xsalsa20poly1305/ref/keypair.c +12 -0
- data/ext/ruby_nacl/NaCl/crypto_box/curve25519xsalsa20poly1305/selected +0 -0
- data/ext/ruby_nacl/NaCl/crypto_box/curve25519xsalsa20poly1305/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_box/measure.c +137 -0
- data/ext/ruby_nacl/NaCl/crypto_box/try.c +195 -0
- data/ext/ruby_nacl/NaCl/crypto_box/wrapper-box.cpp +24 -0
- data/ext/ruby_nacl/NaCl/crypto_box/wrapper-keypair.cpp +12 -0
- data/ext/ruby_nacl/NaCl/crypto_box/wrapper-open.cpp +27 -0
- data/ext/ruby_nacl/NaCl/crypto_core/hsalsa20/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_core/hsalsa20/ref/api.h +4 -0
- data/ext/ruby_nacl/NaCl/crypto_core/hsalsa20/ref/core.c +135 -0
- data/ext/ruby_nacl/NaCl/crypto_core/hsalsa20/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_core/hsalsa20/ref2/api.h +4 -0
- data/ext/ruby_nacl/NaCl/crypto_core/hsalsa20/ref2/core.c +108 -0
- data/ext/ruby_nacl/NaCl/crypto_core/hsalsa20/ref2/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_core/hsalsa20/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_core/measure.c +18 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa20/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa20/ref/api.h +4 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa20/ref/core.c +134 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa20/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa20/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa2012/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa2012/ref/api.h +4 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa2012/ref/core.c +134 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa2012/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa2012/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa208/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa208/ref/api.h +4 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa208/ref/core.c +134 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa208/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_core/salsa208/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_core/try.c +116 -0
- data/ext/ruby_nacl/NaCl/crypto_core/wrapper-empty.cpp +0 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/measure.c +66 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha256/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha256/ref/api.h +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha256/ref/hash.c +69 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha256/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha256/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha512/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha512/ref/api.h +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha512/ref/hash.c +71 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha512/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha512/selected +0 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/sha512/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/try.c +77 -0
- data/ext/ruby_nacl/NaCl/crypto_hash/wrapper-hash.cpp +10 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/measure.c +18 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha256/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha256/inplace/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha256/inplace/blocks.c +228 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha256/inplace/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha256/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha256/ref/blocks.c +212 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha256/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha256/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha512/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha512/inplace/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha512/inplace/blocks.c +256 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha512/inplace/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha512/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha512/ref/blocks.c +239 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha512/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha512/selected +0 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/sha512/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/try.c +79 -0
- data/ext/ruby_nacl/NaCl/crypto_hashblocks/wrapper-empty.cpp +0 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/measure.c +69 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/53/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/53/auth.c +1616 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/53/verify.c +9 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/amd64/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/amd64/auth.s +2787 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/amd64/constants.s +85 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/amd64/verify.c +9 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/ref/auth.c +104 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/ref/verify.c +9 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/selected +0 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/x86/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/x86/auth.s +2779 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/x86/constants.s +85 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/poly1305/x86/verify.c +9 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/try.c +119 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/wrapper-auth.cpp +11 -0
- data/ext/ruby_nacl/NaCl/crypto_onetimeauth/wrapper-verify.cpp +14 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/base.c +8 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/const.s +114 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/fromdouble.s +195 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/init.s +13 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/mainloop.s +3990 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/mult.s +410 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/smult.c +91 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/square.s +298 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/athlon/todouble.s +144 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/donna_c64/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/donna_c64/base.c +8 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/donna_c64/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/donna_c64/smult.c +477 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/ref/base.c +16 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/ref/smult.c +265 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/curve25519/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/measure.c +61 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/try.c +126 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/wrapper-base.cpp +11 -0
- data/ext/ruby_nacl/NaCl/crypto_scalarmult/wrapper-mult.cpp +12 -0
- data/ext/ruby_nacl/NaCl/crypto_secretbox/measure.c +75 -0
- data/ext/ruby_nacl/NaCl/crypto_secretbox/try.c +129 -0
- data/ext/ruby_nacl/NaCl/crypto_secretbox/wrapper-box.cpp +19 -0
- data/ext/ruby_nacl/NaCl/crypto_secretbox/wrapper-open.cpp +22 -0
- data/ext/ruby_nacl/NaCl/crypto_secretbox/xsalsa20poly1305/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_secretbox/xsalsa20poly1305/ref/api.h +4 -0
- data/ext/ruby_nacl/NaCl/crypto_secretbox/xsalsa20poly1305/ref/box.c +35 -0
- data/ext/ruby_nacl/NaCl/crypto_secretbox/xsalsa20poly1305/selected +0 -0
- data/ext/ruby_nacl/NaCl/crypto_secretbox/xsalsa20poly1305/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/ref/api.h +3 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/ref/fe25519.c +345 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/ref/fe25519.h +54 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/ref/ge25519.c +227 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/ref/ge25519.h +34 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/ref/sc25519.c +146 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/ref/sc25519.h +51 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/ref/sign.c +103 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/selected +0 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/edwards25519sha512batch/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/measure.c +83 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/try.c +86 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/wrapper-keypair.cpp +12 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/wrapper-sign-open.cpp +24 -0
- data/ext/ruby_nacl/NaCl/crypto_sign/wrapper-sign.cpp +23 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/core2/afternm.s +12308 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/core2/api.h +3 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/core2/beforenm.s +13694 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/core2/stream.c +14 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/core2/xor.c +15 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/core2/xor_afternm.s +12407 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/afternm.c +158 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/api.h +3 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/beforenm.c +59 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/common.c +64 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/common.h +788 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/consts.c +14 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/consts.h +28 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/int128.c +128 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/int128.h +47 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/stream.c +28 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/types.h +10 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/portable/xor_afternm.c +180 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/aes128ctr/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/measure.c +73 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/amd64_xmm6/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/amd64_xmm6/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/amd64_xmm6/stream.s +4823 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/ref/stream.c +49 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/ref/xor.c +52 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/x86_xmm5/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/x86_xmm5/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa20/x86_xmm5/stream.s +5078 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/amd64_xmm6/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/amd64_xmm6/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/amd64_xmm6/stream.s +4823 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/ref/stream.c +49 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/ref/xor.c +52 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/x86_xmm5/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/x86_xmm5/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa2012/x86_xmm5/stream.s +5078 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/amd64_xmm6/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/amd64_xmm6/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/amd64_xmm6/stream.s +4823 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/ref/stream.c +49 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/ref/xor.c +52 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/x86_xmm5/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/x86_xmm5/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/salsa208/x86_xmm5/stream.s +5078 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/try.c +124 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/wrapper-stream.cpp +12 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/wrapper-xor.cpp +17 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/xsalsa20/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/xsalsa20/ref/api.h +2 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/xsalsa20/ref/implementors +1 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/xsalsa20/ref/stream.c +22 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/xsalsa20/ref/xor.c +23 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/xsalsa20/selected +0 -0
- data/ext/ruby_nacl/NaCl/crypto_stream/xsalsa20/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_stream.h +18 -0
- data/ext/ruby_nacl/NaCl/crypto_stream_aes128ctr.h +33 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/16/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/16/ref/api.h +1 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/16/ref/verify.c +24 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/16/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/32/checksum +1 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/32/ref/api.h +1 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/32/ref/verify.c +40 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/32/used +0 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/measure.c +18 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/try.c +75 -0
- data/ext/ruby_nacl/NaCl/crypto_verify/wrapper-empty.cpp +0 -0
- data/ext/ruby_nacl/NaCl/curvecp/LIBS +31 -0
- data/ext/ruby_nacl/NaCl/curvecp/README +10 -0
- data/ext/ruby_nacl/NaCl/curvecp/SOURCES +36 -0
- data/ext/ruby_nacl/NaCl/curvecp/TARGETS +5 -0
- data/ext/ruby_nacl/NaCl/curvecp/blocking.c +12 -0
- data/ext/ruby_nacl/NaCl/curvecp/blocking.h +7 -0
- data/ext/ruby_nacl/NaCl/curvecp/byte.h +8 -0
- data/ext/ruby_nacl/NaCl/curvecp/byte_copy.c +8 -0
- data/ext/ruby_nacl/NaCl/curvecp/byte_isequal.c +10 -0
- data/ext/ruby_nacl/NaCl/curvecp/byte_zero.c +7 -0
- data/ext/ruby_nacl/NaCl/curvecp/crypto_block.c +35 -0
- data/ext/ruby_nacl/NaCl/curvecp/crypto_block.h +4 -0
- data/ext/ruby_nacl/NaCl/curvecp/curvecpclient.c +476 -0
- data/ext/ruby_nacl/NaCl/curvecp/curvecpmakekey.c +57 -0
- data/ext/ruby_nacl/NaCl/curvecp/curvecpmessage.c +654 -0
- data/ext/ruby_nacl/NaCl/curvecp/curvecpprintkey.c +46 -0
- data/ext/ruby_nacl/NaCl/curvecp/curvecpserver.c +497 -0
- data/ext/ruby_nacl/NaCl/curvecp/die.c +42 -0
- data/ext/ruby_nacl/NaCl/curvecp/die.h +16 -0
- data/ext/ruby_nacl/NaCl/curvecp/e.c +106 -0
- data/ext/ruby_nacl/NaCl/curvecp/e.h +438 -0
- data/ext/ruby_nacl/NaCl/curvecp/hexparse.c +25 -0
- data/ext/ruby_nacl/NaCl/curvecp/hexparse.h +6 -0
- data/ext/ruby_nacl/NaCl/curvecp/load.c +33 -0
- data/ext/ruby_nacl/NaCl/curvecp/load.h +6 -0
- data/ext/ruby_nacl/NaCl/curvecp/nameparse.c +19 -0
- data/ext/ruby_nacl/NaCl/curvecp/nameparse.h +6 -0
- data/ext/ruby_nacl/NaCl/curvecp/nanoseconds.c +27 -0
- data/ext/ruby_nacl/NaCl/curvecp/nanoseconds.h +6 -0
- data/ext/ruby_nacl/NaCl/curvecp/open.h +10 -0
- data/ext/ruby_nacl/NaCl/curvecp/open_cwd.c +6 -0
- data/ext/ruby_nacl/NaCl/curvecp/open_lock.c +19 -0
- data/ext/ruby_nacl/NaCl/curvecp/open_pipe.c +15 -0
- data/ext/ruby_nacl/NaCl/curvecp/open_read.c +17 -0
- data/ext/ruby_nacl/NaCl/curvecp/open_write.c +17 -0
- data/ext/ruby_nacl/NaCl/curvecp/portparse.c +14 -0
- data/ext/ruby_nacl/NaCl/curvecp/portparse.h +6 -0
- data/ext/ruby_nacl/NaCl/curvecp/randommod.c +14 -0
- data/ext/ruby_nacl/NaCl/curvecp/randommod.h +6 -0
- data/ext/ruby_nacl/NaCl/curvecp/safenonce.c +74 -0
- data/ext/ruby_nacl/NaCl/curvecp/safenonce.h +6 -0
- data/ext/ruby_nacl/NaCl/curvecp/savesync.c +24 -0
- data/ext/ruby_nacl/NaCl/curvecp/savesync.h +6 -0
- data/ext/ruby_nacl/NaCl/curvecp/socket.h +9 -0
- data/ext/ruby_nacl/NaCl/curvecp/socket_bind.c +15 -0
- data/ext/ruby_nacl/NaCl/curvecp/socket_recv.c +23 -0
- data/ext/ruby_nacl/NaCl/curvecp/socket_send.c +19 -0
- data/ext/ruby_nacl/NaCl/curvecp/socket_udp.c +36 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint16_pack.c +7 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint16_pack.h +8 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint16_unpack.c +9 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint16_unpack.h +8 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint32_pack.c +9 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint32_pack.h +8 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint32_unpack.c +11 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint32_unpack.h +8 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint64_pack.c +13 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint64_pack.h +8 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint64_unpack.c +15 -0
- data/ext/ruby_nacl/NaCl/curvecp/uint64_unpack.h +8 -0
- data/ext/ruby_nacl/NaCl/curvecp/writeall.c +27 -0
- data/ext/ruby_nacl/NaCl/curvecp/writeall.h +6 -0
- data/ext/ruby_nacl/NaCl/do +468 -0
- data/ext/ruby_nacl/NaCl/inttypes/crypto_int16.c +3 -0
- data/ext/ruby_nacl/NaCl/inttypes/crypto_int32.c +3 -0
- data/ext/ruby_nacl/NaCl/inttypes/crypto_int64.c +3 -0
- data/ext/ruby_nacl/NaCl/inttypes/crypto_int8.c +3 -0
- data/ext/ruby_nacl/NaCl/inttypes/crypto_uint16.c +3 -0
- data/ext/ruby_nacl/NaCl/inttypes/crypto_uint32.c +3 -0
- data/ext/ruby_nacl/NaCl/inttypes/crypto_uint64.c +3 -0
- data/ext/ruby_nacl/NaCl/inttypes/crypto_uint8.c +3 -0
- data/ext/ruby_nacl/NaCl/inttypes/do +47 -0
- data/ext/ruby_nacl/NaCl/inttypes/signed.h +17 -0
- data/ext/ruby_nacl/NaCl/inttypes/unsigned.h +17 -0
- data/ext/ruby_nacl/NaCl/measure-anything.c +225 -0
- data/ext/ruby_nacl/NaCl/okcompilers/abiname.c +45 -0
- data/ext/ruby_nacl/NaCl/okcompilers/archivers +2 -0
- data/ext/ruby_nacl/NaCl/okcompilers/c +8 -0
- data/ext/ruby_nacl/NaCl/okcompilers/cpp +8 -0
- data/ext/ruby_nacl/NaCl/okcompilers/do +196 -0
- data/ext/ruby_nacl/NaCl/okcompilers/lib.c +29 -0
- data/ext/ruby_nacl/NaCl/okcompilers/lib.cpp +19 -0
- data/ext/ruby_nacl/NaCl/okcompilers/main.c +25 -0
- data/ext/ruby_nacl/NaCl/okcompilers/main.cpp +22 -0
- data/ext/ruby_nacl/NaCl/randombytes/devurandom.c +34 -0
- data/ext/ruby_nacl/NaCl/randombytes/devurandom.h +24 -0
- data/ext/ruby_nacl/NaCl/randombytes/do +43 -0
- data/ext/ruby_nacl/NaCl/randombytes/test.c +15 -0
- data/ext/ruby_nacl/NaCl/tests/auth.c +19 -0
- data/ext/ruby_nacl/NaCl/tests/auth.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/auth2.c +34 -0
- data/ext/ruby_nacl/NaCl/tests/auth2.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/auth3.c +34 -0
- data/ext/ruby_nacl/NaCl/tests/auth3.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/auth4.cpp +44 -0
- data/ext/ruby_nacl/NaCl/tests/auth4.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/auth5.c +36 -0
- data/ext/ruby_nacl/NaCl/tests/auth5.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/auth6.cpp +46 -0
- data/ext/ruby_nacl/NaCl/tests/auth6.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/box.c +63 -0
- data/ext/ruby_nacl/NaCl/tests/box.out +19 -0
- data/ext/ruby_nacl/NaCl/tests/box2.c +64 -0
- data/ext/ruby_nacl/NaCl/tests/box2.out +17 -0
- data/ext/ruby_nacl/NaCl/tests/box3.cpp +60 -0
- data/ext/ruby_nacl/NaCl/tests/box3.out +19 -0
- data/ext/ruby_nacl/NaCl/tests/box4.cpp +66 -0
- data/ext/ruby_nacl/NaCl/tests/box4.out +17 -0
- data/ext/ruby_nacl/NaCl/tests/box5.cpp +30 -0
- data/ext/ruby_nacl/NaCl/tests/box5.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/box6.cpp +43 -0
- data/ext/ruby_nacl/NaCl/tests/box6.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/box7.c +36 -0
- data/ext/ruby_nacl/NaCl/tests/box7.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/box8.c +41 -0
- data/ext/ruby_nacl/NaCl/tests/box8.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/core1.c +30 -0
- data/ext/ruby_nacl/NaCl/tests/core1.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/core2.c +33 -0
- data/ext/ruby_nacl/NaCl/tests/core2.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/core3.c +41 -0
- data/ext/ruby_nacl/NaCl/tests/core3.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/core4.c +33 -0
- data/ext/ruby_nacl/NaCl/tests/core4.out +8 -0
- data/ext/ruby_nacl/NaCl/tests/core5.c +32 -0
- data/ext/ruby_nacl/NaCl/tests/core5.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/core6.c +47 -0
- data/ext/ruby_nacl/NaCl/tests/core6.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/hash.c +14 -0
- data/ext/ruby_nacl/NaCl/tests/hash.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/hash2.cpp +18 -0
- data/ext/ruby_nacl/NaCl/tests/hash2.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/hash3.c +14 -0
- data/ext/ruby_nacl/NaCl/tests/hash3.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/hash4.cpp +18 -0
- data/ext/ruby_nacl/NaCl/tests/hash4.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth.c +42 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth.out +2 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth2.c +40 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth2.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth5.cpp +46 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth5.out +2 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth6.cpp +50 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth6.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth7.c +36 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth7.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth8.cpp +46 -0
- data/ext/ruby_nacl/NaCl/tests/onetimeauth8.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult.c +23 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult2.c +23 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult2.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult3.cpp +31 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult3.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult4.cpp +31 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult4.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult5.c +30 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult5.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult6.c +30 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult6.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult7.cpp +32 -0
- data/ext/ruby_nacl/NaCl/tests/scalarmult7.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox.c +56 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox.out +19 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox2.c +57 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox2.out +17 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox3.cpp +52 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox3.out +19 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox4.cpp +54 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox4.out +17 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox5.cpp +29 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox5.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox6.cpp +42 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox6.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox7.c +32 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox7.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox8.c +37 -0
- data/ext/ruby_nacl/NaCl/tests/secretbox8.out +0 -0
- data/ext/ruby_nacl/NaCl/tests/stream.c +29 -0
- data/ext/ruby_nacl/NaCl/tests/stream.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/stream2.c +27 -0
- data/ext/ruby_nacl/NaCl/tests/stream2.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/stream3.c +28 -0
- data/ext/ruby_nacl/NaCl/tests/stream3.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/stream4.c +53 -0
- data/ext/ruby_nacl/NaCl/tests/stream4.out +17 -0
- data/ext/ruby_nacl/NaCl/tests/stream5.cpp +29 -0
- data/ext/ruby_nacl/NaCl/tests/stream5.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/stream6.cpp +27 -0
- data/ext/ruby_nacl/NaCl/tests/stream6.out +1 -0
- data/ext/ruby_nacl/NaCl/tests/stream7.cpp +30 -0
- data/ext/ruby_nacl/NaCl/tests/stream7.out +4 -0
- data/ext/ruby_nacl/NaCl/tests/stream8.cpp +56 -0
- data/ext/ruby_nacl/NaCl/tests/stream8.out +17 -0
- data/ext/ruby_nacl/NaCl/try-anything.c +173 -0
- data/ext/ruby_nacl/NaCl/version +1 -0
- data/ext/ruby_nacl/extconf.rb +18 -0
- data/ext/ruby_nacl/ruby_nacl.cpp +147 -0
- data/ext/ruby_nacl/ruby_nacl.h +49 -0
- metadata +554 -0
@@ -0,0 +1,468 @@
|
|
1
|
+
#!/bin/sh
|
2
|
+
|
3
|
+
# nacl/do
|
4
|
+
# D. J. Bernstein
|
5
|
+
# Public domain.
|
6
|
+
|
7
|
+
version=`cat version`
|
8
|
+
project=nacl
|
9
|
+
shorthostname=`hostname | sed 's/\..*//' | tr -cd '[a-z][A-Z][0-9]'`
|
10
|
+
|
11
|
+
top="`pwd`/build/$shorthostname"
|
12
|
+
bin="$top/bin"
|
13
|
+
lib="$top/lib"
|
14
|
+
include="$top/include"
|
15
|
+
work="$top/work"
|
16
|
+
|
17
|
+
PATH="/usr/local/bin:$PATH"
|
18
|
+
PATH="/usr/sfw/bin:$PATH"
|
19
|
+
PATH="$bin:$PATH"
|
20
|
+
export PATH
|
21
|
+
|
22
|
+
LD_LIBRARY_PATH="/usr/local/lib/sparcv9:/usr/local/lib:$LD_LIBRARY_PATH"
|
23
|
+
LD_LIBRARY_PATH="/usr/sfw/lib/sparcv9:/usr/sfw/lib:$LD_LIBRARY_PATH"
|
24
|
+
export LD_LIBRARY_PATH
|
25
|
+
|
26
|
+
# and wacky MacOS X
|
27
|
+
DYLD_LIBRARY_PATH="/usr/local/lib/sparcv9:/usr/local/lib:$DYLD_LIBRARY_PATH"
|
28
|
+
DYLD_LIBRARY_PATH="/usr/sfw/lib/sparcv9:/usr/sfw/lib:$DYLD_LIBRARY_PATH"
|
29
|
+
export DYLD_LIBRARY_PATH
|
30
|
+
|
31
|
+
# and work around bug in GNU sort
|
32
|
+
LANG=C
|
33
|
+
export LANG
|
34
|
+
|
35
|
+
rm -rf "$top"
|
36
|
+
mkdir -p "$top"
|
37
|
+
mkdir -p "$bin"
|
38
|
+
mkdir -p "$lib"
|
39
|
+
mkdir -p "$include"
|
40
|
+
|
41
|
+
exec >"$top/log"
|
42
|
+
exec 2>&1
|
43
|
+
exec 5>"$top/data"
|
44
|
+
exec </dev/null
|
45
|
+
|
46
|
+
echo "=== `date` === starting"
|
47
|
+
|
48
|
+
echo "=== `date` === hostname"
|
49
|
+
hostname || :
|
50
|
+
echo "=== `date` === uname -a"
|
51
|
+
uname -a || :
|
52
|
+
echo "=== `date` === uname -M"
|
53
|
+
uname -M || :
|
54
|
+
echo "=== `date` === uname -F"
|
55
|
+
uname -F || :
|
56
|
+
echo "=== `date` === /usr/sbin/lscfg | grep proc"
|
57
|
+
/usr/sbin/lscfg | grep proc || :
|
58
|
+
echo "=== `date` === /usr/sbin/lsattr -El proc0"
|
59
|
+
/usr/sbin/lsattr -El proc0 || :
|
60
|
+
echo "=== `date` === cat /proc/cpuinfo"
|
61
|
+
cat /proc/cpuinfo || :
|
62
|
+
echo "=== `date` === cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq"
|
63
|
+
cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq || :
|
64
|
+
echo "=== `date` === cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq"
|
65
|
+
cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq || :
|
66
|
+
echo "=== `date` === cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_max_freq"
|
67
|
+
cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_max_freq || :
|
68
|
+
echo "=== `date` === cat /sys/devices/system/cpu/cpu0/clock_tick"
|
69
|
+
cat /sys/devices/system/cpu/cpu0/clock_tick || :
|
70
|
+
echo "=== `date` === sysctl hw.model"
|
71
|
+
sysctl hw.model || :
|
72
|
+
echo "=== `date` === sysctl machdep.tsc_freq"
|
73
|
+
sysctl machdep.tsc_freq || :
|
74
|
+
echo "=== `date` === /usr/sbin/psrinfo -v"
|
75
|
+
/usr/sbin/psrinfo -v || :
|
76
|
+
|
77
|
+
echo "=== `date` === building okcompilers"
|
78
|
+
rm -rf "$work"
|
79
|
+
mkdir -p "$work"
|
80
|
+
cp -pr okcompilers/* "$work"
|
81
|
+
( cd "$work" && sh do )
|
82
|
+
cp -p "$work"/bin/* "$bin"
|
83
|
+
|
84
|
+
echo "=== `date` === building cpuid"
|
85
|
+
rm -rf "$work"
|
86
|
+
mkdir -p "$work"
|
87
|
+
cp -pr cpuid/* "$work"
|
88
|
+
( cd "$work" && sh do )
|
89
|
+
cp -pr "$work"/include/* "$include"
|
90
|
+
|
91
|
+
echo "=== `date` === building inttypes"
|
92
|
+
rm -rf "$work"
|
93
|
+
mkdir -p "$work"
|
94
|
+
cp -pr inttypes/* "$work"
|
95
|
+
( cd "$work" && sh do )
|
96
|
+
cp -pr "$work"/include/* "$include"
|
97
|
+
|
98
|
+
echo "=== `date` === building cpucycles"
|
99
|
+
rm -rf "$work"
|
100
|
+
mkdir -p "$work"
|
101
|
+
cp -pr cpucycles/* "$work"
|
102
|
+
( cd "$work" && sh do )
|
103
|
+
cp -pr "$work"/lib/* "$lib"
|
104
|
+
cp -pr "$work"/include/* "$include"
|
105
|
+
|
106
|
+
echo "=== `date` === building randombytes"
|
107
|
+
rm -rf "$work"
|
108
|
+
mkdir -p "$work"
|
109
|
+
cp -pr randombytes/* "$work"
|
110
|
+
( cd "$work" && sh do )
|
111
|
+
cp -pr "$work"/lib/* "$lib"
|
112
|
+
cp -pr "$work"/include/* "$include"
|
113
|
+
|
114
|
+
okabi \
|
115
|
+
| while read abi
|
116
|
+
do
|
117
|
+
rm -rf "$work"
|
118
|
+
mkdir -p "$work"
|
119
|
+
echo 'void crypto_'"$project"'_base(void) { ; }' > "$work/${project}_base.c"
|
120
|
+
okc-$abi \
|
121
|
+
| while read compiler
|
122
|
+
do
|
123
|
+
( cd "$work" && $compiler -c ${project}_base.c ) && break
|
124
|
+
done
|
125
|
+
okar-$abi cr "$lib/$abi/lib${project}.a" "$work/${project}_base.o"
|
126
|
+
( ranlib "$lib/$abi/lib${project}.a" || exit 0 )
|
127
|
+
done
|
128
|
+
|
129
|
+
# loop over operations
|
130
|
+
cat OPERATIONS \
|
131
|
+
| while read o
|
132
|
+
do
|
133
|
+
[ -d "$o" ] || continue
|
134
|
+
|
135
|
+
selected=''
|
136
|
+
[ -f "$o/selected" ] && selected=`cat "$o/selected"`
|
137
|
+
|
138
|
+
# for each operation, loop over primitives
|
139
|
+
ls "$o" \
|
140
|
+
| sort \
|
141
|
+
| while read p
|
142
|
+
do
|
143
|
+
[ -d "$o/$p" ] || continue
|
144
|
+
expectedchecksum=''
|
145
|
+
[ -f "$o/$p/checksum" ] && expectedchecksum=`cat "$o/$p/checksum"`
|
146
|
+
op="${o}_${p}"
|
147
|
+
|
148
|
+
startdate=`date +%Y%m%d`
|
149
|
+
|
150
|
+
# for each operation primitive, loop over abis
|
151
|
+
okabi \
|
152
|
+
| while read abi
|
153
|
+
do
|
154
|
+
echo "=== `date` === $abi $o/$p"
|
155
|
+
libs=`"oklibs-$abi"`
|
156
|
+
libs="$lib/$abi/cpucycles.o $libs"
|
157
|
+
[ -f "$lib/$abi/lib${project}.a" ] && libs="$lib/$abi/lib${project}.a $libs"
|
158
|
+
|
159
|
+
rm -rf "$work"
|
160
|
+
mkdir -p "$work"
|
161
|
+
mkdir -p "$work/best"
|
162
|
+
|
163
|
+
# for each operation primitive abi, loop over implementations
|
164
|
+
find "$o/$p" -follow -name "api.h" \
|
165
|
+
| sort \
|
166
|
+
| while read doth
|
167
|
+
do
|
168
|
+
implementationdir=`dirname $doth`
|
169
|
+
opi=`echo "$implementationdir" | tr ./- ___`
|
170
|
+
|
171
|
+
echo "=== `date` === $abi $implementationdir"
|
172
|
+
|
173
|
+
rm -rf "$work/compile"
|
174
|
+
mkdir -p "$work/compile"
|
175
|
+
|
176
|
+
cfiles=`ls "$implementationdir" | grep '\.c$' || :`
|
177
|
+
sfiles=`ls "$implementationdir" | grep '\.[sS]$' || :`
|
178
|
+
cppfiles=`ls "$o" | grep '\.cpp$' || :`
|
179
|
+
|
180
|
+
cp -p "$o"/*.c "$work/compile/"
|
181
|
+
cp -p "$o"/*.cpp "$work/compile/"
|
182
|
+
|
183
|
+
cp -pr "$implementationdir"/* "$work/compile"
|
184
|
+
|
185
|
+
cp -p "try-anything.c" "$work/compile/try-anything.c"
|
186
|
+
cp -p "measure-anything.c" "$work/compile/measure-anything.c"
|
187
|
+
|
188
|
+
cp -p MACROS "$work/compile/MACROS"
|
189
|
+
cp -p PROTOTYPES.c "$work/compile/PROTOTYPES.c"
|
190
|
+
cp -p PROTOTYPES.cpp "$work/compile/PROTOTYPES.cpp"
|
191
|
+
|
192
|
+
(
|
193
|
+
cd "$work/compile"
|
194
|
+
(
|
195
|
+
echo "#ifndef ${o}_H"
|
196
|
+
echo "#define ${o}_H"
|
197
|
+
echo ""
|
198
|
+
echo "#include \"${op}.h\""
|
199
|
+
echo ""
|
200
|
+
egrep "${o}"'$|'"${o}"'\(|'"${o}"'_' < MACROS \
|
201
|
+
| sed "s/$o/$op/" | while read mop
|
202
|
+
do
|
203
|
+
echo "#define ${mop} ${mop}" | sed "s/$op/$o/"
|
204
|
+
done
|
205
|
+
echo "#define ${o}_PRIMITIVE \"${p}\""
|
206
|
+
echo "#define ${o}_IMPLEMENTATION ${op}_IMPLEMENTATION"
|
207
|
+
echo "#define ${o}_VERSION ${op}_VERSION"
|
208
|
+
echo ""
|
209
|
+
echo "#endif"
|
210
|
+
) > "$o.h"
|
211
|
+
(
|
212
|
+
echo "#ifndef ${op}_H"
|
213
|
+
echo "#define ${op}_H"
|
214
|
+
echo ""
|
215
|
+
sed 's/[ ]CRYPTO_/ '"${opi}"'_/g' < api.h
|
216
|
+
echo '#ifdef __cplusplus'
|
217
|
+
echo '#include <string>'
|
218
|
+
egrep "${o}"'$|'"${o}"'\(|'"${o}"'_' < PROTOTYPES.cpp \
|
219
|
+
| sed "s/$o/$opi/"
|
220
|
+
echo 'extern "C" {'
|
221
|
+
echo '#endif'
|
222
|
+
egrep "${o}"'$|'"${o}"'\(|'"${o}"'_' < PROTOTYPES.c \
|
223
|
+
| sed "s/$o/$opi/"
|
224
|
+
echo '#ifdef __cplusplus'
|
225
|
+
echo '}'
|
226
|
+
echo '#endif'
|
227
|
+
echo ""
|
228
|
+
egrep "${o}"'$|'"${o}"'\(|'"${o}"'_' < MACROS \
|
229
|
+
| sed "s/$o/$opi/" | while read mopi
|
230
|
+
do
|
231
|
+
echo "#define ${mopi} ${mopi}" | sed "s/$opi/$op/"
|
232
|
+
done
|
233
|
+
echo "#define ${op}_IMPLEMENTATION \"${implementationdir}\""
|
234
|
+
echo "#ifndef ${opi}_VERSION"
|
235
|
+
echo "#define ${opi}_VERSION \"-\""
|
236
|
+
echo "#endif"
|
237
|
+
echo "#define ${op}_VERSION ${opi}_VERSION"
|
238
|
+
echo ""
|
239
|
+
echo "#endif"
|
240
|
+
) > "$op.h"
|
241
|
+
|
242
|
+
okc-$abi \
|
243
|
+
| while read compiler
|
244
|
+
do
|
245
|
+
echo "=== `date` === $abi $implementationdir $compiler"
|
246
|
+
compilerword=`echo "$compiler" | tr ' ' '_'`
|
247
|
+
ok=1
|
248
|
+
for f in $cfiles $sfiles
|
249
|
+
do
|
250
|
+
if [ "$ok" = 1 ]
|
251
|
+
then
|
252
|
+
$compiler \
|
253
|
+
-I. -I"$include" -I"$include/$abi" \
|
254
|
+
-c "$f" >../errors 2>&1 || ok=0
|
255
|
+
( if [ `wc -l < ../errors` -lt 25 ]
|
256
|
+
then
|
257
|
+
cat ../errors
|
258
|
+
else
|
259
|
+
head ../errors
|
260
|
+
echo ...
|
261
|
+
tail ../errors
|
262
|
+
fi
|
263
|
+
) \
|
264
|
+
| while read err
|
265
|
+
do
|
266
|
+
echo "$version $shorthostname $abi $startdate $o $p fromcompiler $implementationdir $compilerword $f $err" >&5
|
267
|
+
done
|
268
|
+
fi
|
269
|
+
done
|
270
|
+
|
271
|
+
[ "$ok" = 1 ] || continue
|
272
|
+
okar-$abi cr "$op.a" *.o || continue
|
273
|
+
ranlib "$op.a"
|
274
|
+
|
275
|
+
$compiler \
|
276
|
+
-I. -I"$include" -I"$include/$abi" \
|
277
|
+
-o try try.c try-anything.c \
|
278
|
+
"$op.a" $libs >../errors 2>&1 || ok=0
|
279
|
+
cat ../errors \
|
280
|
+
| while read err
|
281
|
+
do
|
282
|
+
echo "$version $shorthostname $abi $startdate $o $p fromcompiler $implementationdir $compilerword try.c $err" >&5
|
283
|
+
done
|
284
|
+
[ "$ok" = 1 ] || continue
|
285
|
+
|
286
|
+
if sh -c './try || exit $?' >../outputs 2>../errors
|
287
|
+
then
|
288
|
+
checksum=`awk '{print $1}' < ../outputs`
|
289
|
+
cycles=`awk '{print $2}' < ../outputs`
|
290
|
+
checksumcycles=`awk '{print $3}' < ../outputs`
|
291
|
+
cyclespersecond=`awk '{print $4}' < ../outputs`
|
292
|
+
impl=`awk '{print $5}' < ../outputs`
|
293
|
+
else
|
294
|
+
echo "$version $shorthostname $abi $startdate $o $p tryfails $implementationdir $compilerword error $?" >&5
|
295
|
+
cat ../outputs ../errors \
|
296
|
+
| while read err
|
297
|
+
do
|
298
|
+
echo "$version $shorthostname $abi $startdate $o $p tryfails $implementationdir $compilerword $err" >&5
|
299
|
+
done
|
300
|
+
continue
|
301
|
+
fi
|
302
|
+
|
303
|
+
checksumok=fails
|
304
|
+
[ "x$expectedchecksum" = "x$checksum" ] && checksumok=ok
|
305
|
+
[ "x$expectedchecksum" = "x" ] && checksumok=unknown
|
306
|
+
echo "$version $shorthostname $abi $startdate $o $p try $checksum $checksumok $cycles $checksumcycles $cyclespersecond $impl $compilerword" >&5
|
307
|
+
[ "$checksumok" = fails ] && continue
|
308
|
+
|
309
|
+
[ -s ../bestmedian ] && [ `cat ../bestmedian` -le $cycles ] && continue
|
310
|
+
echo "$cycles" > ../bestmedian
|
311
|
+
|
312
|
+
$compiler -D'COMPILER="'"$compiler"'"' \
|
313
|
+
-DLOOPS=1 \
|
314
|
+
-I. -I"$include" -I"$include/$abi" \
|
315
|
+
-o measure measure.c measure-anything.c \
|
316
|
+
"$op.a" $libs >../errors 2>&1 || ok=0
|
317
|
+
cat ../errors \
|
318
|
+
| while read err
|
319
|
+
do
|
320
|
+
echo "$version $shorthostname $abi $startdate $o $p fromcompiler $implementationdir $compilerword measure.c $err" >&5
|
321
|
+
done
|
322
|
+
[ "$ok" = 1 ] || continue
|
323
|
+
|
324
|
+
for f in $cppfiles
|
325
|
+
do
|
326
|
+
okcpp-$abi \
|
327
|
+
| while read cppcompiler
|
328
|
+
do
|
329
|
+
echo "=== `date` === $abi $implementationdir $cppcompiler"
|
330
|
+
$cppcompiler \
|
331
|
+
-I. -I"$include" -I"$include/$abi" \
|
332
|
+
-c "$f" && break
|
333
|
+
done
|
334
|
+
done
|
335
|
+
|
336
|
+
rm -f ../best/*.o ../best/measure || continue
|
337
|
+
for f in *.o
|
338
|
+
do
|
339
|
+
cp -p "$f" "../best/${opi}-$f"
|
340
|
+
done
|
341
|
+
cp -p "$op.h" "../$op.h"
|
342
|
+
cp -p "$o.h" "../$o.h"
|
343
|
+
cp -p measure ../best/measure
|
344
|
+
done
|
345
|
+
)
|
346
|
+
done
|
347
|
+
|
348
|
+
echo "=== `date` === $abi $o/$p measuring"
|
349
|
+
|
350
|
+
"$work/best/measure" \
|
351
|
+
| while read measurement
|
352
|
+
do
|
353
|
+
echo "$version $shorthostname $abi $startdate $o $p $measurement" >&5
|
354
|
+
done
|
355
|
+
|
356
|
+
[ -f "$o/$p/used" ] \
|
357
|
+
&& okar-$abi cr "$lib/$abi/lib${project}.a" "$work/best"/*.o \
|
358
|
+
&& ( ranlib "$lib/$abi/lib${project}.a" || exit 0 ) \
|
359
|
+
&& cp -p "$work/$op.h" "$include/$abi/$op.h" \
|
360
|
+
&& [ -f "$o/$p/selected" ] \
|
361
|
+
&& cp -p "$work/$o.h" "$include/$abi/$o.h" \
|
362
|
+
|| :
|
363
|
+
done
|
364
|
+
done
|
365
|
+
done
|
366
|
+
|
367
|
+
for language in c cpp
|
368
|
+
do
|
369
|
+
for bintype in commandline tests
|
370
|
+
do
|
371
|
+
ls $bintype \
|
372
|
+
| sed -n 's/\.'$language'$//p' \
|
373
|
+
| sort \
|
374
|
+
| while read cmd
|
375
|
+
do
|
376
|
+
echo "=== `date` === starting $bintype/$cmd"
|
377
|
+
|
378
|
+
rm -rf "$work"
|
379
|
+
mkdir -p "$work/compile"
|
380
|
+
|
381
|
+
cp "$bintype/$cmd.$language" "$work/compile/$cmd.$language"
|
382
|
+
[ "$bintype" = tests ] && cp -p "$bintype/$cmd.out" "$work/compile/$cmd.out"
|
383
|
+
|
384
|
+
okabi \
|
385
|
+
| while read abi
|
386
|
+
do
|
387
|
+
[ -x "$bin/$cmd" ] && break
|
388
|
+
|
389
|
+
libs=`"oklibs-$abi"`
|
390
|
+
libs="$lib/$abi/cpucycles.o $libs"
|
391
|
+
libs="$libs $lib/$abi/randombytes.o"
|
392
|
+
|
393
|
+
ok${language}-$abi \
|
394
|
+
| while read compiler
|
395
|
+
do
|
396
|
+
[ -x "$bin/$cmd" ] && break
|
397
|
+
|
398
|
+
echo "=== `date` === $bintype/$cmd $abi $compiler"
|
399
|
+
(
|
400
|
+
cd "$work/compile"
|
401
|
+
if $compiler \
|
402
|
+
-I"$include" -I"$include/$abi" \
|
403
|
+
-o "$cmd" "$cmd.${language}" \
|
404
|
+
"$lib/$abi/lib${project}.a" $libs
|
405
|
+
then
|
406
|
+
case "$bintype" in
|
407
|
+
commandline) cp -p "$cmd" "$bin/$cmd" ;;
|
408
|
+
tests) "./$cmd" | cmp - "$cmd.out" || "./$cmd" ;;
|
409
|
+
esac
|
410
|
+
fi
|
411
|
+
)
|
412
|
+
done
|
413
|
+
done
|
414
|
+
done
|
415
|
+
done
|
416
|
+
done
|
417
|
+
|
418
|
+
echo "=== `date` === starting curvecp"
|
419
|
+
|
420
|
+
okabi \
|
421
|
+
| awk '
|
422
|
+
{ if ($1=="amd64" || $1=="ia64" || $1=="ppc64" || $1=="sparcv9" || $1=="mips64") print 1,$1
|
423
|
+
else if ($1 == "mips32") print 2,$1
|
424
|
+
else print 3,$1
|
425
|
+
}
|
426
|
+
' \
|
427
|
+
| sort \
|
428
|
+
| while read okabipriority abi
|
429
|
+
do
|
430
|
+
[ -x "$bin/curvecpmessage" ] && break
|
431
|
+
libs=`"oklibs-$abi"`
|
432
|
+
libs="$lib/$abi/cpucycles.o $libs"
|
433
|
+
libs="$libs $lib/$abi/randombytes.o"
|
434
|
+
|
435
|
+
okc-$abi \
|
436
|
+
| while read compiler
|
437
|
+
do
|
438
|
+
[ -x "$bin/curvecpmessage" ] && break
|
439
|
+
|
440
|
+
echo "=== `date` === curvecp $abi $compiler"
|
441
|
+
rm -rf "$work"
|
442
|
+
mkdir -p "$work/compile"
|
443
|
+
cp curvecp/* "$work/compile"
|
444
|
+
(
|
445
|
+
cd "$work/compile"
|
446
|
+
cat SOURCES \
|
447
|
+
| while read x
|
448
|
+
do
|
449
|
+
$compiler -I"$include" -I"$include/$abi" -c "$x.c"
|
450
|
+
done
|
451
|
+
|
452
|
+
if okar-$abi cr curvecplibs.a `cat LIBS`
|
453
|
+
then
|
454
|
+
cat TARGETS \
|
455
|
+
| while read x
|
456
|
+
do
|
457
|
+
$compiler -I"$include" -I"$include/$abi" \
|
458
|
+
-o "$x" "$x.o" \
|
459
|
+
curvecplibs.a "$lib/$abi/lib${project}.a" $libs \
|
460
|
+
&& cp -p "$x" "$bin/$x"
|
461
|
+
done
|
462
|
+
fi
|
463
|
+
)
|
464
|
+
done
|
465
|
+
|
466
|
+
done
|
467
|
+
|
468
|
+
echo "=== `date` === finishing"
|
@@ -0,0 +1,47 @@
|
|
1
|
+
#!/bin/sh -e
|
2
|
+
|
3
|
+
okabi | (
|
4
|
+
while read abi
|
5
|
+
do
|
6
|
+
(
|
7
|
+
echo 'int8 signed char'
|
8
|
+
echo 'int16 short'
|
9
|
+
echo 'int32 int'
|
10
|
+
echo 'int32 long'
|
11
|
+
echo 'int64 long long'
|
12
|
+
echo 'int64 long'
|
13
|
+
echo 'int64 int __attribute__((__mode__(__DI__)))'
|
14
|
+
echo 'uint8 unsigned char'
|
15
|
+
echo 'uint16 unsigned short'
|
16
|
+
echo 'uint32 unsigned int'
|
17
|
+
echo 'uint32 unsigned long'
|
18
|
+
echo 'uint64 unsigned long long'
|
19
|
+
echo 'uint64 unsigned long'
|
20
|
+
echo 'uint64 unsigned int __attribute__((__mode__(__DI__)))'
|
21
|
+
) | (
|
22
|
+
while read target source
|
23
|
+
do
|
24
|
+
okc-$abi | (
|
25
|
+
while read c
|
26
|
+
do
|
27
|
+
[ -f include/$abi/crypto_$target.h ] && continue
|
28
|
+
echo "=== `date` === $abi trying $source as $target under $c..." >&2
|
29
|
+
rm -f crypto_$target crypto_$target.h
|
30
|
+
(
|
31
|
+
echo "#ifndef crypto_${target}_h"
|
32
|
+
echo "#define crypto_${target}_h"
|
33
|
+
echo ""
|
34
|
+
echo "typedef ${source} crypto_${target};"
|
35
|
+
echo ""
|
36
|
+
echo "#endif"
|
37
|
+
) > crypto_$target.h
|
38
|
+
$c -o crypto_$target crypto_$target.c || continue
|
39
|
+
./crypto_$target || continue
|
40
|
+
mkdir -p include/$abi
|
41
|
+
cp crypto_$target.h include/$abi/crypto_$target.h
|
42
|
+
done
|
43
|
+
)
|
44
|
+
done
|
45
|
+
)
|
46
|
+
done
|
47
|
+
)
|
@@ -0,0 +1,17 @@
|
|
1
|
+
#define DOIT(bits,target) \
|
2
|
+
int main() \
|
3
|
+
{ \
|
4
|
+
target x; \
|
5
|
+
int i; \
|
6
|
+
\
|
7
|
+
x = 1; \
|
8
|
+
for (i = 0;i < bits;++i) { \
|
9
|
+
if (x == 0) return 100; \
|
10
|
+
x += x; \
|
11
|
+
} \
|
12
|
+
if (x != 0) return 100; \
|
13
|
+
x -= 1; \
|
14
|
+
if (x > 0) return 100; \
|
15
|
+
\
|
16
|
+
return 0; \
|
17
|
+
}
|
@@ -0,0 +1,17 @@
|
|
1
|
+
#define DOIT(bits,target) \
|
2
|
+
int main() \
|
3
|
+
{ \
|
4
|
+
target x; \
|
5
|
+
int i; \
|
6
|
+
\
|
7
|
+
x = 1; \
|
8
|
+
for (i = 0;i < bits;++i) { \
|
9
|
+
if (x == 0) return 100; \
|
10
|
+
x += x; \
|
11
|
+
} \
|
12
|
+
if (x != 0) return 100; \
|
13
|
+
x -= 1; \
|
14
|
+
if (x < 0) return 100; \
|
15
|
+
\
|
16
|
+
return 0; \
|
17
|
+
}
|