Coverage Report

Created: 2025-11-16 06:40

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl32/fuzz/smime.c
Line
Count
Source
1
/*
2
 * Copyright 2023 The OpenSSL Project Authors. All Rights Reserved.
3
 *
4
 * Licensed under the Apache License 2.0 (the "License");
5
 * you may not use this file except in compliance with the License.
6
 * You may obtain a copy of the License at
7
 * https://www.openssl.org/source/license.html
8
 * or in the file LICENSE in the source distribution.
9
 */
10
11
#include "fuzzer.h"
12
#include <openssl/err.h>
13
#include <openssl/pkcs7.h>
14
#include <openssl/x509.h>
15
#include <stdio.h>
16
17
int FuzzerInitialize(int *argc, char ***argv)
18
200
{
19
200
    return 1;
20
200
}
21
22
int FuzzerTestOneInput(const uint8_t *buf, size_t len)
23
22.6k
{
24
22.6k
    BIO *b = BIO_new_mem_buf(buf, len);
25
22.6k
    PKCS7 *p7 = SMIME_read_PKCS7(b, NULL);
26
27
22.6k
    if (p7 != NULL) {
28
952
        STACK_OF(PKCS7_SIGNER_INFO) *p7si = PKCS7_get_signer_info(p7);
29
952
        int i;
30
31
1.22k
        for (i = 0; i < sk_PKCS7_SIGNER_INFO_num(p7si); i++) {
32
271
            STACK_OF(X509_ALGOR) *algs;
33
34
271
            PKCS7_cert_from_signer_info(p7,
35
271
                                        sk_PKCS7_SIGNER_INFO_value(p7si, i));
36
271
            algs = PKCS7_get_smimecap(sk_PKCS7_SIGNER_INFO_value(p7si, i));
37
271
            sk_X509_ALGOR_pop_free(algs, X509_ALGOR_free);
38
271
        }
39
952
        PKCS7_free(p7);
40
952
    }
41
42
22.6k
    BIO_free(b);
43
22.6k
    ERR_clear_error();
44
22.6k
    return 0;
45
22.6k
}
46
47
void FuzzerCleanup(void)
48
0
{
49
0
}