From: David M. Lee Date: Mon, 27 Aug 2012 16:40:45 +0000 (+0000) Subject: Fixes ast_rwlock_timed[rd|wr]lock for BSD and variants. X-Git-Tag: 1.8.17.0-rc1~46 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=c977fe4197808d71124dee5071360bebccfd223e;p=thirdparty%2Fasterisk.git Fixes ast_rwlock_timed[rd|wr]lock for BSD and variants. The original implementations simply wrap pthread functions, which take absolute time as an argument. The spinlock version for systems without those functions treated the argument as a delta. This patch fixes the spinlock version to be consistent with the pthread version. (closes issue ASTERISK-20240) Reported by: Egor Gorlin Patches: lock.c.patch uploaded by Egor Gorlin (license 6416) git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.8@371718 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/main/lock.c b/main/lock.c index c854b3d615..c48c71e7c9 100644 --- a/main/lock.c +++ b/main/lock.c @@ -1141,13 +1141,13 @@ int __ast_rwlock_timedrdlock(const char *filename, int line, const char *func, a res = pthread_rwlock_timedrdlock(&t->lock, abs_timeout); #else do { - struct timeval _start = ast_tvnow(), _diff; + struct timeval _now; for (;;) { if (!(res = pthread_rwlock_tryrdlock(&t->lock))) { break; } - _diff = ast_tvsub(ast_tvnow(), _start); - if (_diff.tv_sec > abs_timeout->tv_sec || (_diff.tv_sec == abs_timeout->tv_sec && _diff.tv_usec * 1000 > abs_timeout->tv_nsec)) { + _now = ast_tvnow(); + if (_now.tv_sec > abs_timeout->tv_sec || (_now.tv_sec == abs_timeout->tv_sec && _now.tv_usec * 1000 > abs_timeout->tv_nsec)) { break; } usleep(1); @@ -1244,13 +1244,13 @@ int __ast_rwlock_timedwrlock(const char *filename, int line, const char *func, a res = pthread_rwlock_timedwrlock(&t->lock, abs_timeout); #else do { - struct timeval _start = ast_tvnow(), _diff; + struct timeval _now; for (;;) { if (!(res = pthread_rwlock_trywrlock(&t->lock))) { break; } - _diff = ast_tvsub(ast_tvnow(), _start); - if (_diff.tv_sec > abs_timeout->tv_sec || (_diff.tv_sec == abs_timeout->tv_sec && _diff.tv_usec * 1000 > abs_timeout->tv_nsec)) { + _now = ast_tvnow(); + if (_now.tv_sec > abs_timeout->tv_sec || (_now.tv_sec == abs_timeout->tv_sec && _now.tv_usec * 1000 > abs_timeout->tv_nsec)) { break; } usleep(1);