projects
/
urcu.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix: don't wait after completion of job batch if work queue is empty
[urcu.git]
/
src
/
workqueue.c
diff --git
a/src/workqueue.c
b/src/workqueue.c
index db0c63abf711307e995b3bd5cb372f560bd83711..0b1a9eae41f91ba5bad8dc7e43db2731707d8854 100644
(file)
--- a/
src/workqueue.c
+++ b/
src/workqueue.c
@@
-221,11
+221,11
@@
static void *workqueue_thread(void *arg)
cbcount = 0;
__cds_wfcq_for_each_blocking_safe(&cbs_tmp_head,
&cbs_tmp_tail, cbs, cbs_tmp_n) {
cbcount = 0;
__cds_wfcq_for_each_blocking_safe(&cbs_tmp_head,
&cbs_tmp_tail, cbs, cbs_tmp_n) {
- struct
rcu_head *rh
p;
+ struct
urcu_work *uw
p;
-
rh
p = caa_container_of(cbs,
- struct
rcu_head
, next);
-
rhp->func(rh
p);
+
uw
p = caa_container_of(cbs,
+ struct
urcu_work
, next);
+
uwp->func(uw
p);
cbcount++;
}
uatomic_sub(&workqueue->qlen, cbcount);
cbcount++;
}
uatomic_sub(&workqueue->qlen, cbcount);
@@
-238,7
+238,6
@@
static void *workqueue_thread(void *arg)
if (cds_wfcq_empty(&workqueue->cbs_head,
&workqueue->cbs_tail)) {
futex_wait(&workqueue->futex);
if (cds_wfcq_empty(&workqueue->cbs_head,
&workqueue->cbs_tail)) {
futex_wait(&workqueue->futex);
- (void) poll(NULL, 0, 10);
uatomic_dec(&workqueue->futex);
/*
* Decrement futex before reading
uatomic_dec(&workqueue->futex);
/*
* Decrement futex before reading
This page took
0.024298 seconds
and
4
git commands to generate.