MFcalloutng:
Extend condvar(9) KPI introducing sbt variant of cv_timedwait. This rely on the previously committed sleepq_set_timeout_sbt(). Sponsored by: Google Summer of Code 2012, iXsystems inc. Tested by: flo, marius, ian, markj, Fabian Keil
This commit is contained in:
parent
9392b519d7
commit
7395c58e52
@ -270,12 +270,13 @@ _cv_wait_sig(struct cv *cvp, struct lock_object *lock)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Wait on a condition variable for at most timo/hz seconds. Returns 0 if the
|
* Wait on a condition variable for (at most) the value specified in sbt
|
||||||
* process was resumed by cv_signal or cv_broadcast, EWOULDBLOCK if the timeout
|
* argument. Returns 0 if the process was resumed by cv_signal or cv_broadcast,
|
||||||
* expires.
|
* EWOULDBLOCK if the timeout expires.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
_cv_timedwait(struct cv *cvp, struct lock_object *lock, int timo)
|
_cv_timedwait_sbt(struct cv *cvp, struct lock_object *lock, sbintime_t sbt,
|
||||||
|
sbintime_t pr, int flags)
|
||||||
{
|
{
|
||||||
WITNESS_SAVE_DECL(lock_witness);
|
WITNESS_SAVE_DECL(lock_witness);
|
||||||
struct lock_class *class;
|
struct lock_class *class;
|
||||||
@ -311,7 +312,7 @@ _cv_timedwait(struct cv *cvp, struct lock_object *lock, int timo)
|
|||||||
DROP_GIANT();
|
DROP_GIANT();
|
||||||
|
|
||||||
sleepq_add(cvp, lock, cvp->cv_description, SLEEPQ_CONDVAR, 0);
|
sleepq_add(cvp, lock, cvp->cv_description, SLEEPQ_CONDVAR, 0);
|
||||||
sleepq_set_timeout(cvp, timo);
|
sleepq_set_timeout_sbt(cvp, sbt, pr, flags);
|
||||||
if (lock != &Giant.lock_object) {
|
if (lock != &Giant.lock_object) {
|
||||||
if (class->lc_flags & LC_SLEEPABLE)
|
if (class->lc_flags & LC_SLEEPABLE)
|
||||||
sleepq_release(cvp);
|
sleepq_release(cvp);
|
||||||
@ -336,13 +337,15 @@ _cv_timedwait(struct cv *cvp, struct lock_object *lock, int timo)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Wait on a condition variable for at most timo/hz seconds, allowing
|
* Wait on a condition variable for (at most) the value specified in sbt
|
||||||
* interruption by signals. Returns 0 if the thread was resumed by cv_signal
|
* argument, allowing interruption by signals.
|
||||||
* or cv_broadcast, EWOULDBLOCK if the timeout expires, and EINTR or ERESTART if
|
* Returns 0 if the thread was resumed by cv_signal or cv_broadcast,
|
||||||
* a signal was caught.
|
* EWOULDBLOCK if the timeout expires, and EINTR or ERESTART if a signal
|
||||||
|
* was caught.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
_cv_timedwait_sig(struct cv *cvp, struct lock_object *lock, int timo)
|
_cv_timedwait_sig_sbt(struct cv *cvp, struct lock_object *lock,
|
||||||
|
sbintime_t sbt, sbintime_t pr, int flags)
|
||||||
{
|
{
|
||||||
WITNESS_SAVE_DECL(lock_witness);
|
WITNESS_SAVE_DECL(lock_witness);
|
||||||
struct lock_class *class;
|
struct lock_class *class;
|
||||||
@ -379,7 +382,7 @@ _cv_timedwait_sig(struct cv *cvp, struct lock_object *lock, int timo)
|
|||||||
|
|
||||||
sleepq_add(cvp, lock, cvp->cv_description, SLEEPQ_CONDVAR |
|
sleepq_add(cvp, lock, cvp->cv_description, SLEEPQ_CONDVAR |
|
||||||
SLEEPQ_INTERRUPTIBLE, 0);
|
SLEEPQ_INTERRUPTIBLE, 0);
|
||||||
sleepq_set_timeout(cvp, timo);
|
sleepq_set_timeout_sbt(cvp, sbt, pr, flags);
|
||||||
if (lock != &Giant.lock_object) {
|
if (lock != &Giant.lock_object) {
|
||||||
if (class->lc_flags & LC_SLEEPABLE)
|
if (class->lc_flags & LC_SLEEPABLE)
|
||||||
sleepq_release(cvp);
|
sleepq_release(cvp);
|
||||||
|
@ -55,8 +55,10 @@ void cv_destroy(struct cv *cvp);
|
|||||||
void _cv_wait(struct cv *cvp, struct lock_object *lock);
|
void _cv_wait(struct cv *cvp, struct lock_object *lock);
|
||||||
void _cv_wait_unlock(struct cv *cvp, struct lock_object *lock);
|
void _cv_wait_unlock(struct cv *cvp, struct lock_object *lock);
|
||||||
int _cv_wait_sig(struct cv *cvp, struct lock_object *lock);
|
int _cv_wait_sig(struct cv *cvp, struct lock_object *lock);
|
||||||
int _cv_timedwait(struct cv *cvp, struct lock_object *lock, int timo);
|
int _cv_timedwait_sbt(struct cv *cvp, struct lock_object *lock,
|
||||||
int _cv_timedwait_sig(struct cv *cvp, struct lock_object *lock, int timo);
|
sbintime_t sbt, sbintime_t pr, int flags);
|
||||||
|
int _cv_timedwait_sig_sbt(struct cv *cvp, struct lock_object *lock,
|
||||||
|
sbintime_t sbt, sbintime_t pr, int flags);
|
||||||
|
|
||||||
void cv_signal(struct cv *cvp);
|
void cv_signal(struct cv *cvp);
|
||||||
void cv_broadcastpri(struct cv *cvp, int pri);
|
void cv_broadcastpri(struct cv *cvp, int pri);
|
||||||
@ -68,9 +70,15 @@ void cv_broadcastpri(struct cv *cvp, int pri);
|
|||||||
#define cv_wait_sig(cvp, lock) \
|
#define cv_wait_sig(cvp, lock) \
|
||||||
_cv_wait_sig((cvp), &(lock)->lock_object)
|
_cv_wait_sig((cvp), &(lock)->lock_object)
|
||||||
#define cv_timedwait(cvp, lock, timo) \
|
#define cv_timedwait(cvp, lock, timo) \
|
||||||
_cv_timedwait((cvp), &(lock)->lock_object, (timo))
|
_cv_timedwait_sbt((cvp), &(lock)->lock_object, \
|
||||||
|
tick_sbt * (timo), 0, C_HARDCLOCK)
|
||||||
|
#define cv_timedwait_sbt(cvp, lock, sbt, pr, flags) \
|
||||||
|
_cv_timedwait_sbt((cvp), &(lock)->lock_object, (sbt), (pr), (flags))
|
||||||
#define cv_timedwait_sig(cvp, lock, timo) \
|
#define cv_timedwait_sig(cvp, lock, timo) \
|
||||||
_cv_timedwait_sig((cvp), &(lock)->lock_object, (timo))
|
_cv_timedwait_sig_sbt((cvp), &(lock)->lock_object, \
|
||||||
|
tick_sbt * (timo), 0, C_HARDCLOCK)
|
||||||
|
#define cv_timedwait_sig_sbt(cvp, lock, sbt, pr, flags) \
|
||||||
|
_cv_timedwait_sig_sbt((cvp), &(lock)->lock_object, (sbt), (pr), (flags))
|
||||||
|
|
||||||
#define cv_broadcast(cvp) cv_broadcastpri(cvp, 0)
|
#define cv_broadcast(cvp) cv_broadcastpri(cvp, 0)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user