1*49cdfc7eSAndroid Build Coastguard Worker // SPDX-License-Identifier: GPL-2.0-or-later
2*49cdfc7eSAndroid Build Coastguard Worker /*
3*49cdfc7eSAndroid Build Coastguard Worker * Copyright 2019 Google LLC
4*49cdfc7eSAndroid Build Coastguard Worker * Copyright (c) Linux Test Project, 2019-2021
5*49cdfc7eSAndroid Build Coastguard Worker */
6*49cdfc7eSAndroid Build Coastguard Worker
7*49cdfc7eSAndroid Build Coastguard Worker /*
8*49cdfc7eSAndroid Build Coastguard Worker * Regression test for commit bb2964810233 ("crypto: vmac - separate tfm and
9*49cdfc7eSAndroid Build Coastguard Worker * request context"). This test verifies that a VMAC transform can be used by
10*49cdfc7eSAndroid Build Coastguard Worker * multiple concurrent hash requests without crashing the kernel. Based on the
11*49cdfc7eSAndroid Build Coastguard Worker * reproducer from the commit message.
12*49cdfc7eSAndroid Build Coastguard Worker */
13*49cdfc7eSAndroid Build Coastguard Worker
14*49cdfc7eSAndroid Build Coastguard Worker #include <stdio.h>
15*49cdfc7eSAndroid Build Coastguard Worker #include <sys/wait.h>
16*49cdfc7eSAndroid Build Coastguard Worker
17*49cdfc7eSAndroid Build Coastguard Worker #include "tst_test.h"
18*49cdfc7eSAndroid Build Coastguard Worker #include "tst_af_alg.h"
19*49cdfc7eSAndroid Build Coastguard Worker
test_with_symm_enc_algs(const char * symm_enc_algname)20*49cdfc7eSAndroid Build Coastguard Worker static void test_with_symm_enc_algs(const char *symm_enc_algname)
21*49cdfc7eSAndroid Build Coastguard Worker {
22*49cdfc7eSAndroid Build Coastguard Worker int algfd, reqfd;
23*49cdfc7eSAndroid Build Coastguard Worker char buf[256] = { 0 };
24*49cdfc7eSAndroid Build Coastguard Worker char vmac_algname[64];
25*49cdfc7eSAndroid Build Coastguard Worker pid_t pid;
26*49cdfc7eSAndroid Build Coastguard Worker int status;
27*49cdfc7eSAndroid Build Coastguard Worker int i;
28*49cdfc7eSAndroid Build Coastguard Worker
29*49cdfc7eSAndroid Build Coastguard Worker sprintf(vmac_algname, "vmac64(%s)", symm_enc_algname);
30*49cdfc7eSAndroid Build Coastguard Worker if (!tst_have_alg("hash", vmac_algname)) {
31*49cdfc7eSAndroid Build Coastguard Worker sprintf(vmac_algname, "vmac(%s)", symm_enc_algname);
32*49cdfc7eSAndroid Build Coastguard Worker if (!tst_have_alg("hash", vmac_algname))
33*49cdfc7eSAndroid Build Coastguard Worker return;
34*49cdfc7eSAndroid Build Coastguard Worker }
35*49cdfc7eSAndroid Build Coastguard Worker algfd = tst_alg_setup("hash", vmac_algname, NULL, 16);
36*49cdfc7eSAndroid Build Coastguard Worker
37*49cdfc7eSAndroid Build Coastguard Worker tst_res(TINFO, "Starting vmac hashing test. May crash buggy kernels.");
38*49cdfc7eSAndroid Build Coastguard Worker
39*49cdfc7eSAndroid Build Coastguard Worker pid = SAFE_FORK();
40*49cdfc7eSAndroid Build Coastguard Worker
41*49cdfc7eSAndroid Build Coastguard Worker reqfd = tst_alg_accept(algfd);
42*49cdfc7eSAndroid Build Coastguard Worker
43*49cdfc7eSAndroid Build Coastguard Worker for (i = 0; i < 500000; i++)
44*49cdfc7eSAndroid Build Coastguard Worker SAFE_WRITE(SAFE_WRITE_ALL, reqfd, buf, sizeof(buf));
45*49cdfc7eSAndroid Build Coastguard Worker
46*49cdfc7eSAndroid Build Coastguard Worker close(reqfd);
47*49cdfc7eSAndroid Build Coastguard Worker
48*49cdfc7eSAndroid Build Coastguard Worker if (pid != 0) {
49*49cdfc7eSAndroid Build Coastguard Worker SAFE_WAIT(&status);
50*49cdfc7eSAndroid Build Coastguard Worker if (WIFEXITED(status) && WEXITSTATUS(status) == 0)
51*49cdfc7eSAndroid Build Coastguard Worker tst_res(TPASS, "didn't crash");
52*49cdfc7eSAndroid Build Coastguard Worker else if (WIFSIGNALED(status) && WTERMSIG(status) == SIGKILL)
53*49cdfc7eSAndroid Build Coastguard Worker tst_res(TFAIL, "crashed");
54*49cdfc7eSAndroid Build Coastguard Worker else
55*49cdfc7eSAndroid Build Coastguard Worker tst_brk(TBROK, "child %s", tst_strstatus(status));
56*49cdfc7eSAndroid Build Coastguard Worker
57*49cdfc7eSAndroid Build Coastguard Worker close(algfd);
58*49cdfc7eSAndroid Build Coastguard Worker }
59*49cdfc7eSAndroid Build Coastguard Worker }
60*49cdfc7eSAndroid Build Coastguard Worker
61*49cdfc7eSAndroid Build Coastguard Worker /* try several different symmetric encryption algorithms */
62*49cdfc7eSAndroid Build Coastguard Worker static const char * const symm_enc_algs[] = {
63*49cdfc7eSAndroid Build Coastguard Worker "aes",
64*49cdfc7eSAndroid Build Coastguard Worker "sm4",
65*49cdfc7eSAndroid Build Coastguard Worker "sm4-generic",
66*49cdfc7eSAndroid Build Coastguard Worker };
67*49cdfc7eSAndroid Build Coastguard Worker
do_test(unsigned int i)68*49cdfc7eSAndroid Build Coastguard Worker static void do_test(unsigned int i)
69*49cdfc7eSAndroid Build Coastguard Worker {
70*49cdfc7eSAndroid Build Coastguard Worker test_with_symm_enc_algs(symm_enc_algs[i]);
71*49cdfc7eSAndroid Build Coastguard Worker }
72*49cdfc7eSAndroid Build Coastguard Worker
73*49cdfc7eSAndroid Build Coastguard Worker static struct tst_test test = {
74*49cdfc7eSAndroid Build Coastguard Worker .test = do_test,
75*49cdfc7eSAndroid Build Coastguard Worker .tcnt = ARRAY_SIZE(symm_enc_algs),
76*49cdfc7eSAndroid Build Coastguard Worker .forks_child = 1,
77*49cdfc7eSAndroid Build Coastguard Worker .tags = (const struct tst_tag[]) {
78*49cdfc7eSAndroid Build Coastguard Worker {"linux-git", "bb2964810233"},
79*49cdfc7eSAndroid Build Coastguard Worker {}
80*49cdfc7eSAndroid Build Coastguard Worker }
81*49cdfc7eSAndroid Build Coastguard Worker };
82