projects
/
urcu.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Refactor liburcu to support many flavors per compile unit
[urcu.git]
/
src
/
workqueue.c
diff --git
a/src/workqueue.c
b/src/workqueue.c
index db0c63abf711307e995b3bd5cb372f560bd83711..14957a0d3910aa83740d4e22b5420aa48658cf84 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,18
+238,18
@@
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
* urcu_work list.
*/
cmm_smp_mb();
uatomic_dec(&workqueue->futex);
/*
* Decrement futex before reading
* urcu_work list.
*/
cmm_smp_mb();
- } else {
- (void) poll(NULL, 0, 10);
}
} else {
}
} else {
- (void) poll(NULL, 0, 10);
+ if (cds_wfcq_empty(&workqueue->cbs_head,
+ &workqueue->cbs_tail)) {
+ (void) poll(NULL, 0, 10);
+ }
}
if (workqueue->worker_after_wake_up_fct)
workqueue->worker_after_wake_up_fct(workqueue, workqueue->priv);
}
if (workqueue->worker_after_wake_up_fct)
workqueue->worker_after_wake_up_fct(workqueue, workqueue->priv);
This page took
0.03244 seconds
and
4
git commands to generate.