import # Internals ../constantine/hashes, # Helpers ../helpers/prng_unsafe, ./bench_blueprint proc separator*() = separator(69) # Deal with platform mess # -------------------------------------------------------------------- when defined(windows): when sizeof(int) == 8: const DLLSSLName* = "(libssl-1_1-x64|ssleay64|libssl64).dll" else: const DLLSSLName* = "(libssl-1_1|ssleay32|libssl32).dll" else: when defined(macosx): const versions = "(.1.1|.38|.39|.41|.43|.44|.45|.46|.47|.48|.10|.1.0.2|.1.0.1|.1.0.0|.0.9.9|.0.9.8|)" else: const versions = "(.1.1|.1.0.2|.1.0.1|.1.0.0|.0.9.9|.0.9.8|.48|.47|.46|.45|.44|.43|.41|.39|.38|.10|)" when defined(macosx): const DLLSSLName* = "libssl" & versions & ".dylib" elif defined(genode): const DLLSSLName* = "libssl.lib.so" else: const DLLSSLName* = "libssl.so" & versions # OpenSSL wrapper # -------------------------------------------------------------------- proc SHA256[T: byte|char]( msg: openarray[T], digest: ptr array[32, byte] = nil ): ptr array[32, byte] {.cdecl, dynlib: DLLSSLName, importc.} proc SHA256_OpenSSL[T: byte|char]( digest: var array[32, byte], s: openarray[T]) = discard SHA256(s, digest.addr) # -------------------------------------------------------------------- proc report(op: string, bytes: int, startTime, stopTime: MonoTime, startClk, stopClk: int64, iters: int) = let ns = inNanoseconds((stopTime-startTime) div iters) let throughput = 1e9 / float64(ns) when SupportsGetTicks: let cycles = (stopClk - startClk) div iters let cyclePerByte = cycles.float64 / bytes.float64 echo &"{op:<30} {throughput:>15.3f} ops/s {ns:>9} ns/op {cycles:>10} cycles {cyclePerByte:>5.2f} cycles/byte" else: echo &"{op:<30} {throughput:>15.3f} ops/s {ns:>9} ns/op" template bench(op: string, bytes: int, iters: int, body: untyped): untyped = measure(iters, startTime, stopTime, startClk, stopClk, body) report(op, bytes, startTime, stopTime, startClk, stopClk, iters) proc benchSHA256_constantine[T](msg: openarray[T], msgComment: string, iters: int) = var digest: array[32, byte] bench("SHA256 - Constantine - " & msgComment, msg.len, iters): sha256.hash(digest, msg) proc benchSHA256_openssl[T](msg: openarray[T], msgComment: string, iters: int) = var digest: array[32, byte] bench("SHA256 - OpenSSL - " & msgComment, msg.len, iters): SHA256_OpenSSL(digest, msg) when isMainModule: proc main() = block: let msg32B = rng.random_byte_seq(32) benchSHA256_constantine(msg32B, "32B", 100) benchSHA256_openssl(msg32B, "32B", 100) block: let msg64B = rng.random_byte_seq(64) benchSHA256_constantine(msg64B, "64B", 100) benchSHA256_openssl(msg64B, "64B", 100) block: let msg128B = rng.random_byte_seq(128) benchSHA256_constantine(msg128B, "128B", 100) benchSHA256_openssl(msg128B, "128B", 100) block: let msg576B = rng.random_byte_seq(576) benchSHA256_constantine(msg576B, "576B", 50) benchSHA256_openssl(msg576B, "576B", 50) block: let msg8192B = rng.random_byte_seq(8192) benchSHA256_constantine(msg8192B, "8192B", 25) benchSHA256_openssl(msg8192B, "8192B", 25) block: let msg1MB = rng.random_byte_seq(1_000_000) benchSHA256_constantine(msg1MB, "1MB", 16) benchSHA256_openssl(msg1MB, "1MB", 16) block: let msg10MB = rng.random_byte_seq(10_000_000) benchSHA256_constantine(msg10MB, "10MB", 16) benchSHA256_openssl(msg10MB, "10MB", 16) block: let msg100MB = rng.random_byte_seq(100_000_000) benchSHA256_constantine(msg100MB, "100MB", 3) benchSHA256_openssl(msg100MB, "100MB", 3) main()