blob: 8532ffa8de8397e6cc17412c3269bbe5d5b367ca [file] [log] [blame]
/* Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#include <stdio.h>
#include <stdlib.h>
#include "cryptolib.h"
#include "timer_utils.h"
#include "utility.h"
#define NUM_HASH_ALGORITHMS 3
#define TEST_BUFFER_SIZE 4000000
/* Table of hash function pointers and their description. */
typedef uint8_t* (*Hashptr) (const uint8_t*, uint64_t, uint8_t*);
typedef struct HashFxTable {
Hashptr hash;
char* description;
} HashFxTable;
HashFxTable hash_functions[NUM_HASH_ALGORITHMS] = {
{SHA1, "sha1"},
{SHA256, "sha256"},
{SHA512, "sha512"}
};
int main(int argc, char* argv[]) {
int i;
double speed;
uint32_t msecs;
uint8_t* buffer = (uint8_t*) Malloc(TEST_BUFFER_SIZE);
uint8_t* digest = (uint8_t*) Malloc(SHA512_DIGEST_SIZE); /* Maximum size of
* the digest. */
ClockTimerState ct;
/* Iterate through all the hash functions. */
for(i = 0; i < NUM_HASH_ALGORITHMS; i++) {
StartTimer(&ct);
hash_functions[i].hash(buffer, TEST_BUFFER_SIZE, digest);
StopTimer(&ct);
msecs = GetDurationMsecs(&ct);
speed = ((TEST_BUFFER_SIZE / 10e6)
/ (msecs / 10e3)); /* Mbytes/sec */
fprintf(stderr, "# %s Time taken = %u ms, Speed = %f Mbytes/sec\n",
hash_functions[i].description, msecs, speed);
fprintf(stdout, "mbytes_per_sec_%s:%f\n",
hash_functions[i].description, speed);
}
Free(digest);
Free(buffer);
return 0;
}