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