summaryrefslogtreecommitdiff
path: root/res/res_timing_timerfd.c
diff options
context:
space:
mode:
authorRussell Bryant <russell@russellbryant.com>2009-03-02 23:06:16 +0000
committerRussell Bryant <russell@russellbryant.com>2009-03-02 23:06:16 +0000
commitd6652e97608126cd4f87e29bc9bd12546dec76d4 (patch)
tree827b690250ba1be11e9e31cf788361dbabc7a700 /res/res_timing_timerfd.c
parent0c0479602e577f449e97019554a3e708f30b93c1 (diff)
Fix a reference leak in timerfd_set_rate().
(found during a debugging session with dvossel and mmichelson.) git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@179465 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'res/res_timing_timerfd.c')
-rw-r--r--res/res_timing_timerfd.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/res/res_timing_timerfd.c b/res/res_timing_timerfd.c
index b1cbb04bd..9688758f9 100644
--- a/res/res_timing_timerfd.c
+++ b/res/res_timing_timerfd.c
@@ -134,6 +134,7 @@ static int timerfd_timer_set_rate(int handle, unsigned int rate)
struct timerfd_timer *our_timer, find_helper = {
.handle = handle,
};
+ int res;
if (!(our_timer = ao2_find(timerfd_timers, &find_helper, OBJ_POINTER))) {
ast_log(LOG_ERROR, "Couldn't find timer with handle %d\n", handle);
@@ -145,7 +146,11 @@ static int timerfd_timer_set_rate(int handle, unsigned int rate)
our_timer->saved_timer.it_interval.tv_sec = our_timer->saved_timer.it_value.tv_sec;
our_timer->saved_timer.it_interval.tv_nsec = our_timer->saved_timer.it_value.tv_nsec;
- return timerfd_settime(handle, 0, &our_timer->saved_timer, NULL);
+ res = timerfd_settime(handle, 0, &our_timer->saved_timer, NULL);
+
+ ao2_ref(our_timer, -1);
+
+ return res;
}
static void timerfd_timer_ack(int handle, unsigned int quantity)