/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 | } |