Coverage Report

Created: 2026-04-09 06:50

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
359M
{
17
359M
    ERR_STATE *es;
18
19
359M
    es = ossl_err_get_state_int();
20
359M
    if (es == NULL)
21
0
        return 0;
22
23
359M
    if (es->bottom == es->top)
24
265M
        return 0;
25
94.5M
    es->err_marks[es->top]++;
26
94.5M
    return 1;
27
359M
}
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
335M
{
44
335M
    ERR_STATE *es;
45
46
335M
    es = ossl_err_get_state_int();
47
335M
    if (es == NULL)
48
0
        return 0;
49
50
583M
    while (es->bottom != es->top
51
337M
        && es->err_marks[es->top] == 0) {
52
248M
        err_clear(es, es->top, 0);
53
248M
        es->top = es->top > 0 ? es->top - 1 : ERR_NUM_ERRORS - 1;
54
248M
    }
55
56
335M
    if (es->bottom == es->top)
57
245M
        return 0;
58
89.1M
    es->err_marks[es->top]--;
59
89.1M
    return 1;
60
335M
}
61
62
int ERR_count_to_mark(void)
63
73.9M
{
64
73.9M
    ERR_STATE *es;
65
73.9M
    int count = 0, top;
66
67
73.9M
    es = ossl_err_get_state_int();
68
73.9M
    if (es == NULL)
69
0
        return 0;
70
71
73.9M
    top = es->top;
72
73.9M
    while (es->bottom != top
73
951k
        && es->err_marks[top] == 0) {
74
37.5k
        ++count;
75
37.5k
        top = top > 0 ? top - 1 : ERR_NUM_ERRORS - 1;
76
37.5k
    }
77
78
73.9M
    return count;
79
73.9M
}
80
81
int ERR_clear_last_mark(void)
82
24.7M
{
83
24.7M
    ERR_STATE *es;
84
24.7M
    int top;
85
86
24.7M
    es = ossl_err_get_state_int();
87
24.7M
    if (es == NULL)
88
0
        return 0;
89
90
24.7M
    top = es->top;
91
33.3M
    while (es->bottom != top
92
13.9M
        && es->err_marks[top] == 0) {
93
8.55M
        top = top > 0 ? top - 1 : ERR_NUM_ERRORS - 1;
94
8.55M
    }
95
96
24.7M
    if (es->bottom == top)
97
19.3M
        return 0;
98
5.35M
    es->err_marks[top]--;
99
5.35M
    return 1;
100
24.7M
}