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