Skip to content

Commit d1dbab5

Browse files
Hariharan Marifrankjaa
authored andcommitted
KVM: s390: selftests: Add regression tests for KMAC, KMC, KM, KIMD and KLMD crypto subfunctions
Extend the existing regression test framework for s390x CPU subfunctions to include tests for the KMAC (Compute Message Authentication Code), KMC (Cipher Message with Chaining), KM (Cipher Message) KIMD (Compute Intermediate Message Digest) and KLMD (Compute Last Message Digest) crypto functions. The test procedure follows the established pattern. Suggested-by: Janosch Frank <[email protected]> Signed-off-by: Hariharan Mari <[email protected]> Reviewed-by: Janosch Frank <[email protected]> Reviewed-by: Christoph Schlameuss <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Janosch Frank <[email protected]> Message-ID: <[email protected]>
1 parent 7f269dd commit d1dbab5

File tree

1 file changed

+61
-0
lines changed

1 file changed

+61
-0
lines changed

tools/testing/selftests/kvm/s390x/cpumodel_subfuncs_test.c

Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -33,6 +33,61 @@ static void get_cpu_machine_subfuntions(struct kvm_vm *vm,
3333
TEST_ASSERT(!r, "Get cpu subfunctions failed r=%d errno=%d", r, errno);
3434
}
3535

36+
/* Testing Crypto Compute Message Authentication Code (KMAC) CPU subfunction's ASM block */
37+
static void test_kmac_asm_block(u8 (*query)[16])
38+
{
39+
asm volatile(" la %%r1,%[query]\n"
40+
" xgr %%r0,%%r0\n"
41+
" .insn rre,0xb91e0000,0,2\n"
42+
: [query] "=R" (*query)
43+
:
44+
: "cc", "r0", "r1");
45+
}
46+
47+
/* Testing Crypto Cipher Message with Chaining (KMC) CPU subfunction's ASM block */
48+
static void test_kmc_asm_block(u8 (*query)[16])
49+
{
50+
asm volatile(" la %%r1,%[query]\n"
51+
" xgr %%r0,%%r0\n"
52+
" .insn rre,0xb92f0000,2,4\n"
53+
: [query] "=R" (*query)
54+
:
55+
: "cc", "r0", "r1");
56+
}
57+
58+
/* Testing Crypto Cipher Message (KM) CPU subfunction's ASM block */
59+
static void test_km_asm_block(u8 (*query)[16])
60+
{
61+
asm volatile(" la %%r1,%[query]\n"
62+
" xgr %%r0,%%r0\n"
63+
" .insn rre,0xb92e0000,2,4\n"
64+
: [query] "=R" (*query)
65+
:
66+
: "cc", "r0", "r1");
67+
}
68+
69+
/* Testing Crypto Compute Intermediate Message Digest (KIMD) CPU subfunction's ASM block */
70+
static void test_kimd_asm_block(u8 (*query)[16])
71+
{
72+
asm volatile(" la %%r1,%[query]\n"
73+
" xgr %%r0,%%r0\n"
74+
" .insn rre,0xb93e0000,0,2\n"
75+
: [query] "=R" (*query)
76+
:
77+
: "cc", "r0", "r1");
78+
}
79+
80+
/* Testing Crypto Compute Last Message Digest (KLMD) CPU subfunction's ASM block */
81+
static void test_klmd_asm_block(u8 (*query)[16])
82+
{
83+
asm volatile(" la %%r1,%[query]\n"
84+
" xgr %%r0,%%r0\n"
85+
" .insn rre,0xb93f0000,0,2\n"
86+
: [query] "=R" (*query)
87+
:
88+
: "cc", "r0", "r1");
89+
}
90+
3691
/* Testing Crypto Cipher Message with Counter (KMCTR) CPU subfunction's ASM block */
3792
static void test_kmctr_asm_block(u8 (*query)[16])
3893
{
@@ -141,6 +196,12 @@ struct testdef {
141196
testfunc_t test;
142197
int facility_bit;
143198
} testlist[] = {
199+
/* MSA - Facility bit 17 */
200+
{ "KMAC", cpu_subfunc.kmac, sizeof(cpu_subfunc.kmac), test_kmac_asm_block, 17 },
201+
{ "KMC", cpu_subfunc.kmc, sizeof(cpu_subfunc.kmc), test_kmc_asm_block, 17 },
202+
{ "KM", cpu_subfunc.km, sizeof(cpu_subfunc.km), test_km_asm_block, 17 },
203+
{ "KIMD", cpu_subfunc.kimd, sizeof(cpu_subfunc.kimd), test_kimd_asm_block, 17 },
204+
{ "KLMD", cpu_subfunc.klmd, sizeof(cpu_subfunc.klmd), test_klmd_asm_block, 17 },
144205
/* MSA - Facility bit 77 */
145206
{ "KMCTR", cpu_subfunc.kmctr, sizeof(cpu_subfunc.kmctr), test_kmctr_asm_block, 77 },
146207
{ "KMF", cpu_subfunc.kmf, sizeof(cpu_subfunc.kmf), test_kmf_asm_block, 77 },

0 commit comments

Comments
 (0)