Coverage Report

Created: 2026-04-01 06:39

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl35/crypto/param_build_set.c
Line
Count
Source
1
/*
2
 * Copyright 2020-2022 The OpenSSL Project Authors. All Rights Reserved.
3
 *
4
 * Licensed under the Apache License 2.0 (the "License").  You may not use
5
 * this file except in compliance with the License.  You can obtain a copy
6
 * in the file LICENSE in the source distribution or at
7
 * https://www.openssl.org/source/license.html
8
 */
9
10
/*
11
 * Key Management utility functions to share functionality between the export()
12
 * and get_params() methods.
13
 * export() uses OSSL_PARAM_BLD, and get_params() used the OSSL_PARAM[] to
14
 * fill in parameter data for the same key and data fields.
15
 */
16
17
#include <openssl/core_names.h>
18
#include "internal/param_build_set.h"
19
20
DEFINE_SPECIAL_STACK_OF_CONST(BIGNUM_const, BIGNUM)
21
22
int ossl_param_build_set_int(OSSL_PARAM_BLD *bld, OSSL_PARAM *p,
23
    const char *key, int num)
24
3.45M
{
25
3.45M
    if (bld != NULL)
26
450k
        return OSSL_PARAM_BLD_push_int(bld, key, num);
27
3.00M
    p = OSSL_PARAM_locate(p, key);
28
3.00M
    if (p != NULL)
29
3
        return OSSL_PARAM_set_int(p, num);
30
3.00M
    return 1;
31
3.00M
}
32
33
int ossl_param_build_set_long(OSSL_PARAM_BLD *bld, OSSL_PARAM *p,
34
    const char *key, long num)
35
2.08k
{
36
2.08k
    if (bld != NULL)
37
0
        return OSSL_PARAM_BLD_push_long(bld, key, num);
38
2.08k
    p = OSSL_PARAM_locate(p, key);
39
2.08k
    if (p != NULL)
40
0
        return OSSL_PARAM_set_long(p, num);
41
2.08k
    return 1;
42
2.08k
}
43
44
int ossl_param_build_set_utf8_string(OSSL_PARAM_BLD *bld, OSSL_PARAM *p,
45
    const char *key, const char *buf)
46
3.05M
{
47
3.05M
    if (bld != NULL)
48
380k
        return OSSL_PARAM_BLD_push_utf8_string(bld, key, buf, 0);
49
2.67M
    p = OSSL_PARAM_locate(p, key);
50
2.67M
    if (p != NULL)
51
85.5k
        return OSSL_PARAM_set_utf8_string(p, buf);
52
2.58M
    return 1;
53
2.67M
}
54
55
int ossl_param_build_set_octet_string(OSSL_PARAM_BLD *bld, OSSL_PARAM *p,
56
    const char *key,
57
    const unsigned char *data,
58
    size_t data_len)
59
915k
{
60
915k
    if (bld != NULL)
61
153k
        return OSSL_PARAM_BLD_push_octet_string(bld, key, data, data_len);
62
63
762k
    p = OSSL_PARAM_locate(p, key);
64
762k
    if (p != NULL)
65
0
        return OSSL_PARAM_set_octet_string(p, data, data_len);
66
762k
    return 1;
67
762k
}
68
69
int ossl_param_build_set_bn_pad(OSSL_PARAM_BLD *bld, OSSL_PARAM *p,
70
    const char *key, const BIGNUM *bn, size_t sz)
71
145k
{
72
145k
    if (bld != NULL)
73
51.1k
        return OSSL_PARAM_BLD_push_BN_pad(bld, key, bn, sz);
74
93.8k
    p = OSSL_PARAM_locate(p, key);
75
93.8k
    if (p != NULL) {
76
0
        if (sz > p->data_size) {
77
0
            ERR_raise(ERR_LIB_CRYPTO, CRYPTO_R_TOO_SMALL_BUFFER);
78
0
            return 0;
79
0
        }
80
0
        p->data_size = sz;
81
0
        return OSSL_PARAM_set_BN(p, bn);
82
0
    }
83
93.8k
    return 1;
84
93.8k
}
85
86
int ossl_param_build_set_bn(OSSL_PARAM_BLD *bld, OSSL_PARAM *p,
87
    const char *key, const BIGNUM *bn)
88
1.75M
{
89
1.75M
    if (bld != NULL)
90
446k
        return OSSL_PARAM_BLD_push_BN(bld, key, bn);
91
92
1.30M
    p = OSSL_PARAM_locate(p, key);
93
1.30M
    if (p != NULL)
94
174
        return OSSL_PARAM_set_BN(p, bn) > 0;
95
1.30M
    return 1;
96
1.30M
}
97
98
int ossl_param_build_set_multi_key_bn(OSSL_PARAM_BLD *bld, OSSL_PARAM *params,
99
    const char *names[],
100
    STACK_OF(BIGNUM_const) *stk)
101
270k
{
102
270k
    int i, sz = sk_BIGNUM_const_num(stk);
103
270k
    OSSL_PARAM *p;
104
270k
    const BIGNUM *bn;
105
106
270k
    if (bld != NULL) {
107
507k
        for (i = 0; i < sz && names[i] != NULL; ++i) {
108
316k
            bn = sk_BIGNUM_const_value(stk, i);
109
316k
            if (bn != NULL && !OSSL_PARAM_BLD_push_BN(bld, names[i], bn))
110
0
                return 0;
111
316k
        }
112
190k
        return 1;
113
190k
    }
114
115
232k
    for (i = 0; i < sz && names[i] != NULL; ++i) {
116
153k
        bn = sk_BIGNUM_const_value(stk, i);
117
153k
        p = OSSL_PARAM_locate(params, names[i]);
118
153k
        if (p != NULL && bn != NULL) {
119
0
            if (!OSSL_PARAM_set_BN(p, bn))
120
0
                return 0;
121
0
        }
122
153k
    }
123
79.9k
    return 1;
124
79.9k
}