diff options
author | Richard Braun <rbraun@sceen.net> | 2017-08-27 17:20:12 +0200 |
---|---|---|
committer | Richard Braun <rbraun@sceen.net> | 2017-08-27 17:20:12 +0200 |
commit | cbf35081fabde1ce35cbaf223fde853db86e06d4 (patch) | |
tree | a6215d6335ec42e33da4b6aadfa1b3c0be9c860b /kern/semaphore.h | |
parent | 094319b4a0a04ae11e24b44bb67aaf901536afb2 (diff) | |
parent | 70f7512a01ba8f90aad6dbb4d285e279f0e17e64 (diff) |
Merge branch 'timer_system'
Diffstat (limited to 'kern/semaphore.h')
-rw-r--r-- | kern/semaphore.h | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/kern/semaphore.h b/kern/semaphore.h index e08927ec..e1acbf21 100644 --- a/kern/semaphore.h +++ b/kern/semaphore.h @@ -33,6 +33,7 @@ #define _KERN_SEMAPHORE_H #include <assert.h> +#include <stdint.h> #include <kern/atomic.h> #include <kern/error.h> @@ -93,6 +94,20 @@ semaphore_wait(struct semaphore *semaphore) } } +static inline int +semaphore_timedwait(struct semaphore *semaphore, uint64_t ticks) +{ + unsigned int prev; + + prev = semaphore_dec(semaphore); + + if (unlikely(prev == 0)) { + return semaphore_timedwait_slow(semaphore, ticks); + } + + return 0; +} + /* * Unlock a semaphore. * |