136128a67SGowrishankar Muthukrishnan /* SPDX-License-Identifier: BSD-3-Clause
236128a67SGowrishankar Muthukrishnan * Copyright(C) 2022 Marvell.
336128a67SGowrishankar Muthukrishnan */
436128a67SGowrishankar Muthukrishnan
536128a67SGowrishankar Muthukrishnan #include <string.h>
636128a67SGowrishankar Muthukrishnan #include <time.h>
736128a67SGowrishankar Muthukrishnan #include <stdio.h>
836128a67SGowrishankar Muthukrishnan #include <sys/types.h>
936128a67SGowrishankar Muthukrishnan #include <unistd.h>
1036128a67SGowrishankar Muthukrishnan
1136128a67SGowrishankar Muthukrishnan #ifdef USE_OPENSSL
1236128a67SGowrishankar Muthukrishnan #include <openssl/bn.h>
1336128a67SGowrishankar Muthukrishnan #include <openssl/rand.h>
1436128a67SGowrishankar Muthukrishnan #endif /* USE_OPENSSL */
1536128a67SGowrishankar Muthukrishnan
1636128a67SGowrishankar Muthukrishnan #include <rte_cryptodev.h>
1736128a67SGowrishankar Muthukrishnan #include <rte_malloc.h>
1836128a67SGowrishankar Muthukrishnan
1936128a67SGowrishankar Muthukrishnan #include "fips_validation.h"
2036128a67SGowrishankar Muthukrishnan
218ee030b4SGowrishankar Muthukrishnan #define CONFORMANCE_JSON_STR "conformance"
2236128a67SGowrishankar Muthukrishnan #define TESTTYPE_JSON_STR "testType"
2336128a67SGowrishankar Muthukrishnan #define SIGTYPE_JSON_STR "sigType"
2436128a67SGowrishankar Muthukrishnan #define MOD_JSON_STR "modulo"
2536128a67SGowrishankar Muthukrishnan #define HASH_JSON_STR "hashAlg"
2636128a67SGowrishankar Muthukrishnan #define SALT_JSON_STR "saltLen"
278ee030b4SGowrishankar Muthukrishnan #define RV_JSON_STR "randomValue"
2836128a67SGowrishankar Muthukrishnan #define E_JSON_STR "e"
2936128a67SGowrishankar Muthukrishnan #define N_JSON_STR "n"
3036128a67SGowrishankar Muthukrishnan
3136128a67SGowrishankar Muthukrishnan #define SEED_JSON_STR "seed"
3236128a67SGowrishankar Muthukrishnan #define MSG_JSON_STR "message"
3336128a67SGowrishankar Muthukrishnan #define SIG_JSON_STR "signature"
3436128a67SGowrishankar Muthukrishnan
358ee030b4SGowrishankar Muthukrishnan
368ee030b4SGowrishankar Muthukrishnan #define RV_BUF_LEN (1024/8)
378ee030b4SGowrishankar Muthukrishnan #define RV_BIT_LEN (256)
388ee030b4SGowrishankar Muthukrishnan
3936128a67SGowrishankar Muthukrishnan #ifdef USE_JANSSON
4036128a67SGowrishankar Muthukrishnan struct {
4136128a67SGowrishankar Muthukrishnan uint8_t type;
4236128a67SGowrishankar Muthukrishnan const char *desc;
4336128a67SGowrishankar Muthukrishnan } rsa_test_types[] = {
4436128a67SGowrishankar Muthukrishnan {RSA_AFT, "AFT"},
4536128a67SGowrishankar Muthukrishnan {RSA_GDT, "GDT"},
4636128a67SGowrishankar Muthukrishnan {RSA_KAT, "KAT"},
4736128a67SGowrishankar Muthukrishnan };
4836128a67SGowrishankar Muthukrishnan
4936128a67SGowrishankar Muthukrishnan struct {
5036128a67SGowrishankar Muthukrishnan enum rte_crypto_auth_algorithm auth;
5136128a67SGowrishankar Muthukrishnan const char *desc;
5236128a67SGowrishankar Muthukrishnan } rsa_auth_algs[] = {
5336128a67SGowrishankar Muthukrishnan {RTE_CRYPTO_AUTH_SHA1, "SHA-1"},
5436128a67SGowrishankar Muthukrishnan {RTE_CRYPTO_AUTH_SHA224, "SHA2-224"},
5536128a67SGowrishankar Muthukrishnan {RTE_CRYPTO_AUTH_SHA256, "SHA2-256"},
5636128a67SGowrishankar Muthukrishnan {RTE_CRYPTO_AUTH_SHA384, "SHA2-384"},
5736128a67SGowrishankar Muthukrishnan {RTE_CRYPTO_AUTH_SHA512, "SHA2-512"},
5836128a67SGowrishankar Muthukrishnan };
5936128a67SGowrishankar Muthukrishnan
6036128a67SGowrishankar Muthukrishnan struct {
6136128a67SGowrishankar Muthukrishnan enum rte_crypto_rsa_padding_type padding;
6236128a67SGowrishankar Muthukrishnan const char *desc;
6336128a67SGowrishankar Muthukrishnan } rsa_padding_types[] = {
6436128a67SGowrishankar Muthukrishnan {RTE_CRYPTO_RSA_PADDING_NONE, "none"},
6536128a67SGowrishankar Muthukrishnan {RTE_CRYPTO_RSA_PADDING_PKCS1_5, "pkcs1v1.5"},
6636128a67SGowrishankar Muthukrishnan {RTE_CRYPTO_RSA_PADDING_OAEP, "oaep"},
6736128a67SGowrishankar Muthukrishnan {RTE_CRYPTO_RSA_PADDING_PSS, "pss"},
6836128a67SGowrishankar Muthukrishnan };
6936128a67SGowrishankar Muthukrishnan
7036128a67SGowrishankar Muthukrishnan #ifdef USE_OPENSSL
7136128a67SGowrishankar Muthukrishnan static int
prepare_vec_rsa(void)7236128a67SGowrishankar Muthukrishnan prepare_vec_rsa(void)
7336128a67SGowrishankar Muthukrishnan {
7436128a67SGowrishankar Muthukrishnan BIGNUM *p = NULL, *q = NULL, *n = NULL, *d = NULL, *e = NULL;
7536128a67SGowrishankar Muthukrishnan BIGNUM *dp = NULL, *dq = NULL, *qinv = NULL;
7636128a67SGowrishankar Muthukrishnan BIGNUM *r0, *r1, *r2, *r3, *r4;
7736128a67SGowrishankar Muthukrishnan BIGNUM *m = NULL, *r = NULL;
7836128a67SGowrishankar Muthukrishnan int bits, ret = -1, i;
7936128a67SGowrishankar Muthukrishnan char modbuf[8], *buf;
8036128a67SGowrishankar Muthukrishnan BN_CTX *ctx = NULL;
8136128a67SGowrishankar Muthukrishnan unsigned long pid;
8236128a67SGowrishankar Muthukrishnan
8336128a67SGowrishankar Muthukrishnan /* Seed PRNG */
8436128a67SGowrishankar Muthukrishnan if (vec.rsa.seed.val) {
8536128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.seed);
8636128a67SGowrishankar Muthukrishnan RAND_seed((char *)info.one_line_text, strlen(info.one_line_text));
8736128a67SGowrishankar Muthukrishnan } else {
8836128a67SGowrishankar Muthukrishnan pid = getpid();
8936128a67SGowrishankar Muthukrishnan RAND_seed(&pid, sizeof(pid));
9036128a67SGowrishankar Muthukrishnan }
9136128a67SGowrishankar Muthukrishnan
9236128a67SGowrishankar Muthukrishnan if (!RAND_status())
9336128a67SGowrishankar Muthukrishnan return -1;
9436128a67SGowrishankar Muthukrishnan
9536128a67SGowrishankar Muthukrishnan /* Check if e is known already */
9636128a67SGowrishankar Muthukrishnan if (vec.rsa.e.val) {
9736128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.e);
9836128a67SGowrishankar Muthukrishnan ret = BN_hex2bn(&e, info.one_line_text);
9936128a67SGowrishankar Muthukrishnan if ((uint32_t)ret != strlen(info.one_line_text))
10036128a67SGowrishankar Muthukrishnan goto err;
10136128a67SGowrishankar Muthukrishnan }
10236128a67SGowrishankar Muthukrishnan
10336128a67SGowrishankar Muthukrishnan /* BN context initialization */
10436128a67SGowrishankar Muthukrishnan ctx = BN_CTX_new();
10536128a67SGowrishankar Muthukrishnan if (!ctx)
10636128a67SGowrishankar Muthukrishnan goto err;
10736128a67SGowrishankar Muthukrishnan
10836128a67SGowrishankar Muthukrishnan BN_CTX_start(ctx);
10936128a67SGowrishankar Muthukrishnan r0 = BN_CTX_get(ctx);
11036128a67SGowrishankar Muthukrishnan r1 = BN_CTX_get(ctx);
11136128a67SGowrishankar Muthukrishnan r2 = BN_CTX_get(ctx);
11236128a67SGowrishankar Muthukrishnan r3 = BN_CTX_get(ctx);
11336128a67SGowrishankar Muthukrishnan r4 = BN_CTX_get(ctx);
11436128a67SGowrishankar Muthukrishnan if (!r4)
11536128a67SGowrishankar Muthukrishnan goto err;
11636128a67SGowrishankar Muthukrishnan
11736128a67SGowrishankar Muthukrishnan /* Calculate bit length for prime numbers */
11836128a67SGowrishankar Muthukrishnan m = BN_new();
11936128a67SGowrishankar Muthukrishnan if (!m)
12036128a67SGowrishankar Muthukrishnan goto err;
12136128a67SGowrishankar Muthukrishnan
12236128a67SGowrishankar Muthukrishnan snprintf(modbuf, sizeof(modbuf), "%d", info.interim_info.rsa_data.modulo);
12336128a67SGowrishankar Muthukrishnan if (!BN_dec2bn(&m, modbuf))
12436128a67SGowrishankar Muthukrishnan goto err;
12536128a67SGowrishankar Muthukrishnan
12636128a67SGowrishankar Muthukrishnan r = BN_new();
12736128a67SGowrishankar Muthukrishnan if (!r)
12836128a67SGowrishankar Muthukrishnan goto err;
12936128a67SGowrishankar Muthukrishnan
13036128a67SGowrishankar Muthukrishnan if (!BN_rshift1(r, m))
13136128a67SGowrishankar Muthukrishnan goto err;
13236128a67SGowrishankar Muthukrishnan
13336128a67SGowrishankar Muthukrishnan buf = BN_bn2dec(r);
13436128a67SGowrishankar Muthukrishnan bits = atoi(buf);
13536128a67SGowrishankar Muthukrishnan
13636128a67SGowrishankar Muthukrishnan p = BN_new();
13736128a67SGowrishankar Muthukrishnan if (!p)
13836128a67SGowrishankar Muthukrishnan goto err;
13936128a67SGowrishankar Muthukrishnan
14036128a67SGowrishankar Muthukrishnan q = BN_new();
14136128a67SGowrishankar Muthukrishnan if (!q)
14236128a67SGowrishankar Muthukrishnan goto err;
14336128a67SGowrishankar Muthukrishnan
14436128a67SGowrishankar Muthukrishnan n = BN_new();
14536128a67SGowrishankar Muthukrishnan if (!n)
14636128a67SGowrishankar Muthukrishnan goto err;
14736128a67SGowrishankar Muthukrishnan
14836128a67SGowrishankar Muthukrishnan d = BN_new();
14936128a67SGowrishankar Muthukrishnan if (!d)
15036128a67SGowrishankar Muthukrishnan goto err;
15136128a67SGowrishankar Muthukrishnan
15236128a67SGowrishankar Muthukrishnan /* Generate p and q suitably for RSA */
15336128a67SGowrishankar Muthukrishnan for (i = 0; i < 10; i++) {
15436128a67SGowrishankar Muthukrishnan uint8_t j = 0;
15536128a67SGowrishankar Muthukrishnan
15636128a67SGowrishankar Muthukrishnan if (!BN_generate_prime_ex(p, bits, 0, NULL, NULL, NULL))
15736128a67SGowrishankar Muthukrishnan goto err;
15836128a67SGowrishankar Muthukrishnan
15936128a67SGowrishankar Muthukrishnan do {
16036128a67SGowrishankar Muthukrishnan RAND_add(&j, sizeof(j), 1);
16136128a67SGowrishankar Muthukrishnan if (!BN_generate_prime_ex(q, bits, 0, NULL, NULL, NULL))
16236128a67SGowrishankar Muthukrishnan goto err;
16336128a67SGowrishankar Muthukrishnan
16436128a67SGowrishankar Muthukrishnan } while ((BN_cmp(p, q) == 0) && (j++ < 100));
16536128a67SGowrishankar Muthukrishnan
16636128a67SGowrishankar Muthukrishnan if (j >= 100) {
16736128a67SGowrishankar Muthukrishnan RTE_LOG(ERR, USER1, "Error: insufficient %d retries to generate q", j);
16836128a67SGowrishankar Muthukrishnan goto err;
16936128a67SGowrishankar Muthukrishnan }
17036128a67SGowrishankar Muthukrishnan
17136128a67SGowrishankar Muthukrishnan /* pq */
17236128a67SGowrishankar Muthukrishnan if (!BN_mul(n, p, q, ctx))
17336128a67SGowrishankar Muthukrishnan goto err;
17436128a67SGowrishankar Muthukrishnan
17536128a67SGowrishankar Muthukrishnan /* p-1 */
17636128a67SGowrishankar Muthukrishnan if (!BN_sub(r1, p, BN_value_one()))
17736128a67SGowrishankar Muthukrishnan goto err;
17836128a67SGowrishankar Muthukrishnan
17936128a67SGowrishankar Muthukrishnan /* q-1 */
18036128a67SGowrishankar Muthukrishnan if (!BN_sub(r2, q, BN_value_one()))
18136128a67SGowrishankar Muthukrishnan goto err;
18236128a67SGowrishankar Muthukrishnan
18336128a67SGowrishankar Muthukrishnan /* (p-1 * q-1) */
18436128a67SGowrishankar Muthukrishnan if (!BN_mul(r0, r1, r2, ctx))
18536128a67SGowrishankar Muthukrishnan goto err;
18636128a67SGowrishankar Muthukrishnan
18736128a67SGowrishankar Muthukrishnan /* gcd(p-1, q-1)*/
18836128a67SGowrishankar Muthukrishnan if (!BN_gcd(r3, r1, r2, ctx))
18936128a67SGowrishankar Muthukrishnan goto err;
19036128a67SGowrishankar Muthukrishnan
19136128a67SGowrishankar Muthukrishnan /* lcm(p-1, q-1) */
19236128a67SGowrishankar Muthukrishnan if (!BN_div(r4, r, r0, r3, ctx))
19336128a67SGowrishankar Muthukrishnan goto err;
19436128a67SGowrishankar Muthukrishnan
19536128a67SGowrishankar Muthukrishnan /* check if div and rem are non-zero */
19636128a67SGowrishankar Muthukrishnan if (!r4 || !r)
19736128a67SGowrishankar Muthukrishnan goto err;
19836128a67SGowrishankar Muthukrishnan
19936128a67SGowrishankar Muthukrishnan /* 0 < e < lcm */
20036128a67SGowrishankar Muthukrishnan if (!e) {
20136128a67SGowrishankar Muthukrishnan int k = 0;
20236128a67SGowrishankar Muthukrishnan
20336128a67SGowrishankar Muthukrishnan e = BN_new();
20436128a67SGowrishankar Muthukrishnan do {
20536128a67SGowrishankar Muthukrishnan RAND_add(&k, sizeof(k), 1);
20636128a67SGowrishankar Muthukrishnan if (!BN_rand(e, 32, 1, 1))
20736128a67SGowrishankar Muthukrishnan goto err;
20836128a67SGowrishankar Muthukrishnan
20936128a67SGowrishankar Muthukrishnan if (!BN_gcd(r3, e, r4, ctx))
21036128a67SGowrishankar Muthukrishnan goto err;
21136128a67SGowrishankar Muthukrishnan
21236128a67SGowrishankar Muthukrishnan if (BN_is_one(r3))
21336128a67SGowrishankar Muthukrishnan break;
21436128a67SGowrishankar Muthukrishnan } while (k++ < 10);
21536128a67SGowrishankar Muthukrishnan
21636128a67SGowrishankar Muthukrishnan if (k >= 10) {
21736128a67SGowrishankar Muthukrishnan RTE_LOG(ERR, USER1, "Error: insufficient %d retries to generate e",
21836128a67SGowrishankar Muthukrishnan k);
21936128a67SGowrishankar Muthukrishnan goto err;
22036128a67SGowrishankar Muthukrishnan }
22136128a67SGowrishankar Muthukrishnan }
22236128a67SGowrishankar Muthukrishnan
22336128a67SGowrishankar Muthukrishnan /* (de) mod lcm == 1 */
22436128a67SGowrishankar Muthukrishnan if (!BN_mod_inverse(d, e, r4, ctx))
22536128a67SGowrishankar Muthukrishnan goto err;
22636128a67SGowrishankar Muthukrishnan
22736128a67SGowrishankar Muthukrishnan if (!BN_gcd(r3, r1, e, ctx))
22836128a67SGowrishankar Muthukrishnan goto err;
22936128a67SGowrishankar Muthukrishnan
23036128a67SGowrishankar Muthukrishnan if (!BN_gcd(r4, r2, e, ctx))
23136128a67SGowrishankar Muthukrishnan goto err;
23236128a67SGowrishankar Muthukrishnan
23336128a67SGowrishankar Muthukrishnan /* check if gcd(p-1, e) and gcd(q-1, e) are 1 */
23436128a67SGowrishankar Muthukrishnan if (BN_is_one(r3) && BN_is_one(r4))
23536128a67SGowrishankar Muthukrishnan break;
23636128a67SGowrishankar Muthukrishnan }
23736128a67SGowrishankar Muthukrishnan
23836128a67SGowrishankar Muthukrishnan if (i >= 10) {
23936128a67SGowrishankar Muthukrishnan RTE_LOG(ERR, USER1, "Error: insufficient %d retries to generate p and q", i);
24036128a67SGowrishankar Muthukrishnan goto err;
24136128a67SGowrishankar Muthukrishnan }
24236128a67SGowrishankar Muthukrishnan
24336128a67SGowrishankar Muthukrishnan /* d mod (p-1) */
24436128a67SGowrishankar Muthukrishnan dp = BN_new();
24536128a67SGowrishankar Muthukrishnan if (!dp)
24636128a67SGowrishankar Muthukrishnan goto err;
24736128a67SGowrishankar Muthukrishnan
24836128a67SGowrishankar Muthukrishnan if (!BN_mod(dp, d, r1, ctx))
24936128a67SGowrishankar Muthukrishnan goto err;
25036128a67SGowrishankar Muthukrishnan
25136128a67SGowrishankar Muthukrishnan /* d mod (q-1) */
25236128a67SGowrishankar Muthukrishnan dq = BN_new();
25336128a67SGowrishankar Muthukrishnan if (!dq)
25436128a67SGowrishankar Muthukrishnan goto err;
25536128a67SGowrishankar Muthukrishnan
25636128a67SGowrishankar Muthukrishnan if (!BN_mod(dq, d, r2, ctx))
25736128a67SGowrishankar Muthukrishnan goto err;
25836128a67SGowrishankar Muthukrishnan
25936128a67SGowrishankar Muthukrishnan /* modinv of q and p */
26036128a67SGowrishankar Muthukrishnan qinv = BN_new();
26136128a67SGowrishankar Muthukrishnan if (!qinv)
26236128a67SGowrishankar Muthukrishnan goto err;
26336128a67SGowrishankar Muthukrishnan
26436128a67SGowrishankar Muthukrishnan if (!BN_mod_inverse(qinv, q, p, ctx))
26536128a67SGowrishankar Muthukrishnan goto err;
26636128a67SGowrishankar Muthukrishnan
2678ee030b4SGowrishankar Muthukrishnan if (info.interim_info.rsa_data.random_msg) {
2688ee030b4SGowrishankar Muthukrishnan if (!BN_generate_prime_ex(r, RV_BIT_LEN, 0, NULL, NULL, NULL))
2698ee030b4SGowrishankar Muthukrishnan goto err;
2708ee030b4SGowrishankar Muthukrishnan
2718ee030b4SGowrishankar Muthukrishnan parse_uint8_hex_str("", BN_bn2hex(r), &vec.rsa.seed);
2728ee030b4SGowrishankar Muthukrishnan }
2738ee030b4SGowrishankar Muthukrishnan
27436128a67SGowrishankar Muthukrishnan parse_uint8_hex_str("", BN_bn2hex(e), &vec.rsa.e);
27536128a67SGowrishankar Muthukrishnan parse_uint8_hex_str("", BN_bn2hex(p), &vec.rsa.p);
27636128a67SGowrishankar Muthukrishnan parse_uint8_hex_str("", BN_bn2hex(q), &vec.rsa.q);
27736128a67SGowrishankar Muthukrishnan parse_uint8_hex_str("", BN_bn2hex(n), &vec.rsa.n);
27836128a67SGowrishankar Muthukrishnan parse_uint8_hex_str("", BN_bn2hex(d), &vec.rsa.d);
27936128a67SGowrishankar Muthukrishnan parse_uint8_hex_str("", BN_bn2hex(dp), &vec.rsa.dp);
28036128a67SGowrishankar Muthukrishnan parse_uint8_hex_str("", BN_bn2hex(dq), &vec.rsa.dq);
28136128a67SGowrishankar Muthukrishnan parse_uint8_hex_str("", BN_bn2hex(qinv), &vec.rsa.qinv);
28236128a67SGowrishankar Muthukrishnan
28336128a67SGowrishankar Muthukrishnan ret = 0;
28436128a67SGowrishankar Muthukrishnan err:
28536128a67SGowrishankar Muthukrishnan BN_CTX_end(ctx);
28636128a67SGowrishankar Muthukrishnan BN_CTX_free(ctx);
28736128a67SGowrishankar Muthukrishnan BN_free(m);
28836128a67SGowrishankar Muthukrishnan BN_free(r);
28936128a67SGowrishankar Muthukrishnan BN_free(p);
29036128a67SGowrishankar Muthukrishnan BN_free(q);
29136128a67SGowrishankar Muthukrishnan BN_free(n);
29236128a67SGowrishankar Muthukrishnan BN_free(d);
29336128a67SGowrishankar Muthukrishnan BN_free(e);
29436128a67SGowrishankar Muthukrishnan return ret;
29536128a67SGowrishankar Muthukrishnan }
29636128a67SGowrishankar Muthukrishnan #else
29736128a67SGowrishankar Muthukrishnan static int
prepare_vec_rsa(void)29836128a67SGowrishankar Muthukrishnan prepare_vec_rsa(void)
29936128a67SGowrishankar Muthukrishnan {
30036128a67SGowrishankar Muthukrishnan /*
30136128a67SGowrishankar Muthukrishnan * Generate RSA values.
30236128a67SGowrishankar Muthukrishnan */
30336128a67SGowrishankar Muthukrishnan return -ENOTSUP;
30436128a67SGowrishankar Muthukrishnan }
30536128a67SGowrishankar Muthukrishnan #endif /* USE_OPENSSL */
30636128a67SGowrishankar Muthukrishnan
30736128a67SGowrishankar Muthukrishnan static int
parse_test_rsa_json_interim_writeback(struct fips_val * val)30836128a67SGowrishankar Muthukrishnan parse_test_rsa_json_interim_writeback(struct fips_val *val)
30936128a67SGowrishankar Muthukrishnan {
31036128a67SGowrishankar Muthukrishnan RTE_SET_USED(val);
31136128a67SGowrishankar Muthukrishnan
3128ee030b4SGowrishankar Muthukrishnan if (info.interim_info.rsa_data.random_msg) {
3138ee030b4SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_group, "conformance",
3148ee030b4SGowrishankar Muthukrishnan json_string("SP800-106"));
3158ee030b4SGowrishankar Muthukrishnan }
3168ee030b4SGowrishankar Muthukrishnan
31736128a67SGowrishankar Muthukrishnan if (info.op == FIPS_TEST_ASYM_SIGGEN) {
31836128a67SGowrishankar Muthukrishnan json_t *obj;
31936128a67SGowrishankar Muthukrishnan
32036128a67SGowrishankar Muthukrishnan /* For siggen tests, RSA values can be created soon after
32136128a67SGowrishankar Muthukrishnan * the test group data are parsed.
32236128a67SGowrishankar Muthukrishnan */
32336128a67SGowrishankar Muthukrishnan if (vec.rsa.e.val) {
32436128a67SGowrishankar Muthukrishnan rte_free(vec.rsa.e.val);
32536128a67SGowrishankar Muthukrishnan vec.rsa.e.val = NULL;
32636128a67SGowrishankar Muthukrishnan }
32736128a67SGowrishankar Muthukrishnan
32836128a67SGowrishankar Muthukrishnan if (prepare_vec_rsa() < 0)
32936128a67SGowrishankar Muthukrishnan return -1;
33036128a67SGowrishankar Muthukrishnan
331*57c10aafSGowrishankar Muthukrishnan if (!vec.rsa.e.val)
332*57c10aafSGowrishankar Muthukrishnan return -1;
333*57c10aafSGowrishankar Muthukrishnan
33436128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.n);
33536128a67SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
33636128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_group, "n", obj);
33736128a67SGowrishankar Muthukrishnan
33836128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.e);
33936128a67SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
34036128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_group, "e", obj);
34136128a67SGowrishankar Muthukrishnan }
34236128a67SGowrishankar Muthukrishnan
34336128a67SGowrishankar Muthukrishnan return 0;
34436128a67SGowrishankar Muthukrishnan }
34536128a67SGowrishankar Muthukrishnan
34636128a67SGowrishankar Muthukrishnan static int
parse_test_rsa_json_writeback(struct fips_val * val)34736128a67SGowrishankar Muthukrishnan parse_test_rsa_json_writeback(struct fips_val *val)
34836128a67SGowrishankar Muthukrishnan {
34936128a67SGowrishankar Muthukrishnan json_t *tcId;
35036128a67SGowrishankar Muthukrishnan
35136128a67SGowrishankar Muthukrishnan RTE_SET_USED(val);
35236128a67SGowrishankar Muthukrishnan
35336128a67SGowrishankar Muthukrishnan tcId = json_object_get(json_info.json_test_case, "tcId");
35436128a67SGowrishankar Muthukrishnan
35536128a67SGowrishankar Muthukrishnan json_info.json_write_case = json_object();
35636128a67SGowrishankar Muthukrishnan json_object_set(json_info.json_write_case, "tcId", tcId);
35736128a67SGowrishankar Muthukrishnan
35836128a67SGowrishankar Muthukrishnan if (info.op == FIPS_TEST_ASYM_KEYGEN) {
35936128a67SGowrishankar Muthukrishnan json_t *obj;
36036128a67SGowrishankar Muthukrishnan
36136128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.seed);
36236128a67SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
36336128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "seed", obj);
36436128a67SGowrishankar Muthukrishnan
36536128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.n);
36636128a67SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
36736128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "n", obj);
36836128a67SGowrishankar Muthukrishnan
36936128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.e);
37036128a67SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
37136128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "e", obj);
37236128a67SGowrishankar Muthukrishnan
37336128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.p);
37436128a67SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
37536128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "p", obj);
37636128a67SGowrishankar Muthukrishnan
37736128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.q);
37836128a67SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
37936128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "q", obj);
38036128a67SGowrishankar Muthukrishnan
38136128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.d);
38236128a67SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
38336128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "d", obj);
38436128a67SGowrishankar Muthukrishnan } else if (info.op == FIPS_TEST_ASYM_SIGGEN) {
38536128a67SGowrishankar Muthukrishnan json_t *obj;
38636128a67SGowrishankar Muthukrishnan
38736128a67SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.signature);
38836128a67SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
38936128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "signature", obj);
3908ee030b4SGowrishankar Muthukrishnan
3918ee030b4SGowrishankar Muthukrishnan if (info.interim_info.rsa_data.random_msg) {
3928ee030b4SGowrishankar Muthukrishnan writeback_hex_str("", info.one_line_text, &vec.rsa.seed);
3938ee030b4SGowrishankar Muthukrishnan obj = json_string(info.one_line_text);
3948ee030b4SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "randomValue", obj);
3958ee030b4SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "randomValueLen",
3968ee030b4SGowrishankar Muthukrishnan json_integer(vec.rsa.seed.len * 8));
3978ee030b4SGowrishankar Muthukrishnan }
39836128a67SGowrishankar Muthukrishnan } else if (info.op == FIPS_TEST_ASYM_SIGVER) {
39936128a67SGowrishankar Muthukrishnan if (vec.status == RTE_CRYPTO_OP_STATUS_SUCCESS)
40036128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "testPassed", json_true());
40136128a67SGowrishankar Muthukrishnan else
40236128a67SGowrishankar Muthukrishnan json_object_set_new(json_info.json_write_case, "testPassed", json_false());
40336128a67SGowrishankar Muthukrishnan }
40436128a67SGowrishankar Muthukrishnan
40536128a67SGowrishankar Muthukrishnan return 0;
40636128a67SGowrishankar Muthukrishnan }
40736128a67SGowrishankar Muthukrishnan
40836128a67SGowrishankar Muthukrishnan static int
parse_interim_str(const char * key,char * src,struct fips_val * val)40936128a67SGowrishankar Muthukrishnan parse_interim_str(const char *key, char *src, struct fips_val *val)
41036128a67SGowrishankar Muthukrishnan {
41136128a67SGowrishankar Muthukrishnan uint32_t i;
41236128a67SGowrishankar Muthukrishnan
41336128a67SGowrishankar Muthukrishnan RTE_SET_USED(val);
41436128a67SGowrishankar Muthukrishnan
41536128a67SGowrishankar Muthukrishnan if (strcmp(key, SIGTYPE_JSON_STR) == 0) {
41636128a67SGowrishankar Muthukrishnan for (i = 0; i < RTE_DIM(rsa_padding_types); i++)
41736128a67SGowrishankar Muthukrishnan if (strstr(src, rsa_padding_types[i].desc)) {
41836128a67SGowrishankar Muthukrishnan info.interim_info.rsa_data.padding = rsa_padding_types[i].padding;
41936128a67SGowrishankar Muthukrishnan break;
42036128a67SGowrishankar Muthukrishnan }
42136128a67SGowrishankar Muthukrishnan
42236128a67SGowrishankar Muthukrishnan if (i >= RTE_DIM(rsa_padding_types))
42336128a67SGowrishankar Muthukrishnan return -EINVAL;
42436128a67SGowrishankar Muthukrishnan
42536128a67SGowrishankar Muthukrishnan } else if (strcmp(key, MOD_JSON_STR) == 0) {
42636128a67SGowrishankar Muthukrishnan info.interim_info.rsa_data.modulo = atoi(src);
42736128a67SGowrishankar Muthukrishnan } else if (strcmp(key, HASH_JSON_STR) == 0) {
42836128a67SGowrishankar Muthukrishnan for (i = 0; i < RTE_DIM(rsa_auth_algs); i++)
42936128a67SGowrishankar Muthukrishnan if (strstr(src, rsa_auth_algs[i].desc)) {
43036128a67SGowrishankar Muthukrishnan info.interim_info.rsa_data.auth = rsa_auth_algs[i].auth;
43136128a67SGowrishankar Muthukrishnan break;
43236128a67SGowrishankar Muthukrishnan }
43336128a67SGowrishankar Muthukrishnan
43436128a67SGowrishankar Muthukrishnan if (i >= RTE_DIM(rsa_auth_algs))
43536128a67SGowrishankar Muthukrishnan return -EINVAL;
43636128a67SGowrishankar Muthukrishnan
4378ee030b4SGowrishankar Muthukrishnan } else if (strcmp(key, CONFORMANCE_JSON_STR) == 0) {
4388ee030b4SGowrishankar Muthukrishnan info.interim_info.rsa_data.random_msg = 1;
43936128a67SGowrishankar Muthukrishnan } else if (strcmp(key, SALT_JSON_STR) == 0) {
44036128a67SGowrishankar Muthukrishnan info.interim_info.rsa_data.saltlen = atoi(src);
44136128a67SGowrishankar Muthukrishnan } else if (strcmp(key, TESTTYPE_JSON_STR) == 0) {
44236128a67SGowrishankar Muthukrishnan for (i = 0; i < RTE_DIM(rsa_test_types); i++)
44336128a67SGowrishankar Muthukrishnan if (strstr(src, rsa_test_types[i].desc)) {
44436128a67SGowrishankar Muthukrishnan info.parse_writeback = parse_test_rsa_json_writeback;
44536128a67SGowrishankar Muthukrishnan break;
44636128a67SGowrishankar Muthukrishnan }
44736128a67SGowrishankar Muthukrishnan
44836128a67SGowrishankar Muthukrishnan if (!info.parse_writeback || i >= RTE_DIM(rsa_test_types))
44936128a67SGowrishankar Muthukrishnan return -EINVAL;
45036128a67SGowrishankar Muthukrishnan
45136128a67SGowrishankar Muthukrishnan } else {
45236128a67SGowrishankar Muthukrishnan return -EINVAL;
45336128a67SGowrishankar Muthukrishnan }
45436128a67SGowrishankar Muthukrishnan
45536128a67SGowrishankar Muthukrishnan return 0;
45636128a67SGowrishankar Muthukrishnan }
45736128a67SGowrishankar Muthukrishnan
45836128a67SGowrishankar Muthukrishnan static int
parse_keygen_e_str(const char * key,char * src,struct fips_val * val)45936128a67SGowrishankar Muthukrishnan parse_keygen_e_str(const char *key, char *src, struct fips_val *val)
46036128a67SGowrishankar Muthukrishnan {
46136128a67SGowrishankar Muthukrishnan parse_uint8_hex_str(key, src, val);
46236128a67SGowrishankar Muthukrishnan
46336128a67SGowrishankar Muthukrishnan /* For keygen tests, key "e" can be the end of input data
46436128a67SGowrishankar Muthukrishnan * to generate RSA values.
46536128a67SGowrishankar Muthukrishnan */
46636128a67SGowrishankar Muthukrishnan return prepare_vec_rsa();
46736128a67SGowrishankar Muthukrishnan }
46836128a67SGowrishankar Muthukrishnan
4698ee030b4SGowrishankar Muthukrishnan /*
4708ee030b4SGowrishankar Muthukrishnan * Message randomization function as per NIST SP 800-106.
4718ee030b4SGowrishankar Muthukrishnan */
4728ee030b4SGowrishankar Muthukrishnan int
fips_test_randomize_message(struct fips_val * msg,struct fips_val * rand)4738ee030b4SGowrishankar Muthukrishnan fips_test_randomize_message(struct fips_val *msg, struct fips_val *rand)
4748ee030b4SGowrishankar Muthukrishnan {
4758ee030b4SGowrishankar Muthukrishnan uint8_t m[FIPS_TEST_JSON_BUF_LEN], rv[RV_BUF_LEN];
4768ee030b4SGowrishankar Muthukrishnan uint32_t m_bitlen, rv_bitlen, count, remain, i, j;
4778ee030b4SGowrishankar Muthukrishnan uint16_t rv_len;
4788ee030b4SGowrishankar Muthukrishnan
4798ee030b4SGowrishankar Muthukrishnan if (!msg->val || !rand->val || rand->len > RV_BUF_LEN
480*57c10aafSGowrishankar Muthukrishnan || msg->len > (FIPS_TEST_JSON_BUF_LEN - 1))
4818ee030b4SGowrishankar Muthukrishnan return -EINVAL;
4828ee030b4SGowrishankar Muthukrishnan
4838ee030b4SGowrishankar Muthukrishnan memset(rv, 0, sizeof(rv));
4848ee030b4SGowrishankar Muthukrishnan memcpy(rv, rand->val, rand->len);
4858ee030b4SGowrishankar Muthukrishnan rv_bitlen = rand->len * 8;
4868ee030b4SGowrishankar Muthukrishnan rv_len = rand->len;
4878ee030b4SGowrishankar Muthukrishnan
4888ee030b4SGowrishankar Muthukrishnan memset(m, 0, sizeof(m));
4898ee030b4SGowrishankar Muthukrishnan memcpy(m, msg->val, msg->len);
4908ee030b4SGowrishankar Muthukrishnan m_bitlen = msg->len * 8;
4918ee030b4SGowrishankar Muthukrishnan
4928ee030b4SGowrishankar Muthukrishnan if (m_bitlen >= (rv_bitlen - 1)) {
4938ee030b4SGowrishankar Muthukrishnan m[msg->len] = 0x80;
4948ee030b4SGowrishankar Muthukrishnan m_bitlen += 8;
4958ee030b4SGowrishankar Muthukrishnan } else {
4968ee030b4SGowrishankar Muthukrishnan m[msg->len] = 0x80;
4978ee030b4SGowrishankar Muthukrishnan m_bitlen += (rv_bitlen - m_bitlen - 8);
4988ee030b4SGowrishankar Muthukrishnan }
4998ee030b4SGowrishankar Muthukrishnan
5008ee030b4SGowrishankar Muthukrishnan count = m_bitlen / rv_bitlen;
5018ee030b4SGowrishankar Muthukrishnan remain = m_bitlen % rv_bitlen;
5028ee030b4SGowrishankar Muthukrishnan for (i = 0; i < count * rv_len; i++)
5038ee030b4SGowrishankar Muthukrishnan m[i] ^= rv[i % rv_len];
5048ee030b4SGowrishankar Muthukrishnan
5058ee030b4SGowrishankar Muthukrishnan for (j = 0; j < remain / 8; j++)
5068ee030b4SGowrishankar Muthukrishnan m[i + j] ^= rv[j];
5078ee030b4SGowrishankar Muthukrishnan
5088ee030b4SGowrishankar Muthukrishnan m[i + j] = ((uint8_t *)&rv_bitlen)[0];
509*57c10aafSGowrishankar Muthukrishnan m[i + j + 1] = ((uint8_t *)&rv_bitlen)[1];
5108ee030b4SGowrishankar Muthukrishnan
5118ee030b4SGowrishankar Muthukrishnan rte_free(msg->val);
5128ee030b4SGowrishankar Muthukrishnan msg->len = (rv_bitlen + m_bitlen + 16) / 8;
5138ee030b4SGowrishankar Muthukrishnan msg->val = rte_zmalloc(NULL, msg->len, 0);
5148ee030b4SGowrishankar Muthukrishnan if (!msg->val)
5158ee030b4SGowrishankar Muthukrishnan return -EPERM;
5168ee030b4SGowrishankar Muthukrishnan
5178ee030b4SGowrishankar Muthukrishnan memcpy(msg->val, rv, rv_len);
5188ee030b4SGowrishankar Muthukrishnan memcpy(&msg->val[rv_len], m, (m_bitlen + 16) / 8);
5198ee030b4SGowrishankar Muthukrishnan return 0;
5208ee030b4SGowrishankar Muthukrishnan }
5218ee030b4SGowrishankar Muthukrishnan
5228ee030b4SGowrishankar Muthukrishnan static int
parse_siggen_message_str(const char * key,char * src,struct fips_val * val)5238ee030b4SGowrishankar Muthukrishnan parse_siggen_message_str(const char *key, char *src, struct fips_val *val)
5248ee030b4SGowrishankar Muthukrishnan {
5258ee030b4SGowrishankar Muthukrishnan int ret = 0;
5268ee030b4SGowrishankar Muthukrishnan
5278ee030b4SGowrishankar Muthukrishnan parse_uint8_hex_str(key, src, val);
5288ee030b4SGowrishankar Muthukrishnan if (info.interim_info.rsa_data.random_msg)
5298ee030b4SGowrishankar Muthukrishnan ret = fips_test_randomize_message(val, &vec.rsa.seed);
5308ee030b4SGowrishankar Muthukrishnan
5318ee030b4SGowrishankar Muthukrishnan return ret;
5328ee030b4SGowrishankar Muthukrishnan }
5338ee030b4SGowrishankar Muthukrishnan
5348ee030b4SGowrishankar Muthukrishnan static int
parse_sigver_randomvalue_str(const char * key,char * src,struct fips_val * val)5358ee030b4SGowrishankar Muthukrishnan parse_sigver_randomvalue_str(const char *key, char *src, struct fips_val *val)
5368ee030b4SGowrishankar Muthukrishnan {
5378ee030b4SGowrishankar Muthukrishnan int ret = 0;
5388ee030b4SGowrishankar Muthukrishnan
5398ee030b4SGowrishankar Muthukrishnan parse_uint8_hex_str(key, src, val);
5408ee030b4SGowrishankar Muthukrishnan if (info.interim_info.rsa_data.random_msg)
5418ee030b4SGowrishankar Muthukrishnan ret = fips_test_randomize_message(&vec.pt, val);
5428ee030b4SGowrishankar Muthukrishnan
5438ee030b4SGowrishankar Muthukrishnan return ret;
5448ee030b4SGowrishankar Muthukrishnan }
5458ee030b4SGowrishankar Muthukrishnan
54636128a67SGowrishankar Muthukrishnan struct fips_test_callback rsa_keygen_interim_json_vectors[] = {
54736128a67SGowrishankar Muthukrishnan {MOD_JSON_STR, parse_interim_str, NULL},
54836128a67SGowrishankar Muthukrishnan {HASH_JSON_STR, parse_interim_str, NULL},
54936128a67SGowrishankar Muthukrishnan {TESTTYPE_JSON_STR, parse_interim_str, NULL},
55036128a67SGowrishankar Muthukrishnan {NULL, NULL, NULL} /**< end pointer */
55136128a67SGowrishankar Muthukrishnan };
55236128a67SGowrishankar Muthukrishnan
55336128a67SGowrishankar Muthukrishnan struct fips_test_callback rsa_siggen_interim_json_vectors[] = {
55436128a67SGowrishankar Muthukrishnan {SIGTYPE_JSON_STR, parse_interim_str, NULL},
55536128a67SGowrishankar Muthukrishnan {MOD_JSON_STR, parse_interim_str, NULL},
55636128a67SGowrishankar Muthukrishnan {HASH_JSON_STR, parse_interim_str, NULL},
5578ee030b4SGowrishankar Muthukrishnan {CONFORMANCE_JSON_STR, parse_interim_str, NULL},
55836128a67SGowrishankar Muthukrishnan {SALT_JSON_STR, parse_interim_str, NULL},
55936128a67SGowrishankar Muthukrishnan {TESTTYPE_JSON_STR, parse_interim_str, NULL},
56036128a67SGowrishankar Muthukrishnan {NULL, NULL, NULL} /**< end pointer */
56136128a67SGowrishankar Muthukrishnan };
56236128a67SGowrishankar Muthukrishnan
56336128a67SGowrishankar Muthukrishnan struct fips_test_callback rsa_sigver_interim_json_vectors[] = {
56436128a67SGowrishankar Muthukrishnan {SIGTYPE_JSON_STR, parse_interim_str, NULL},
56536128a67SGowrishankar Muthukrishnan {MOD_JSON_STR, parse_interim_str, NULL},
56636128a67SGowrishankar Muthukrishnan {HASH_JSON_STR, parse_interim_str, NULL},
5678ee030b4SGowrishankar Muthukrishnan {CONFORMANCE_JSON_STR, parse_interim_str, NULL},
56836128a67SGowrishankar Muthukrishnan {SALT_JSON_STR, parse_interim_str, NULL},
56936128a67SGowrishankar Muthukrishnan {N_JSON_STR, parse_uint8_hex_str, &vec.rsa.n},
57036128a67SGowrishankar Muthukrishnan {E_JSON_STR, parse_uint8_hex_str, &vec.rsa.e},
57136128a67SGowrishankar Muthukrishnan {TESTTYPE_JSON_STR, parse_interim_str, NULL},
57236128a67SGowrishankar Muthukrishnan {NULL, NULL, NULL} /**< end pointer */
57336128a67SGowrishankar Muthukrishnan };
57436128a67SGowrishankar Muthukrishnan
57536128a67SGowrishankar Muthukrishnan struct fips_test_callback rsa_keygen_json_vectors[] = {
57636128a67SGowrishankar Muthukrishnan {SEED_JSON_STR, parse_uint8_hex_str, &vec.rsa.seed},
57736128a67SGowrishankar Muthukrishnan {E_JSON_STR, parse_keygen_e_str, &vec.rsa.e},
57836128a67SGowrishankar Muthukrishnan {NULL, NULL, NULL} /**< end pointer */
57936128a67SGowrishankar Muthukrishnan };
58036128a67SGowrishankar Muthukrishnan
58136128a67SGowrishankar Muthukrishnan struct fips_test_callback rsa_siggen_json_vectors[] = {
5828ee030b4SGowrishankar Muthukrishnan {MSG_JSON_STR, parse_siggen_message_str, &vec.pt},
58336128a67SGowrishankar Muthukrishnan {NULL, NULL, NULL} /**< end pointer */
58436128a67SGowrishankar Muthukrishnan };
58536128a67SGowrishankar Muthukrishnan
58636128a67SGowrishankar Muthukrishnan struct fips_test_callback rsa_sigver_json_vectors[] = {
58736128a67SGowrishankar Muthukrishnan {MSG_JSON_STR, parse_uint8_hex_str, &vec.pt},
58836128a67SGowrishankar Muthukrishnan {SIG_JSON_STR, parse_uint8_hex_str, &vec.rsa.signature},
5898ee030b4SGowrishankar Muthukrishnan {RV_JSON_STR, parse_sigver_randomvalue_str, &vec.rsa.seed},
59036128a67SGowrishankar Muthukrishnan {NULL, NULL, NULL} /**< end pointer */
59136128a67SGowrishankar Muthukrishnan };
59236128a67SGowrishankar Muthukrishnan
59336128a67SGowrishankar Muthukrishnan int
parse_test_rsa_json_init(void)59436128a67SGowrishankar Muthukrishnan parse_test_rsa_json_init(void)
59536128a67SGowrishankar Muthukrishnan {
59636128a67SGowrishankar Muthukrishnan json_t *keyfmt_obj = json_object_get(json_info.json_vector_set, "keyFormat");
59736128a67SGowrishankar Muthukrishnan json_t *mode_obj = json_object_get(json_info.json_vector_set, "mode");
59836128a67SGowrishankar Muthukrishnan const char *keyfmt_str = json_string_value(keyfmt_obj);
59936128a67SGowrishankar Muthukrishnan const char *mode_str = json_string_value(mode_obj);
60036128a67SGowrishankar Muthukrishnan
60136128a67SGowrishankar Muthukrishnan info.callbacks = NULL;
60236128a67SGowrishankar Muthukrishnan info.parse_writeback = NULL;
60336128a67SGowrishankar Muthukrishnan info.interim_callbacks = NULL;
60436128a67SGowrishankar Muthukrishnan info.parse_interim_writeback = NULL;
6058ee030b4SGowrishankar Muthukrishnan info.interim_info.rsa_data.random_msg = 0;
60636128a67SGowrishankar Muthukrishnan
60736128a67SGowrishankar Muthukrishnan if (strcmp(mode_str, "keyGen") == 0) {
60836128a67SGowrishankar Muthukrishnan info.op = FIPS_TEST_ASYM_KEYGEN;
60936128a67SGowrishankar Muthukrishnan info.callbacks = rsa_keygen_json_vectors;
61036128a67SGowrishankar Muthukrishnan info.interim_callbacks = rsa_keygen_interim_json_vectors;
61136128a67SGowrishankar Muthukrishnan } else if (strcmp(mode_str, "sigGen") == 0) {
61236128a67SGowrishankar Muthukrishnan info.op = FIPS_TEST_ASYM_SIGGEN;
61336128a67SGowrishankar Muthukrishnan info.callbacks = rsa_siggen_json_vectors;
61436128a67SGowrishankar Muthukrishnan info.interim_callbacks = rsa_siggen_interim_json_vectors;
61536128a67SGowrishankar Muthukrishnan info.parse_interim_writeback = parse_test_rsa_json_interim_writeback;
61636128a67SGowrishankar Muthukrishnan } else if (strcmp(mode_str, "sigVer") == 0) {
61736128a67SGowrishankar Muthukrishnan info.op = FIPS_TEST_ASYM_SIGVER;
61836128a67SGowrishankar Muthukrishnan info.callbacks = rsa_sigver_json_vectors;
61936128a67SGowrishankar Muthukrishnan info.interim_callbacks = rsa_sigver_interim_json_vectors;
6208ee030b4SGowrishankar Muthukrishnan info.parse_interim_writeback = parse_test_rsa_json_interim_writeback;
62136128a67SGowrishankar Muthukrishnan } else {
62236128a67SGowrishankar Muthukrishnan return -EINVAL;
62336128a67SGowrishankar Muthukrishnan }
62436128a67SGowrishankar Muthukrishnan
62536128a67SGowrishankar Muthukrishnan info.interim_info.rsa_data.privkey = RTE_RSA_KEY_TYPE_QT;
62636128a67SGowrishankar Muthukrishnan if (keyfmt_str != NULL && strcmp(keyfmt_str, "standard") == 0)
62736128a67SGowrishankar Muthukrishnan info.interim_info.rsa_data.privkey = RTE_RSA_KEY_TYPE_EXP;
62836128a67SGowrishankar Muthukrishnan
62936128a67SGowrishankar Muthukrishnan return 0;
63036128a67SGowrishankar Muthukrishnan }
63136128a67SGowrishankar Muthukrishnan
63236128a67SGowrishankar Muthukrishnan #endif /* USE_JANSSON */
633