Coverage Report

Created: 2024-05-21 06:52

/src/nghttp2/lib/nghttp2_ratelim.c
Line
Count
Source (jump to first uncovered line)
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
13.0k
void nghttp2_ratelim_init(nghttp2_ratelim *rl, uint64_t burst, uint64_t rate) {
29
13.0k
  rl->val = rl->burst = burst;
30
13.0k
  rl->rate = rate;
31
13.0k
  rl->tstamp = 0;
32
13.0k
}
33
34
0
void nghttp2_ratelim_update(nghttp2_ratelim *rl, uint64_t tstamp) {
35
0
  uint64_t d, gain;
36
37
0
  if (tstamp == rl->tstamp) {
38
0
    return;
39
0
  }
40
41
0
  if (tstamp > rl->tstamp) {
42
0
    d = tstamp - rl->tstamp;
43
0
  } else {
44
0
    d = 1;
45
0
  }
46
47
0
  rl->tstamp = tstamp;
48
49
0
  if (UINT64_MAX / d < rl->rate) {
50
0
    rl->val = rl->burst;
51
52
0
    return;
53
0
  }
54
55
0
  gain = rl->rate * d;
56
57
0
  if (UINT64_MAX - gain < rl->val) {
58
0
    rl->val = rl->burst;
59
60
0
    return;
61
0
  }
62
63
0
  rl->val += gain;
64
0
  rl->val = nghttp2_min_uint64(rl->val, rl->burst);
65
0
}
66
67
0
int nghttp2_ratelim_drain(nghttp2_ratelim *rl, uint64_t n) {
68
0
  if (rl->val < n) {
69
0
    return -1;
70
0
  }
71
72
0
  rl->val -= n;
73
74
0
  return 0;
75
0
}