Coverage Report

Created: 2025-11-16 06:40

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl33/crypto/err/err_mark.c
Line
Count
Source
1
/*
2
 * Copyright 2003-2023 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
#define OSSL_FORCE_ERR_STATE
11
12
#include <openssl/err.h>
13
#include "err_local.h"
14
15
int ERR_set_mark(void)
16
187M
{
17
187M
    ERR_STATE *es;
18
19
187M
    es = ossl_err_get_state_int();
20
187M
    if (es == NULL)
21
0
        return 0;
22
23
187M
    if (es->bottom == es->top)
24
180M
        return 0;
25
6.84M
    es->err_marks[es->top]++;
26
6.84M
    return 1;
27
187M
}
28
29
int ERR_pop(void)
30
0
{
31
0
    ERR_STATE *es;
32
33
0
    es = ossl_err_get_state_int();
34
0
    if (es == NULL || es->bottom == es->top)
35
0
        return 0;
36
37
0
    err_clear(es, es->top, 0);
38
0
    es->top = es->top > 0 ? es->top - 1 : ERR_NUM_ERRORS - 1;
39
0
    return 1;
40
0
}
41
42
int ERR_pop_to_mark(void)
43
313M
{
44
313M
    ERR_STATE *es;
45
46
313M
    es = ossl_err_get_state_int();
47
313M
    if (es == NULL)
48
0
        return 0;
49
50
542M
    while (es->bottom != es->top
51
233M
           && es->err_marks[es->top] == 0) {
52
229M
        err_clear(es, es->top, 0);
53
229M
        es->top = es->top > 0 ? es->top - 1 : ERR_NUM_ERRORS - 1;
54
229M
    }
55
56
313M
    if (es->bottom == es->top)
57
309M
        return 0;
58
4.37M
    es->err_marks[es->top]--;
59
4.37M
    return 1;
60
313M
}
61
62
int ERR_count_to_mark(void)
63
71.9M
{
64
71.9M
    ERR_STATE *es;
65
71.9M
    int count = 0, top;
66
67
71.9M
    es = ossl_err_get_state_int();
68
71.9M
    if (es == NULL)
69
0
        return 0;
70
71
71.9M
    top = es->top;
72
71.9M
    while (es->bottom != top
73
655k
           && es->err_marks[top] == 0) {
74
23.9k
        ++count;
75
23.9k
        top = top > 0 ? top - 1 : ERR_NUM_ERRORS - 1;
76
23.9k
    }
77
78
71.9M
    return count;
79
71.9M
}
80
81
int ERR_clear_last_mark(void)
82
16.4M
{
83
16.4M
    ERR_STATE *es;
84
16.4M
    int top;
85
86
16.4M
    es = ossl_err_get_state_int();
87
16.4M
    if (es == NULL)
88
0
        return 0;
89
90
16.4M
    top = es->top;
91
24.1M
    while (es->bottom != top
92
9.68M
           && es->err_marks[top] == 0) {
93
7.71M
        top = top > 0 ? top - 1 : ERR_NUM_ERRORS - 1;
94
7.71M
    }
95
96
16.4M
    if (es->bottom == top)
97
14.4M
        return 0;
98
1.97M
    es->err_marks[top]--;
99
1.97M
    return 1;
100
16.4M
}
101