X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=crc%2Ftest.c;h=213b5d5ff72939be77bd1c3ad47069b1c7feb4a9;hb=5921cea2cf9607101ed28d57c939a7dc0898b3d3;hp=63963d0f0b8aed80570948041c7e66bb624b6c12;hpb=d78bbd4c3f3f58ad2a6699c416ea773faa097519;p=fio.git diff --git a/crc/test.c b/crc/test.c index 63963d0f..213b5d5f 100644 --- a/crc/test.c +++ b/crc/test.c @@ -17,7 +17,9 @@ #include "../crc/sha256.h" #include "../crc/sha512.h" #include "../crc/xxhash.h" -#include "../lib/murmur3.h" +#include "../crc/murmur3.h" +#include "../crc/fnv.h" +#include "../hash.h" #include "test.h" @@ -27,7 +29,8 @@ struct test_type { const char *name; unsigned int mask; - void (*fn)(void *, size_t); + void (*fn)(struct test_type *, void *, size_t); + uint32_t output; }; enum { @@ -42,9 +45,11 @@ enum { T_SHA512 = 1U << 8, T_XXHASH = 1U << 9, T_MURMUR3 = 1U << 10, + T_JHASH = 1U << 11, + T_FNV = 1U << 12, }; -static void t_md5(void *buf, size_t size) +static void t_md5(struct test_type *t, void *buf, size_t size) { uint32_t digest[4]; struct fio_md5_ctx ctx = { .hash = digest }; @@ -52,53 +57,53 @@ static void t_md5(void *buf, size_t size) fio_md5_init(&ctx); - for (i = 0; i < NR_CHUNKS; i++) + for (i = 0; i < NR_CHUNKS; i++) { fio_md5_update(&ctx, buf, size); - - fio_md5_final(&ctx); + fio_md5_final(&ctx); + } } -static void t_crc64(void *buf, size_t size) +static void t_crc64(struct test_type *t, void *buf, size_t size) { int i; for (i = 0; i < NR_CHUNKS; i++) - fio_crc64(buf, size); + t->output += fio_crc64(buf, size); } -static void t_crc32(void *buf, size_t size) +static void t_crc32(struct test_type *t, void *buf, size_t size) { int i; for (i = 0; i < NR_CHUNKS; i++) - fio_crc32(buf, size); + t->output += fio_crc32(buf, size); } -static void t_crc32c(void *buf, size_t size) +static void t_crc32c(struct test_type *t, void *buf, size_t size) { int i; for (i = 0; i < NR_CHUNKS; i++) - fio_crc32c(buf, size); + t->output += fio_crc32c(buf, size); } -static void t_crc16(void *buf, size_t size) +static void t_crc16(struct test_type *t, void *buf, size_t size) { int i; for (i = 0; i < NR_CHUNKS; i++) - fio_crc16(buf, size); + t->output += fio_crc16(buf, size); } -static void t_crc7(void *buf, size_t size) +static void t_crc7(struct test_type *t, void *buf, size_t size) { int i; for (i = 0; i < NR_CHUNKS; i++) - fio_crc7(buf, size); + t->output += fio_crc7(buf, size); } -static void t_sha1(void *buf, size_t size) +static void t_sha1(struct test_type *t, void *buf, size_t size) { uint32_t sha[5]; struct fio_sha1_ctx ctx = { .H = sha }; @@ -106,11 +111,13 @@ static void t_sha1(void *buf, size_t size) fio_sha1_init(&ctx); - for (i = 0; i < NR_CHUNKS; i++) + for (i = 0; i < NR_CHUNKS; i++) { fio_sha1_update(&ctx, buf, size); + fio_sha1_final(&ctx); + } } -static void t_sha256(void *buf, size_t size) +static void t_sha256(struct test_type *t, void *buf, size_t size) { uint8_t sha[64]; struct fio_sha256_ctx ctx = { .buf = sha }; @@ -118,13 +125,13 @@ static void t_sha256(void *buf, size_t size) fio_sha256_init(&ctx); - for (i = 0; i < NR_CHUNKS; i++) + for (i = 0; i < NR_CHUNKS; i++) { fio_sha256_update(&ctx, buf, size); - - fio_sha256_final(&ctx); + fio_sha256_final(&ctx); + } } -static void t_sha512(void *buf, size_t size) +static void t_sha512(struct test_type *t, void *buf, size_t size) { uint8_t sha[128]; struct fio_sha512_ctx ctx = { .buf = sha }; @@ -136,15 +143,31 @@ static void t_sha512(void *buf, size_t size) fio_sha512_update(&ctx, buf, size); } -static void t_murmur3(void *buf, size_t size) +static void t_murmur3(struct test_type *t, void *buf, size_t size) +{ + int i; + + for (i = 0; i < NR_CHUNKS; i++) + t->output += murmurhash3(buf, size, 0x8989); +} + +static void t_jhash(struct test_type *t, void *buf, size_t size) +{ + int i; + + for (i = 0; i < NR_CHUNKS; i++) + t->output += jhash(buf, size, 0x8989); +} + +static void t_fnv(struct test_type *t, void *buf, size_t size) { int i; for (i = 0; i < NR_CHUNKS; i++) - murmurhash3(buf, size, 0x8989); + t->output += fnv(buf, size, 0x8989); } -static void t_xxhash(void *buf, size_t size) +static void t_xxhash(struct test_type *t, void *buf, size_t size) { void *state; int i; @@ -154,7 +177,7 @@ static void t_xxhash(void *buf, size_t size) for (i = 0; i < NR_CHUNKS; i++) XXH32_update(state, buf, size); - XXH32_digest(state); + t->output = XXH32_digest(state); } static struct test_type t[] = { @@ -213,6 +236,16 @@ static struct test_type t[] = { .mask = T_MURMUR3, .fn = t_murmur3, }, + { + .name = "jhash", + .mask = T_JHASH, + .fn = t_jhash, + }, + { + .name = "fnv", + .mask = T_FNV, + .fn = t_fnv, + }, { .name = NULL, }, @@ -273,7 +306,7 @@ int fio_crctest(const char *type) } buf = malloc(CHUNK); - init_rand_seed(&state, 0x8989); + init_rand_seed(&state, 0x8989, 0); fill_random_buf(&state, buf, CHUNK); for (i = 0; t[i].name; i++) { @@ -291,20 +324,23 @@ int fio_crctest(const char *type) */ if (first) { usec_spin(100000); - t[i].fn(buf, CHUNK); + t[i].fn(&t[i], buf, CHUNK); } fio_gettime(&tv, NULL); - t[i].fn(buf, CHUNK); + t[i].fn(&t[i], buf, CHUNK); usec = utime_since_now(&tv); - mb_sec = (double) mb / (double) usec; - mb_sec /= (1.024 * 1.024); - if (strlen(t[i].name) >= 7) - sprintf(pre, "\t"); - else - sprintf(pre, "\t\t"); - printf("%s:%s%8.2f MB/sec\n", t[i].name, pre, mb_sec); + if (usec) { + mb_sec = (double) mb / (double) usec; + mb_sec /= (1.024 * 1.024); + if (strlen(t[i].name) >= 7) + sprintf(pre, "\t"); + else + sprintf(pre, "\t\t"); + printf("%s:%s%8.2f MB/sec\n", t[i].name, pre, mb_sec); + } else + printf("%s:inf MB/sec\n", t[i].name); first = 0; }