1*5071c229SJamin Lin /*
2*5071c229SJamin Lin * QTest testcase for the ASPEED Hash and Crypto Engine
3*5071c229SJamin Lin *
4*5071c229SJamin Lin * SPDX-License-Identifier: GPL-2.0-or-later
5*5071c229SJamin Lin * Copyright (C) 2025 ASPEED Technology Inc.
6*5071c229SJamin Lin */
7*5071c229SJamin Lin
8*5071c229SJamin Lin #include "qemu/osdep.h"
9*5071c229SJamin Lin #include "libqtest.h"
10*5071c229SJamin Lin #include "qemu/bitops.h"
11*5071c229SJamin Lin #include "aspeed-hace-utils.h"
12*5071c229SJamin Lin
13*5071c229SJamin Lin static const struct AspeedMasks as2700_masks = {
14*5071c229SJamin Lin .src = 0x7fffffff,
15*5071c229SJamin Lin .dest = 0x7ffffff8,
16*5071c229SJamin Lin .key = 0x7ffffff8,
17*5071c229SJamin Lin .len = 0x0fffffff,
18*5071c229SJamin Lin .src_hi = 0x00000003,
19*5071c229SJamin Lin .dest_hi = 0x00000003,
20*5071c229SJamin Lin .key_hi = 0x00000003,
21*5071c229SJamin Lin };
22*5071c229SJamin Lin
23*5071c229SJamin Lin /* ast2700 */
test_md5_ast2700(void)24*5071c229SJamin Lin static void test_md5_ast2700(void)
25*5071c229SJamin Lin {
26*5071c229SJamin Lin aspeed_test_md5("-machine ast2700a1-evb", 0x12070000, 0x400000000);
27*5071c229SJamin Lin }
28*5071c229SJamin Lin
test_sha256_ast2700(void)29*5071c229SJamin Lin static void test_sha256_ast2700(void)
30*5071c229SJamin Lin {
31*5071c229SJamin Lin aspeed_test_sha256("-machine ast2700a1-evb", 0x12070000, 0x400000000);
32*5071c229SJamin Lin }
33*5071c229SJamin Lin
test_sha256_sg_ast2700(void)34*5071c229SJamin Lin static void test_sha256_sg_ast2700(void)
35*5071c229SJamin Lin {
36*5071c229SJamin Lin aspeed_test_sha256_sg("-machine ast2700a1-evb", 0x12070000, 0x400000000);
37*5071c229SJamin Lin }
38*5071c229SJamin Lin
test_sha384_ast2700(void)39*5071c229SJamin Lin static void test_sha384_ast2700(void)
40*5071c229SJamin Lin {
41*5071c229SJamin Lin aspeed_test_sha384("-machine ast2700a1-evb", 0x12070000, 0x400000000);
42*5071c229SJamin Lin }
43*5071c229SJamin Lin
test_sha384_sg_ast2700(void)44*5071c229SJamin Lin static void test_sha384_sg_ast2700(void)
45*5071c229SJamin Lin {
46*5071c229SJamin Lin aspeed_test_sha384_sg("-machine ast2700a1-evb", 0x12070000, 0x400000000);
47*5071c229SJamin Lin }
48*5071c229SJamin Lin
test_sha512_ast2700(void)49*5071c229SJamin Lin static void test_sha512_ast2700(void)
50*5071c229SJamin Lin {
51*5071c229SJamin Lin aspeed_test_sha512("-machine ast2700a1-evb", 0x12070000, 0x400000000);
52*5071c229SJamin Lin }
53*5071c229SJamin Lin
test_sha512_sg_ast2700(void)54*5071c229SJamin Lin static void test_sha512_sg_ast2700(void)
55*5071c229SJamin Lin {
56*5071c229SJamin Lin aspeed_test_sha512_sg("-machine ast2700a1-evb", 0x12070000, 0x400000000);
57*5071c229SJamin Lin }
58*5071c229SJamin Lin
test_sha256_accum_ast2700(void)59*5071c229SJamin Lin static void test_sha256_accum_ast2700(void)
60*5071c229SJamin Lin {
61*5071c229SJamin Lin aspeed_test_sha256_accum("-machine ast2700a1-evb", 0x12070000, 0x400000000);
62*5071c229SJamin Lin }
63*5071c229SJamin Lin
test_sha384_accum_ast2700(void)64*5071c229SJamin Lin static void test_sha384_accum_ast2700(void)
65*5071c229SJamin Lin {
66*5071c229SJamin Lin aspeed_test_sha384_accum("-machine ast2700a1-evb", 0x12070000, 0x400000000);
67*5071c229SJamin Lin }
68*5071c229SJamin Lin
test_sha512_accum_ast2700(void)69*5071c229SJamin Lin static void test_sha512_accum_ast2700(void)
70*5071c229SJamin Lin {
71*5071c229SJamin Lin aspeed_test_sha512_accum("-machine ast2700a1-evb", 0x12070000, 0x400000000);
72*5071c229SJamin Lin }
73*5071c229SJamin Lin
test_addresses_ast2700(void)74*5071c229SJamin Lin static void test_addresses_ast2700(void)
75*5071c229SJamin Lin {
76*5071c229SJamin Lin aspeed_test_addresses("-machine ast2700a1-evb", 0x12070000, &as2700_masks);
77*5071c229SJamin Lin }
78*5071c229SJamin Lin
main(int argc,char ** argv)79*5071c229SJamin Lin int main(int argc, char **argv)
80*5071c229SJamin Lin {
81*5071c229SJamin Lin g_test_init(&argc, &argv, NULL);
82*5071c229SJamin Lin
83*5071c229SJamin Lin qtest_add_func("ast2700/hace/addresses", test_addresses_ast2700);
84*5071c229SJamin Lin qtest_add_func("ast2700/hace/sha512", test_sha512_ast2700);
85*5071c229SJamin Lin qtest_add_func("ast2700/hace/sha384", test_sha384_ast2700);
86*5071c229SJamin Lin qtest_add_func("ast2700/hace/sha256", test_sha256_ast2700);
87*5071c229SJamin Lin qtest_add_func("ast2700/hace/md5", test_md5_ast2700);
88*5071c229SJamin Lin
89*5071c229SJamin Lin qtest_add_func("ast2700/hace/sha512_sg", test_sha512_sg_ast2700);
90*5071c229SJamin Lin qtest_add_func("ast2700/hace/sha384_sg", test_sha384_sg_ast2700);
91*5071c229SJamin Lin qtest_add_func("ast2700/hace/sha256_sg", test_sha256_sg_ast2700);
92*5071c229SJamin Lin
93*5071c229SJamin Lin qtest_add_func("ast2700/hace/sha512_accum", test_sha512_accum_ast2700);
94*5071c229SJamin Lin qtest_add_func("ast2700/hace/sha384_accum", test_sha384_accum_ast2700);
95*5071c229SJamin Lin qtest_add_func("ast2700/hace/sha256_accum", test_sha256_accum_ast2700);
96*5071c229SJamin Lin
97*5071c229SJamin Lin return g_test_run();
98*5071c229SJamin Lin }
99