xref: /aosp_15_r20/external/pigweed/pw_log/rate_limited.cc (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1*61c4878aSAndroid Build Coastguard Worker // Copyright 2024 The Pigweed Authors
2*61c4878aSAndroid Build Coastguard Worker //
3*61c4878aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); you may not
4*61c4878aSAndroid Build Coastguard Worker // use this file except in compliance with the License. You may obtain a copy of
5*61c4878aSAndroid Build Coastguard Worker // the License at
6*61c4878aSAndroid Build Coastguard Worker //
7*61c4878aSAndroid Build Coastguard Worker //     https://www.apache.org/licenses/LICENSE-2.0
8*61c4878aSAndroid Build Coastguard Worker //
9*61c4878aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*61c4878aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11*61c4878aSAndroid Build Coastguard Worker // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12*61c4878aSAndroid Build Coastguard Worker // License for the specific language governing permissions and limitations under
13*61c4878aSAndroid Build Coastguard Worker // the License.
14*61c4878aSAndroid Build Coastguard Worker 
15*61c4878aSAndroid Build Coastguard Worker #include "pw_log/rate_limited.h"
16*61c4878aSAndroid Build Coastguard Worker 
17*61c4878aSAndroid Build Coastguard Worker namespace pw::log::internal {
18*61c4878aSAndroid Build Coastguard Worker 
Poll(chrono::SystemClock::duration min_interval_between_logs)19*61c4878aSAndroid Build Coastguard Worker RateLimiter::PollResult RateLimiter::Poll(
20*61c4878aSAndroid Build Coastguard Worker     chrono::SystemClock::duration min_interval_between_logs) {
21*61c4878aSAndroid Build Coastguard Worker   PollResult result({
22*61c4878aSAndroid Build Coastguard Worker       .count = 0,
23*61c4878aSAndroid Build Coastguard Worker       .logs_per_s = 0,
24*61c4878aSAndroid Build Coastguard Worker   });
25*61c4878aSAndroid Build Coastguard Worker   const chrono::SystemClock::time_point now = chrono::SystemClock::now();
26*61c4878aSAndroid Build Coastguard Worker   const chrono::SystemClock::duration elapsed = now - last_timestamp_;
27*61c4878aSAndroid Build Coastguard Worker 
28*61c4878aSAndroid Build Coastguard Worker   if (count_ < std::numeric_limits<uint16_t>::max()) {
29*61c4878aSAndroid Build Coastguard Worker     count_++;
30*61c4878aSAndroid Build Coastguard Worker   }
31*61c4878aSAndroid Build Coastguard Worker 
32*61c4878aSAndroid Build Coastguard Worker   if (last_timestamp_.time_since_epoch().count() != 0 &&
33*61c4878aSAndroid Build Coastguard Worker       elapsed < min_interval_between_logs) {
34*61c4878aSAndroid Build Coastguard Worker     return result;
35*61c4878aSAndroid Build Coastguard Worker   }
36*61c4878aSAndroid Build Coastguard Worker 
37*61c4878aSAndroid Build Coastguard Worker   // Add half to round not floor.
38*61c4878aSAndroid Build Coastguard Worker   uint16_t elapsed_ms =
39*61c4878aSAndroid Build Coastguard Worker       std::chrono::duration_cast<std::chrono::milliseconds>(elapsed).count();
40*61c4878aSAndroid Build Coastguard Worker   if (elapsed_ms != 0) {
41*61c4878aSAndroid Build Coastguard Worker     result.logs_per_s = (count_ * 1000 + 500) / elapsed_ms;
42*61c4878aSAndroid Build Coastguard Worker   }
43*61c4878aSAndroid Build Coastguard Worker   result.count = count_;
44*61c4878aSAndroid Build Coastguard Worker 
45*61c4878aSAndroid Build Coastguard Worker   last_timestamp_ = now;
46*61c4878aSAndroid Build Coastguard Worker   count_ = 0;
47*61c4878aSAndroid Build Coastguard Worker 
48*61c4878aSAndroid Build Coastguard Worker   return result;
49*61c4878aSAndroid Build Coastguard Worker }
50*61c4878aSAndroid Build Coastguard Worker 
51*61c4878aSAndroid Build Coastguard Worker }  // namespace pw::log::internal