Coverage Report

Created: 2026-06-10 06:19

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/nghttp2/lib/nghttp2_ratelim.c
Line
Count
Source
1
/*
2
 * nghttp2 - HTTP/2 C Library
3
 *
4
 * Copyright (c) 2023 nghttp2 contributors
5
 *
6
 * Permission is hereby granted, free of charge, to any person obtaining
7
 * a copy of this software and associated documentation files (the
8
 * "Software"), to deal in the Software without restriction, including
9
 * without limitation the rights to use, copy, modify, merge, publish,
10
 * distribute, sublicense, and/or sell copies of the Software, and to
11
 * permit persons to whom the Software is furnished to do so, subject to
12
 * the following conditions:
13
 *
14
 * The above copyright notice and this permission notice shall be
15
 * included in all copies or substantial portions of the Software.
16
 *
17
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
18
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
20
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
21
 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
22
 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
23
 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24
 */
25
#include "nghttp2_ratelim.h"
26
#include "nghttp2_helper.h"
27
28
47.9k
void nghttp2_ratelim_init(nghttp2_ratelim *rl, uint64_t burst, uint64_t rate) {
29
47.9k
  *rl = (nghttp2_ratelim){
30
47.9k
    .burst = burst,
31
47.9k
    .rate = rate,
32
47.9k
    .val = burst,
33
47.9k
  };
34
47.9k
}
35
36
60.3k
void nghttp2_ratelim_update(nghttp2_ratelim *rl, uint64_t tstamp) {
37
60.3k
  uint64_t d, gain;
38
39
60.3k
  if (tstamp == rl->tstamp) {
40
55.7k
    return;
41
55.7k
  }
42
43
4.58k
  if (tstamp > rl->tstamp) {
44
4.58k
    d = tstamp - rl->tstamp;
45
4.58k
  } else {
46
0
    d = 1;
47
0
  }
48
49
4.58k
  rl->tstamp = tstamp;
50
51
4.58k
  if (UINT64_MAX / d < rl->rate) {
52
0
    rl->val = rl->burst;
53
54
0
    return;
55
0
  }
56
57
4.58k
  gain = rl->rate * d;
58
59
4.58k
  if (UINT64_MAX - gain < rl->val) {
60
0
    rl->val = rl->burst;
61
62
0
    return;
63
0
  }
64
65
4.58k
  rl->val += gain;
66
4.58k
  rl->val = nghttp2_min_uint64(rl->val, rl->burst);
67
4.58k
}
68
69
60.3k
int nghttp2_ratelim_drain(nghttp2_ratelim *rl, uint64_t n) {
70
60.3k
  if (rl->val < n) {
71
30
    return -1;
72
30
  }
73
74
60.3k
  rl->val -= n;
75
76
60.3k
  return 0;
77
60.3k
}