diff options
author | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2005-04-13 18:46:35 +0000 |
---|---|---|
committer | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2005-04-13 18:46:35 +0000 |
commit | a5898b4c0d9f7147f38315d743ca62c16e2ac85c (patch) | |
tree | ed66eb46d3b93acb448045522a038880b557ffee /sched.c | |
parent | 30a4d0bfa84b4ac6d7a2e43a265a7bb47db657ac (diff) |
Add sched_when function (bug #4022)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@5466 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'sched.c')
-rwxr-xr-x | sched.c | 25 |
1 files changed, 25 insertions, 0 deletions
@@ -399,3 +399,28 @@ int ast_sched_runq(struct sched_context *con) ast_mutex_unlock(&con->lock); return x; } + +long ast_sched_when(struct sched_context *con,int id) +{ + struct sched *s; + long secs; + struct timeval now; + DEBUG(ast_log(LOG_DEBUG, "ast_sched_when()\n")); + + ast_mutex_lock(&con->lock); + s=con->schedq; + while (s!=NULL) { + if (s->id==id) break; + s=s->next; + } + secs=-1; + if (s!=NULL) { + if (gettimeofday(&now, NULL)) { + ast_log(LOG_NOTICE, "gettimeofday() failed!\n"); + } else { + secs=s->when.tv_sec-now.tv_sec; + } + } + ast_mutex_unlock(&con->lock); + return secs; +} |