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 WorkerRateLimiter::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