#define _BSD_SOURCE
#define _GNU_SOURCE
#define _LGPL_SOURCE
+#define _DEFAULT_SOURCE
#include <stdio.h>
#include <pthread.h>
#include <signal.h>
_CMM_STORE_SHARED(URCU_TLS(rcu_reader).need_mb, 0);
cmm_smp_mb();
}
- poll(NULL,0,10);
+ (void) poll(NULL, 0, 10);
}
#endif /* #else #ifndef DISTRUST_SIGNALS_EXTREME */
}
cds_list_for_each_entry(index, ®istry, node) {
while (CMM_LOAD_SHARED(index->need_mb)) {
pthread_kill(index->tid, SIGRCU);
- poll(NULL, 0, 1);
+ (void) poll(NULL, 0, 1);
}
}
cmm_smp_mb(); /* read ->need_mb before ending the barrier */
{
/* Read reader_gp before read futex */
smp_mb_master(RCU_MB_GROUP);
- if (uatomic_read(&rcu_gp.futex) == -1)
- futex_async(&rcu_gp.futex, FUTEX_WAIT, -1,
- NULL, NULL, 0);
+ if (uatomic_read(&rcu_gp.futex) != -1)
+ return;
+ while (futex_async(&rcu_gp.futex, FUTEX_WAIT, -1,
+ NULL, NULL, 0)) {
+ switch (errno) {
+ case EWOULDBLOCK:
+ /* Value already changed. */
+ return;
+ case EINTR:
+ /* Retry if interrupted by signal. */
+ break; /* Get out of switch. */
+ default:
+ /* Unexpected error. */
+ urcu_die(errno);
+ }
+ }
}
/*