Coverage Report

Created: 2025-06-13 06:58

/src/openssl30/fuzz/ct.c
Line
Count
Source (jump to first uncovered line)
1
/*
2
 * Copyright 2016 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
/*
12
 * Fuzz the SCT parser.
13
 */
14
15
#include <stdio.h>
16
#include <openssl/ct.h>
17
#include <openssl/err.h>
18
#include "fuzzer.h"
19
20
int FuzzerInitialize(int *argc, char ***argv)
21
108
{
22
108
    OPENSSL_init_crypto(OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL);
23
108
    CRYPTO_free_ex_index(0, -1);
24
108
    ERR_clear_error();
25
108
    return 1;
26
108
}
27
28
int FuzzerTestOneInput(const uint8_t *buf, size_t len)
29
6.16k
{
30
6.16k
    const uint8_t **pp = &buf;
31
6.16k
    unsigned char *der = NULL;
32
6.16k
    STACK_OF(SCT) *scts = d2i_SCT_LIST(NULL, pp, len);
33
6.16k
    if (scts != NULL) {
34
2.26k
        BIO *bio = BIO_new(BIO_s_null());
35
2.26k
        SCT_LIST_print(scts, bio, 4, "\n", NULL);
36
2.26k
        BIO_free(bio);
37
38
2.26k
        if (i2d_SCT_LIST(scts, &der)) {
39
            /* Silence unused result warning */
40
2.26k
        }
41
2.26k
        OPENSSL_free(der);
42
43
2.26k
        SCT_LIST_free(scts);
44
2.26k
    }
45
6.16k
    ERR_clear_error();
46
6.16k
    return 0;
47
6.16k
}
48
49
void FuzzerCleanup(void)
50
0
{
51
0
}