Coverage Report

Created: 2025-08-28 07:07

/src/openssl35/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
200
{
22
200
    OPENSSL_init_crypto(OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL);
23
200
    CRYPTO_free_ex_index(0, -1);
24
200
    ERR_clear_error();
25
200
    return 1;
26
200
}
27
28
int FuzzerTestOneInput(const uint8_t *buf, size_t len)
29
8.69k
{
30
8.69k
    const uint8_t **pp = &buf;
31
8.69k
    unsigned char *der = NULL;
32
8.69k
    STACK_OF(SCT) *scts = d2i_SCT_LIST(NULL, pp, len);
33
8.69k
    if (scts != NULL) {
34
3.07k
        BIO *bio = BIO_new(BIO_s_null());
35
3.07k
        SCT_LIST_print(scts, bio, 4, "\n", NULL);
36
3.07k
        BIO_free(bio);
37
38
3.07k
        if (i2d_SCT_LIST(scts, &der)) {
39
            /* Silence unused result warning */
40
3.07k
        }
41
3.07k
        OPENSSL_free(der);
42
43
3.07k
        SCT_LIST_free(scts);
44
3.07k
    }
45
8.69k
    ERR_clear_error();
46
8.69k
    return 0;
47
8.69k
}
48
49
void FuzzerCleanup(void)
50
0
{
51
0
}