153a5a1b3Sopenharmony_ci/*** 253a5a1b3Sopenharmony_ci This file is part of PulseAudio. 353a5a1b3Sopenharmony_ci 453a5a1b3Sopenharmony_ci Copyright 2009 Lennart Poettering 553a5a1b3Sopenharmony_ci 653a5a1b3Sopenharmony_ci PulseAudio is free software; you can redistribute it and/or modify 753a5a1b3Sopenharmony_ci it under the terms of the GNU Lesser General Public License as 853a5a1b3Sopenharmony_ci published by the Free Software Foundation; either version 2.1 of the 953a5a1b3Sopenharmony_ci License, or (at your option) any later version. 1053a5a1b3Sopenharmony_ci 1153a5a1b3Sopenharmony_ci PulseAudio is distributed in the hope that it will be useful, but 1253a5a1b3Sopenharmony_ci WITHOUT ANY WARRANTY; without even the implied warranty of 1353a5a1b3Sopenharmony_ci MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 1453a5a1b3Sopenharmony_ci General Public License for more details. 1553a5a1b3Sopenharmony_ci 1653a5a1b3Sopenharmony_ci You should have received a copy of the GNU Lesser General Public 1753a5a1b3Sopenharmony_ci License along with PulseAudio; if not, see <http://www.gnu.org/licenses/>. 1853a5a1b3Sopenharmony_ci***/ 1953a5a1b3Sopenharmony_ci 2053a5a1b3Sopenharmony_ci#ifdef HAVE_CONFIG_H 2153a5a1b3Sopenharmony_ci#include <config.h> 2253a5a1b3Sopenharmony_ci#endif 2353a5a1b3Sopenharmony_ci 2453a5a1b3Sopenharmony_ci#include <pulse/rtclock.h> 2553a5a1b3Sopenharmony_ci 2653a5a1b3Sopenharmony_ci#include <pulsecore/log.h> 2753a5a1b3Sopenharmony_ci#include <pulsecore/mutex.h> 2853a5a1b3Sopenharmony_ci 2953a5a1b3Sopenharmony_ci#include "ratelimit.h" 3053a5a1b3Sopenharmony_ci 3153a5a1b3Sopenharmony_cistatic pa_static_mutex mutex = PA_STATIC_MUTEX_INIT; 3253a5a1b3Sopenharmony_ci 3353a5a1b3Sopenharmony_ci/* Modelled after Linux' lib/ratelimit.c by Dave Young 3453a5a1b3Sopenharmony_ci * <hidave.darkstar@gmail.com>, which is licensed GPLv2. */ 3553a5a1b3Sopenharmony_ci 3653a5a1b3Sopenharmony_cibool pa_ratelimit_test(pa_ratelimit *r, pa_log_level_t t) { 3753a5a1b3Sopenharmony_ci pa_usec_t now; 3853a5a1b3Sopenharmony_ci pa_mutex *m; 3953a5a1b3Sopenharmony_ci 4053a5a1b3Sopenharmony_ci now = pa_rtclock_now(); 4153a5a1b3Sopenharmony_ci 4253a5a1b3Sopenharmony_ci m = pa_static_mutex_get(&mutex, false, false); 4353a5a1b3Sopenharmony_ci pa_mutex_lock(m); 4453a5a1b3Sopenharmony_ci 4553a5a1b3Sopenharmony_ci pa_assert(r); 4653a5a1b3Sopenharmony_ci pa_assert(r->interval > 0); 4753a5a1b3Sopenharmony_ci pa_assert(r->burst > 0); 4853a5a1b3Sopenharmony_ci 4953a5a1b3Sopenharmony_ci if (r->begin <= 0 || 5053a5a1b3Sopenharmony_ci r->begin + r->interval < now) { 5153a5a1b3Sopenharmony_ci 5253a5a1b3Sopenharmony_ci if (r->n_missed > 0) 5353a5a1b3Sopenharmony_ci pa_logl(t, "%u events suppressed", r->n_missed); 5453a5a1b3Sopenharmony_ci 5553a5a1b3Sopenharmony_ci r->begin = now; 5653a5a1b3Sopenharmony_ci 5753a5a1b3Sopenharmony_ci /* Reset counters */ 5853a5a1b3Sopenharmony_ci r->n_printed = 0; 5953a5a1b3Sopenharmony_ci r->n_missed = 0; 6053a5a1b3Sopenharmony_ci goto good; 6153a5a1b3Sopenharmony_ci } 6253a5a1b3Sopenharmony_ci 6353a5a1b3Sopenharmony_ci if (r->n_printed <= r->burst) 6453a5a1b3Sopenharmony_ci goto good; 6553a5a1b3Sopenharmony_ci 6653a5a1b3Sopenharmony_ci r->n_missed++; 6753a5a1b3Sopenharmony_ci pa_mutex_unlock(m); 6853a5a1b3Sopenharmony_ci return false; 6953a5a1b3Sopenharmony_ci 7053a5a1b3Sopenharmony_cigood: 7153a5a1b3Sopenharmony_ci r->n_printed++; 7253a5a1b3Sopenharmony_ci pa_mutex_unlock(m); 7353a5a1b3Sopenharmony_ci return true; 7453a5a1b3Sopenharmony_ci} 75