2 * QEMU Crypto hmac speed benchmark
4 * Copyright (c) 2017 HUAWEI TECHNOLOGIES CO., LTD.
7 * Longpeng(Mike) <longpeng2@huawei.com>
9 * This work is licensed under the terms of the GNU GPL, version 2 or
10 * (at your option) any later version. See the COPYING file in the
11 * top-level directory.
13 #include "qemu/osdep.h"
14 #include "qemu/units.h"
15 #include "crypto/init.h"
16 #include "crypto/hmac.h"
18 #define KEY "monkey monkey monkey monkey"
20 static void test_hmac_speed(const void *opaque
)
22 size_t chunk_size
= (size_t)opaque
;
23 QCryptoHmac
*hmac
= NULL
;
24 uint8_t *in
= NULL
, *out
= NULL
;
31 if (!qcrypto_hmac_supports(QCRYPTO_HASH_ALG_SHA256
)) {
35 in
= g_new0(uint8_t, chunk_size
);
36 memset(in
, g_test_rand_int(), chunk_size
);
38 iov
.iov_base
= (char *)in
;
39 iov
.iov_len
= chunk_size
;
43 hmac
= qcrypto_hmac_new(QCRYPTO_HASH_ALG_SHA256
,
44 (const uint8_t *)KEY
, strlen(KEY
), &err
);
45 g_assert(err
== NULL
);
46 g_assert(hmac
!= NULL
);
48 ret
= qcrypto_hmac_bytesv(hmac
, &iov
, 1, &out
, &out_len
, &err
);
50 g_assert(err
== NULL
);
52 qcrypto_hmac_free(hmac
);
55 } while (g_test_timer_elapsed() < 5.0);
58 g_print("hmac(sha256): ");
59 g_print("Testing chunk_size %zu bytes ", chunk_size
);
60 g_print("done: %.2f MB in %.2f secs: ", total
, g_test_timer_last());
61 g_print("%.2f MB/sec\n", total
/ g_test_timer_last());
67 int main(int argc
, char **argv
)
72 g_test_init(&argc
, &argv
, NULL
);
73 g_assert(qcrypto_init(NULL
) == 0);
75 for (i
= 512; i
<= 64 * KiB
; i
*= 2) {
76 memset(name
, 0 , sizeof(name
));
77 snprintf(name
, sizeof(name
), "/crypto/hmac/speed-%zu", i
);
78 g_test_add_data_func(name
, (void *)i
, test_hmac_speed
);